1 <!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Transitional//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
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" />
13 <h2 class=
"sectionedit1" id=
"pcbtype">PCBType
</h2>
17 PCBType is the main data structure
21 PCBType contain all the general information used in the program and it contains a pointer to the DataType
25 <a href=
"media/devel_intro/structpcbtype_graph.png" class=
"media" target=
"_blank" title=
"devel_intro:structpcbtype_graph.png"><img src=
"media/devel_intro/structpcbtype_graph.png" class=
"media" alt=
"" /></a>
29 <!-- EDIT1 SECTION "PCBType" [1-206] -->
30 <h2 class=
"sectionedit2" id=
"datatype">DataType
</h2>
34 The DataType contains the actual data that defines our printed circuit board.
38 DataType is what
's stored in the Buffers when you do cut/paste.
40 <div class=
"table sectionedit3"><table class=
"inline">
43 <th class=
"col0">Data Fields
</th><th class=
"col1" colspan=
"2"> </th>
47 <td class=
"col0">Cardinal
</td><td class=
"col1">ViaN
</td><td class=
"col2"> </td>
50 <td class=
"col0">Cardinal
</td><td class=
"col1">ElementN
</td><td class=
"col2"> </td>
53 <td class=
"col0">Cardinal
</td><td class=
"col1">RatN
</td><td class=
"col2"> </td>
56 <td class=
"col0">int
</td><td class=
"col1">LayerN
</td><td class=
"col2"> </td>
59 <td class=
"col0">GList *
</td><td class=
"col1">Via
</td><td class=
"col2">Layer independent via
's
</td>
62 <td class=
"col0">GList *
</td><td class=
"col1">Element
</td><td class=
"col2">Layer independent elements
</td>
65 <td class=
"col0">GList *
</td><td class=
"col1">Rat
</td><td class=
"col2">Layer independent rat-lines
</td>
68 <td class=
"col0">rtree_t *
</td><td class=
"col1">via_tree
</td><td class=
"col2"> </td>
71 <td class=
"col0">rtree_t *
</td><td class=
"col1">element_tree
</td><td class=
"col2"> </td>
74 <td class=
"col0">rtree_t *
</td><td class=
"col1">pin_tree
</td><td class=
"col2"> </td>
77 <td class=
"col0">rtree_t *
</td><td class=
"col1">pad_tree
</td><td class=
"col2"> </td>
80 <td class=
"col0">rtree_t *
</td><td class=
"col1">name_tree [
3]
</td><td class=
"col2"> </td>
83 <td class=
"col0">rtree_t *
</td><td class=
"col1">rat_tree
</td><td class=
"col2"> </td>
86 <td class=
"col0">struct PCBType *
</td><td class=
"col1">pcb
</td><td class=
"col2">A pointer back to the main data structure
</td>
89 <td class=
"col0">LayerType
</td><td class=
"col1">Layer [MAX_LAYER+
2]
</td><td class=
"col2">All layer dependent items
</td>
92 <td class=
"col0">int
</td><td class=
"col1">polyClip
</td><td class=
"col2"> </td>
95 <!-- EDIT3 TABLE [373-875] -->
97 The actual data is stored in the
<a href=
"geda-pcb_developer_introduction.html#glist" class=
"wikilink1" title=
"geda-pcb_developer_introduction.html">GList
</a> data elements. The rest is there for administrative purposes, to keep track of it all.
98 Here I like to specially mention the rtree_t* data members. Although they have an administrative character the
<a href=
"geda-pcb_developer_introduction.html#r-tree" class=
"wikilink1" title=
"geda-pcb_developer_introduction.html">R-TREE
</a> data structure is heavily used in the PCB program.
102 <!-- EDIT2 SECTION "DataType" [207-1247] -->
103 <h2 class=
"sectionedit4" id=
"glist">GList
</h2>
105 <pre class=
"code c"><span class=
"kw4">struct
</span> GList
<span class=
"br0">{</span>
106 gpointer data
<span class=
"sy0">;
</span>
107 GList
<span class=
"sy0">*
</span>next
<span class=
"sy0">;
</span>
108 GList
<span class=
"sy0">*
</span>prev
<span class=
"sy0">;
</span>
109 <span class=
"br0">}</span><span class=
"sy0">;
</span> </pre>
112 The GList struct is used for each element in a doubly-linked list.
118 <div class=
"table sectionedit5"><table class=
"inline">
120 <td class=
"col0">gpointer data
</td><td class=
"col1">holds the element
's data , which can be a pointer to any kind of data.
</td>
123 <td class=
"col0">GList *next
</td><td class=
"col1">contains the link to the next element in the list
</td>
126 <td class=
"col0">GList *prev;
</td><td class=
"col1">contains the link to the previous element in the list
</td>
129 <!-- EDIT5 TABLE [1429-1648] -->
133 <pre class=
"code c"><span class=
"kw4">typedef
</span> <span class=
"kw4">void
</span><span class=
"sy0">*
</span> gpointer
<span class=
"sy0">;
</span></pre>
136 An untyped pointer.
<code>gpointer
</code> looks better and is easier to use than
<code>void*
</code>.
140 <!-- EDIT4 SECTION "GList" [1248-1787] -->
141 <h2 class=
"sectionedit6" id=
"r-tree">R-TREE
</h2>
146 The key idea of the r-tree data structure is to group nearby objects and represent them with their minimum bounding rectangle in the next higher level of the tree; the “R” in R-tree is for rectangle. Since all objects lie within this bounding rectangle, a query that does not intersect the bounding rectangle also cannot intersect any of the contained objects. At the leaf level, each rectangle describes a single object; at higher levels the aggregation of an increasing number of objects. This can also be seen as an increasingly coarse approximation of the data set.
150 A general r-tree will look like this:
154 <a href=
"media/devel_intro/rtree.png" class=
"media" target=
"_blank" title=
"devel_intro:rtree.png"><img src=
"media/devel_intro/rtree.png" class=
"media" alt=
"" /></a>
158 The bottom row of records are called leafs.
162 The rtree data structure PCB uses is:
166 <a href=
"media/devel_intro/structrtree.png" class=
"media" target=
"_blank" title=
"devel_intro:structrtree.png"><img src=
"media/devel_intro/structrtree.png" class=
"media" alt=
"" /></a>
170 The r-tree data structure hold a copy of the where
's what data. Meaning that it holds a list of every item on our canvas arranged in successively smaller boxes.
171 <a href=
"media/devel_intro/rtreepicture.png" class=
"media" target=
"_blank" title=
"devel_intro:rtreepicture.png"><img src=
"media/devel_intro/rtreepicture.png" class=
"media" alt=
"" /></a>
175 <!-- EDIT6 SECTION "R-TREE" [1788-2776] -->
176 <h2 class=
"sectionedit7" id=
"object_list">object_list
</h2>
180 This is presently available in the home/cparker/drc_test branch. Hopefully merged in soon.
184 This is a type for keeping lists of things. It uses void pointers, so, you can keep lists of just about anything you want: pointers, complex data structures, whatever. A list can only hold one type of object. I implemented this, because I found myself implementing similar things over and over again for different types.
188 This explanation needs to be expanded on later, but, briefly, this list just keeps a big block of memory and copies data around inside it. If you hand it a data structure, it makes its own copy of that data structure. A future version might provide an option to take control of an existing structure, but, not right now.
192 Since a list only handles a single type of object, it can calculate where in the block of memory a given index should be. When you ask for an element, it will calculate the location of that element, and give you a pointer to it. Since it knows how many elements are in the list, when you insert at element, it can figure out how much data needs to be moved to make space for the new element.
196 Some objects are more complex than just a block of data. For example, an object might contain a pointer to a string. The object technically owns that string, but if you just make a copy of the object, the pointer will point to the same string. If the original object is deleted, now the list
's copy will point to a string that no longer exists. To deal with this, complex objects require the definition of two functions, a clear function and a copy function.
200 The clear function should take care of “zeroing out” an object. If the object owns other bits of memory, the clear function should free them. It should essentially make the object blank.
204 The copy function should be used to copy an object
's data, including data that the object owns that is stored elsewhere.
208 I
'll eventually put some examples here, but for now, have a look at the unit tests at the end of src/object_list.c.
212 <!-- EDIT7 SECTION "object_list" [2777-] --></body>