X-Authentication-Warning: delorie.com: mail set sender to geda-user-bounces using -f X-Recipient: geda-user AT delorie DOT com X-Original-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=date:from:to:subject:message-id:in-reply-to:references:mime-version :content-type:content-transfer-encoding; bh=pHlWyF+ExNqbInYVObdy5NBVstVk8Zund54Qzo04sR0=; b=EoeMVDY8u3mICj90QLXWL+IWfhRfeRJs9zaCX/oO8M0iy5TatVae4P9+eTs3OOQ6pn 9ZxCza75OkWnXPfdNzdlvaNFxDqF4xnAhB1bxeIcaMgXKk0cCENq9zwSIAh9IMaFwyKb wRuWkrROSApuo9GD/O39PwB4s3FQjPIyttqypqFhRF4cH6T7nPlFZe/v70dw4rYLpAcO vZK2e9D1MYJMdhuvOp2MGY0iUUBi5nftmf+OVF5zY9MROxPGD6l15Z4nCr4HCFbVcXiA /DQVbiAc92AwToao5Ozt5VutqSCYrw7zNUN1sbp3Y2BDoY+sOqQ2S8mOmiJGueM5yohz +OYQ== X-Received: by 10.152.10.71 with SMTP id g7mr26919243lab.61.1440532118708; Tue, 25 Aug 2015 12:48:38 -0700 (PDT) Date: Tue, 25 Aug 2015 21:48:37 +0200 From: "Nicklas Karlsson (nicklas DOT karlsson17 AT gmail DOT com) [via geda-user AT delorie DOT com]" To: geda-user AT delorie DOT com Subject: Re: [geda-user] Re: off-topic: daydreaming about modularization Message-Id: <20150825214837.b071e888cb8f39e1015f4e9a@gmail.com> In-Reply-To: References: <6B8DDCCF-0E84-43DC-94A3-89CE0E56F0ED AT noqsi DOT com> <201508242052 DOT 28189 DOT ad252 AT freeelectron DOT net> <3766120C-93DD-454D-B2FA-7C79B78DC86C AT noqsi DOT com> <8DC5050C-49D2-49AD-94B0-A1FC857178E5 AT noqsi DOT com> <55DC6491 DOT 8030607 AT iae DOT nl> <3FA132D6-A8D9-47C8-8D37-E1962EF4098B AT noqsi DOT com> <55DCAA14 DOT 1030009 AT xs4all DOT nl> X-Mailer: Sylpheed 3.5.0beta1 (GTK+ 2.24.25; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Reply-To: geda-user AT delorie DOT com Errors-To: nobody AT delorie DOT com X-Mailing-List: geda-user AT delorie DOT com X-Unsubscribes-To: listserv AT delorie DOT com Precedence: bulk > Imagine if pcb was split up > * pcb-layout for just doing the GUI layout. > * pcb2net for people doing back annotation > * pcb2pdf for people exporting pdfs > * pcb2ps > * pcb2gcode > * pcb2bom > > And now imagine the biggest difference of all. Instead of one giant > program with poorly defined boundaries between layers you had > > * libpcbfile for moving between a memory representation of a layout > and the file that stores it > * libpcbgeo for processing geometric properties > * libpcbexport for translation to pdf, ps, png, jpeg > * libpcbnetlist for forward and backward annotation > * libpcbui for providing the HID interface Missing pcb2gerber I think it would work great, a button or menu item to run them is no big deal if anybody want that. I guess the storage library libpcbfile need functions to walk thru the objects in property value order or access the objects with a particular value. On top of that there would probably be a need for sorting functions. For exporting gerber you would extract the objects with the layer(s) property value for the layer which should be exported. The most critical point would be the interface functions in the storage library libpcbfile to access the objects in the layout.