missing NULL terminator in set_config_x
[geda-gaf.git] / docs / wiki / geda-usage.html
blob1416a64fdc9079c89553e78e6505a21afa9be5ff
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
3 <html>
4 <head>
5 <link rel="stylesheet" media="screen" type="text/css" href="./style.css" />
6 <link rel="stylesheet" media="screen" type="text/css" href="./design.css" />
7 <link rel="stylesheet" media="print" type="text/css" href="./print.css" />
9 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
10 </head>
11 <body>
13 <p>
14 <em>Translations of this page are also available in the following languages:</em> <a href="geda-usage.fr.html" class="wikilink1" title="geda-usage.fr.html">Français</a>, <a href="geda-usage.ru.html" class="wikilink1" title="geda-usage.ru.html">Русский</a>.
15 </p>
17 <h1 class="sectionedit1" id="what_s_the_best_way_to_learn_to_use_geda">What&#039;s the best way to learn to use gEDA?</h1>
18 <div class="level1">
20 <p>
21 The first thing to do is to read and understand Bill Wilson’s excellent <a href="geda-gsch2pcb_tutorial.html" class="wikilink1" title="geda-gsch2pcb_tutorial.html">gschem -&gt; gsch2pcb -&gt; PCB</a> tutorial and/or the DJ Delorie’s <a href="http://www.delorie.com/pcb/docs/gs/gs.html" class="urlextern" title="http://www.delorie.com/pcb/docs/gs/gs.html" rel="nofollow">pcb tutorial</a>. This should get you started.
22 </p>
24 <p>
25 Also be sure to check out the other <a href="http://geda.seul.org/wiki/geda:documentation" class="urlextern" title="http://geda.seul.org/wiki/geda:documentation" rel="nofollow">gEDA documentation</a> available on this website.
26 </p>
28 <p>
29 However, the best way to learn the gEDA Suite is to download it and try it out yourself! If you consult Bill Wilson’s tutorial while trying the suite for yourself, you will become an expert in no time!
30 </p>
32 </div>
33 <!-- EDIT1 SECTION "What's the best way to learn to use gEDA?" [132-777] -->
34 <h1 class="sectionedit2" id="what_does_the_design_flow_in_geda_look_like">What does the design flow in gEDA look like?</h1>
35 <div class="level1">
37 <p>
38 Here is a quick graphic for simple PCB design flow using the gEDA Suite:
39 </p>
41 <p>
42 <a href="media/geda/design_flow.jpg" class="media" target="_blank" title="geda:design_flow.jpg"><img src="media/geda/design_flow.jpg" class="media" alt="" /></a>
43 </p>
45 <p>
46 In words, the design flow for a simple PCB proceeds as follows:
47 </p>
48 <ol>
49 <li class="level1"><div class="li"> Create your schematic using “gschem”.</div>
50 </li>
51 <li class="level1"><div class="li"> Check your schematics with the DRC checker. Learn about it <a href="geda-faq-attribs.html#how_do_i_check_my_schematics" class="wikilink1" title="geda-faq-attribs.html">here</a>.</div>
52 </li>
53 <li class="level1"><div class="li"> Assign reference designators to your components using “grenum” or “refdes_renum” (or just attach them manually from within “gschem”).</div>
54 </li>
55 <li class="level1"><div class="li"> Assign other component attributes (such as component footprints) using “gattrib” (or just attach them manually using “gschem”).</div>
56 </li>
57 <li class="level1"><div class="li"> Create a preliminary layout file and netlist using “gsch2pcb”.</div>
58 </li>
59 <li class="level1"><div class="li"> Lay out and route your board using “pcb”.</div>
60 </li>
61 <li class="level1"><div class="li"> Output Gerbers from within “pcb” using “File → print layout”, and select “Gerber/RS274X” as the output file type.</div>
62 </li>
63 </ol>
65 <p>
66 If you make changes, or add to your schematic or attributes while in layout, update your board file like this:
67 </p>
68 <ol>
69 <li class="level1"><div class="li"> Edit your schematic and/or attributes (”gschem” or “gattrib”).</div>
70 </li>
71 <li class="level1"><div class="li"> Check your schematics with the DRC checker. Learn about it <a href="geda-faq-attribs.html#how_do_i_check_my_schematics" class="wikilink1" title="geda-faq-attribs.html">here</a>.</div>
72 </li>
73 <li class="level1"><div class="li"> Forward annotate your changes using “gsch2pcb”.</div>
74 </li>
75 <li class="level1"><div class="li"> From within “pcb”, update your components using “File → load layout data to paste buffer”, and then click on the drawing area to place the components.</div>
76 </li>
77 <li class="level1"><div class="li"> From within “pcb”, update your netlist using “File → load netlist file”.</div>
78 </li>
79 </ol>
81 <p>
82 Usually, users invoke the individual tools from the command line. A project manager (”geda”) exists, but needs improvement.
83 </p>
85 </div>
86 <!-- EDIT2 SECTION "What does the design flow in gEDA look like?" [778-2453] -->
87 <h1 class="sectionedit3" id="what_limitations_exist_for_the_geda_tools">What limitations exist for the gEDA tools?</h1>
88 <div class="level1">
90 <p>
91 The most important thing to keep in mind about gEDA’s limitations is this: GEDA is an open-source software project. It has some limitations, but unlike many instances of commercial software, its limitations are not artificial, arbitrary, or driven by marketeering. That is, gEDA is neither nagware, crippleware, demoware, nor “limited student edition”-ware. Any limitations to the gEDA tools exist because the programmers haven’t yet implemented that particular feature. Since the code is open for all to see and modify, anybody is welcome to implement a new feature or remove a limitation, and then submit their patches to the project. If you are a hacker and are interested in making a contribution to the gEDA project, consider tackling one of the limitations listed below! You will make a lot of friends, and earn international exposure!
92 </p>
93 <ul>
94 <li class="level1"><div class="li"> Hierarchical bus support: Support for hierarchical buses doesn’t exist yet.</div>
95 </li>
96 <li class="level1"><div class="li"> Net and pin attributes in gattrib: Attaching routing attributes for nets and pins in gattrib remains TBD. (Net attributes are useful for high-speed design. For example, it’s often important that all tracks in a bus have the same electrical length. Unfortunately, it’s not clear that PCB will support these routing attributes right now.)</div>
97 </li>
98 <li class="level1"><div class="li"> Backannotation from PCB to gschem. Support for pinswapping and modification of the design file in pcb with subsequent backanno to gschem is TBD.</div>
99 </li>
100 <li class="level1"><div class="li"> The project manager “geda” is out of date, and needs an update.</div>
101 </li>
102 <li class="level1"><div class="li"> Layer count in PCB: Currently, the layer count in PCB is limited to 16 layers plus two silk layers by default. This is more than adequate for small- and mid-sized projects. If necessary, the number of layers can be increased arbitrarily at compile time.</div>
103 </li>
104 </ul>
106 </div>
107 <!-- EDIT3 SECTION "What limitations exist for the gEDA tools?" [2454-4267] -->
108 <h1 class="sectionedit4" id="what_local_configuration_files_are_used_for_a_project">What local configuration files are used for a project?</h1>
109 <div class="level1">
112 A typical PCB design requires the following config files in your local directory:
113 </p>
114 <ul>
115 <li class="level1"><div class="li"> gafrc: This holds configuration info for the gEDA/gaf programs (i.e. gschem, gattrib, gnetlist, etc.). It should hold pointers to your local symbol directory (if any).</div>
116 </li>
117 <li class="level1"><div class="li"> attribs: If you use “gnetlist -g bom2” to create a project BOM, then you need this file in order to specify which attributes are written into the BOM.</div>
118 </li>
119 <li class="level1"><div class="li"> projectrc: When going to layout, “gsch2pcb projectrc” is a convenient way to specify paths to local footprint directories, as well as hold other configuration information for “gsch2pcb”. Note that this file may have any name you choose; I like to use projectrc since its name is suggestive of its function.</div>
120 </li>
121 </ul>
124 Further detailed information about each configuration file is provided in the <a href="http://geda.seul.org/wiki/geda:documentation" class="urlextern" title="http://geda.seul.org/wiki/geda:documentation" rel="nofollow">documentation</a> for each facility.
125 </p>
127 </div>
128 <!-- EDIT4 SECTION "What local configuration files are used for a project?" [4268-5232] -->
129 <h1 class="sectionedit5" id="what_are_the_names_and_locations_of_the_rc_files_used_with_geda_gaf_applications">What are the names and locations of the RC files used with gEDA/gaf applications?</h1>
130 <div class="level1">
133 The various gEDA/gaf applications (gschem, gattrib, gnetlist, etc.) use a set of RC files to set various configurable options in the tools themselves. These RC files are read in by each application upon start-up. Philosophically, there are three places where a gEDA/gaf application looks for RC files:
134 </p>
135 <ul>
136 <li class="level1"><div class="li"> In the system installation directory: <strong><code>${prefix}/share/gEDA/</code></strong>. This location holds RC files which are global to the entire system, and are common to all users. These RC files must be found and successfully loaded for the gEDA application to work properly. <strong><code>${prefix}</code></strong> is set to the path where you installed gEDA/gaf.</div>
137 </li>
138 <li class="level1"><div class="li"> In the user’s home directory: <strong><code>$HOME/.gEDA/</code></strong>. This location holds RC files which apply to all of this user’s projects. <strong><code>.gEDA</code></strong> is a directory. These files are optional. Do not just place a copy of the system-gschemrc (or whatever) into this directory; this will not work properly. The right thing to do is to override specific things you want to change.</div>
139 </li>
140 <li class="level1"><div class="li"> In the local project directory. This location holds RC files which apply to the local project (which also lives in this directory). These RC files provide specific overrides, such as component or source libraries. This file is also optional. Do not just place a copy of the system-gschemrc (or whatever) into this directory; this will not work properly.</div>
141 </li>
142 </ul>
145 The RC file system has evolved over time. Originally, each gEDA/gaf application used its own RC file (for example, gschem used gschemrc, gnetlist used gnetlistrc, and so on). However, as the number of gEDA/gaf applications grew, it became clear that the individual RC files held a lot of redundant information, and that new users were confused by all the different RC files. Therefore, the different RC files were consolidated into a single file, called “gafrc”. However, because gschem needs all kind of special customizations, we decided to keep the system gschemrc in addition to all the gafrc files. Also, in order to preserve backwards compatibility, the old RC file system is still maintained in the system directory. Accordingly, the current RC file configuration looks like this:
146 </p>
147 <ul>
148 <li class="level1 node"><div class="li"> In the system installation directory:</div>
149 <ul>
150 <li class="level2"><div class="li"> <strong><code>system-gafrc</code></strong> – This contains most of the global gaf settings.</div>
151 </li>
152 <li class="level2"><div class="li"> <strong><code>system-gattribrc</code></strong></div>
153 </li>
154 <li class="level2"><div class="li"> <strong><code>system-gnetlistrc</code></strong></div>
155 </li>
156 <li class="level2"><div class="li"> <strong><code>system-gschemrc</code></strong> – This contains lots of settings specific to gschem</div>
157 </li>
158 <li class="level2"><div class="li"> <strong><code>system-gschlasrc</code></strong></div>
159 </li>
160 <li class="level2"><div class="li"> <strong><code>system-gsymcheckrc</code></strong></div>
161 </li>
162 </ul>
163 </li>
164 <li class="level1 node"><div class="li"> In the user’s <strong><code>${HOME}</code></strong> directory:</div>
165 <ul>
166 <li class="level2"><div class="li"> <strong><code>.gEDA/gafrc</code></strong></div>
167 </li>
168 </ul>
169 </li>
170 <li class="level1 node"><div class="li"> In the local project directory:</div>
171 <ul>
172 <li class="level2"><div class="li"> <strong><code>gafrc</code></strong> – This should contain your local overrides, such as pointers to locally defined symbols.</div>
173 </li>
174 </ul>
175 </li>
176 </ul>
179 Also loaded by the system-gschemrc is the gschem-darkbg or gschem-lightbg color definitions.
180 </p>
183 Finally, note that gEDA/gaf applications will look for up to six configuration files upon startup:
184 </p>
185 <ol>
186 <li class="level1"><div class="li"> <strong><code>system-gafrc</code></strong></div>
187 </li>
188 <li class="level1"><div class="li"> <strong><code>system-gschemrc</code></strong> (or whatever)</div>
189 </li>
190 <li class="level1"><div class="li"> <strong><code>${HOME}/.gEDA/gafrc</code></strong></div>
191 </li>
192 <li class="level1"><div class="li"> <strong><code>${HOME}/.gEDA/gschemrc</code></strong> (or whatever)</div>
193 </li>
194 <li class="level1"><div class="li"> <strong><code>./gafrc</code></strong></div>
195 </li>
196 <li class="level1"><div class="li"> <strong><code>./gschemrc</code></strong> (or whatever)</div>
197 </li>
198 </ol>
201 If you get a warning that your app can’t find one or another of these files, don’t worry. Most of them are optional. The only required files are the system RC files.
202 </p>
204 </div>
205 <!-- EDIT5 SECTION "What are the names and locations of the RC files used with gEDA/gaf applications?" [5233-8610] -->
206 <h1 class="sectionedit6" id="what_about_a_project_manager">What about a project manager?</h1>
207 <div class="level1">
210 The individual components in the gEDA design suite do not have the concept of an end-to-end project. Rather, they deal with their own files (e.g. “gschem” → .sch, “pcb” → .pcb). However, there is a project manager, called “geda”, which you can invoke from the command line. It’s goal is to help manage your design as a whole as you take it from concept, through schematic capture, attribute attachment, layout, BOM generation, and so on.
211 </p>
214 Unfortunately, development of “geda” has not kept up with the rest of gEDA/gaf. In particular, “geda” does not use the latest tools or methods to accomplish the individual design tasks. Therefore, we recommend that user simply invoke the individual tools (e.g. gschem, gattrib, gnetlist, gsch2pcb, etc) from the command line. Meanwhile, if your are a hacker are looking for a smallish project to adopt, polishing up “geda” would make a nice introduction to the gEDA Suite, and you would make a lot of friends by doing so!
215 </p>
217 </div>
218 <!-- EDIT6 SECTION "What about a project manager?" [8611-9646] -->
219 <h1 class="sectionedit7" id="can_we_change_geda_to_use_an_xml_file_format">Can we change gEDA to use an XML file format?</h1>
220 <div class="level1">
223 We have a recurrent debate about XML file formats on geda-user every two or three years. I think it has to do with how long it takes us to lose our institutional memory due to churn on the mailing list.
224 </p>
227 It&#039;s unlikely the gEDA Project will ever switch to an XML file format for schematics or symbols, so get used to it. Some reasons against XML are:
228 </p>
229 <ol>
230 <li class="level1"><div class="li"> GEDA/gaf already has a fixed, well documented, <abbr title="American Standard Code for Information Interchange">ASCII</abbr> file format. It&#039;s over 8 years old as of 2007. It&#039;s well used and well tested.</div>
231 </li>
232 <li class="level1"><div class="li"> We already have a parser for our file format. It&#039;s lightweight &amp; thoroughly debugged.</div>
233 </li>
234 <li class="level1"><div class="li"> There are lots of legacy designs using the file format out there already. People would scream if we switched file formats since their old designs would become obsolete. And supporting two file formats – old and new – would be a major <abbr title="Pain in the Ass">PITA</abbr>.</div>
235 </li>
236 <li class="level1"><div class="li"> XML is a generalized file format. Therefore, XML files tend to become bloated pigs. The gEDA file format is light &amp; well adapted to its purpose: representing graphical information pertinent to schematic diagrams in electronics.</div>
237 </li>
238 <li class="level1"><div class="li"> One purported benefit for XML files is that there are lots of open-source parsers for them available, making integration into libgeda trivial. That&#039;s the theory, but in reality the job of a parser is to analyze and parse the input, and then stick it into datastructures suitable for use with the rest of gschem&#039;s code. An open-source parser does about 1/3 of the job we need (i.e. reading &amp; analyzing the file, and creating some kind of parse tree). The rest of the job involves putting the stuff in the parse tree into libgeda&#039;s data structures. That&#039;s lots of work. Therefore, the purported advantage of the freely-available XML parser is a chimera. Yes, XML may be of interest for a new program written from the ground up, but not for an existing program like gEDA.</div>
239 </li>
240 <li class="level1"><div class="li"> GEDA developer time is better used on implementing new features like backannotation. Using developer time on porting our file format to XML is a sideways move which doesn&#039;t provide the end user any more utility, but soaks up valuable developer time.</div>
241 </li>
242 <li class="level1"><div class="li"> The other benefit of XML is that it is more-or-less human readable. I&#039;ll grant that this is a valid assertion. Our current file format is not readable by a human who has never read the documentation. However, our current file format *is* <abbr title="American Standard Code for Information Interchange">ASCII</abbr>, and is completely documented, so an essential reason for readability – the ability to write scripts against the file – is already taken care of. Also, a human can certainly read the file format once he has taken the time to <abbr title="Read The Fine Manual">RTFM</abbr>. Human readability – without knowing the file format – is a “nice to have” which isn&#039;t high on my priority list.</div>
243 </li>
244 </ol>
246 </div>
247 <!-- EDIT7 SECTION "Can we change gEDA to use an XML file format?" [9647-] --></body>
248 </html>