KiCad PCB EDA Suite
Loading...
Searching...
No Matches
import_fabmaster.h
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
5 * Author: Seth Hillbrand <[email protected]>
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, you may find one here:
19 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
20 * or you may search the http://www.gnu.org website for the version 2 license,
21 * or you may write to the Free Software Foundation, Inc.,
22 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
23 */
24
25
26#ifndef PCBNEW_IMPORTERS_IMPORT_FABMASTER_H_
27#define PCBNEW_IMPORTERS_IMPORT_FABMASTER_H_
28
29#include <eda_text.h>
30#include <geometry/shape_arc.h>
31#include <padstack.h>
32
33#include <deque>
34#include <functional>
35#include <iostream>
36#include <map>
37#include <memory>
38#include <set>
39#include <unordered_map>
40#include <string>
41#include <vector>
42
43#include <wx/filename.h>
44
45enum PCB_LAYER_ID : int;
46class BOARD;
47class BOARD_ITEM;
48class PCB_TEXT;
50
52{
53public:
54
55 using single_row = std::vector<std::string>;
57 has_pads( false ),
58 has_comps( false ),
59 has_graphic( false ),
60 has_nets( false ),
61 has_pins( false ),
62 m_progressReporter( nullptr ),
63 m_doneCount( 0 ),
65 m_totalCount( 0 )
66
67 {}
68
69 bool Read( const std::string& aFile );
70
71 bool Process();
72
73 bool LoadBoard( BOARD* aBoard, PROGRESS_REPORTER* aProgressReporter );
74
75private:
76
77 wxFileName m_filename;
78
94
95 std::deque<single_row> rows;
96
102
103
106 {
108 std::string custom_name;
109 bool is_octogon = false;
110 int width = 0;
111 int height = 0;
112 int x_offset = 0;
113 int y_offset = 0;
114 };
115
116 struct FM_PAD
117 {
118 std::string name;
119 bool fixed;
120 bool via;
122 std::string custom_name;
123 bool top;
124 bool bottom;
125 bool paste;
126 bool mask;
127 bool drill;
128 bool plated;
132 int width;
141 std::set<std::string> copper_layers;
142 std::map<std::string, FM_PAD_LAYER> layer_shapes;
143
144 struct HASH
145 {
146 std::size_t operator()( const FM_PAD& aPad ) const
147 {
148 return std::hash<std::string>{}( aPad.name );
149 }
150 };
151 };
152
153 std::unordered_map<std::string, FM_PAD> pads;
154
162
171
172 // A!NET_NAME!REFDES!PIN_NUMBER!PIN_NAME!PIN_GROUND!PIN_POWER!
173 struct NETNAME
174 {
175 std::string name;
176 std::string refdes;
177 std::string pin_num;
178 std::string pin_name;
179 bool pin_gnd;
180 bool pin_pwr;
181
182 struct LESS
183 {
184 bool operator()(const NETNAME& lhs, const NETNAME& rhs) const
185 {
186 if( lhs.refdes == rhs.refdes )
187 return lhs.pin_num < rhs.pin_num;
188
189 return lhs.refdes < rhs.refdes;
190 }
191 };
192 };
193
194 std::map<std::pair<std::string, std::string>, NETNAME> pin_nets;
195 std::set<std::string> netnames;
196
197 struct CLASS
198 {
199 std::string name;
200 std::string subclass;
201 };
202
203
215
225
227 {
228 virtual ~GRAPHIC_ITEM() = default;
229
232 int width;
233 std::string layer;
234 std::string symbol;
235 std::string refdes;
236 int seq;
237 int subseq;
240
241
242 struct SEQ_CMP
243 {
244 bool operator()(const std::unique_ptr<GRAPHIC_ITEM>& lhs,
245 const std::unique_ptr<GRAPHIC_ITEM>& rhs) const
246 {
247 if( lhs->refdes != rhs->refdes )
248 return lhs->refdes < rhs->refdes;
249
250 if( lhs->layer != rhs->layer )
251 return lhs->layer < rhs->layer;
252
253 return lhs->seq < rhs->seq;
254 }
255 };
256 };
257
259 {
260 int end_x;
261 int end_y;
263 };
264
265 struct GRAPHIC_ARC : public GRAPHIC_ITEM
266 {
267 int end_x;
268 int end_y;
271 int radius;
274
276 };
277
279 {
280 int end_x;
281 int end_y;
282 bool fill;
283 };
284
286 {
287 bool oblong_x;
288 int size_x;
289 int size_y;
290 // width is GRAPHIC_DATA5 (or is it fill?)
291 };
292
294 {
295 bool oblong_x;
296 int size_x;
297 int size_y;
298 // width is GRAPHIC_DATA5
299 };
300
301 // Handles hexagons, triangles, octagons
303 {
304 std::vector<VECTOR2I> m_pts;
305 };
306
308 {
309 double rotation;
310 bool mirror;
312 // GRAPHIC_DATA_6 is
313 // SIZE FONT HEIGHT WIDTH ITAL LINESPACE THICKNESS
314 int height;
316 bool ital;
317
318 std::string text;
319 };
320
321 using graphic_element = std::set<std::unique_ptr<GRAPHIC_ITEM>, GRAPHIC_ITEM::SEQ_CMP>;
322
326 {
327 int id;
328 std::string name;
329 bool positive;
330 std::string use;
332 double er;
334 std::string material;
335 bool shield;
337 double thickness;
339 bool disable;
340
341 struct BY_ID
342 {
343 bool operator()(const FABMASTER_LAYER* lhs, const FABMASTER_LAYER* rhs) const
344 {
345 return lhs->id < rhs->id;
346 }
347 };
348 };
349
350 std::map<std::string, FABMASTER_LAYER> layers;
351
358 {
359 std::string name;
360 std::string padstack;
361 std::string refdes;
362 std::string pinnum;
363 std::map<int, graphic_element> elements;
364
365 struct HASH
366 {
367 std::size_t operator()( const std::unique_ptr<FABMASTER_PAD_SHAPE>& aPad ) const
368 {
369 return std::hash<std::string>{}( aPad->name );
370 }
371 };
372 };
373
374 std::unordered_map<std::string, FABMASTER_PAD_SHAPE> pad_shapes;
375
376 // * A!SYM_TYPE!SYM_NAME!REFDES!SYM_X!SYM_Y!SYM_ROTATE!SYM_MIRROR!NET_NAME!CLASS!SUBCLASS!RECORD_TAG!
377 // * GRAPHIC_DATA_NAME!GRAPHIC_DATA_NUMBER!GRAPHIC_DATA_1!GRAPHIC_DATA_2!GRAPHIC_DATA_3!GRAPHIC_DATA_4!
378 // * GRAPHIC_DATA_5!GRAPHIC_DATA_6!GRAPHIC_DATA_7!GRAPHIC_DATA_8!GRAPHIC_DATA_9!GRAPHIC_DATA_10!COMP_DEVICE_TYPE!
379 // * COMP_PACKAGE!COMP_PART_NUMBER!COMP_VALUE!CLIP_DRAWING!
380 struct SYMBOL
381 {
382 int sym_id;
383 int seq_id;
385 std::string name;
386 std::string refdes;
387 int x;
388 int y;
389 std::map<int, graphic_element> elements;
390
391 struct HASH
392 {
393 std::size_t operator()( const FABMASTER::SYMBOL& aSym ) const
394 {
395 return std::hash<std::string>{}( aSym.name );
396 }
397 };
398 };
399
400 // Temporary data structure to pass graphic data from file for processing
402 {
403 std::string graphic_dataname;
404 std::string graphic_datanum;
405 std::string graphic_data1;
406 std::string graphic_data2;
407 std::string graphic_data3;
408 std::string graphic_data4;
409 std::string graphic_data5;
410 std::string graphic_data6;
411 std::string graphic_data7;
412 std::string graphic_data8;
413 std::string graphic_data9;
414 std::string graphic_data10;
415 };
416
417 std::unordered_map<std::string, SYMBOL> symbols;
418
419
420 // * A!GRAPHIC_DATA_NAME!GRAPHIC_DATA_NUMBER!RECORD_TAG!GRAPHIC_DATA_1!GRAPHIC_DATA_2!GRAPHIC_DATA_3!
421 // * GRAPHIC_DATA_4!GRAPHIC_DATA_5!GRAPHIC_DATA_6!GRAPHIC_DATA_7!GRAPHIC_DATA_8!GRAPHIC_DATA_9!
422 // * SUBCLASS!SYM_NAME!REFDES!
423
425 {
426 std::string subclass;
427 std::string name;
428 std::string refdes;
429 int id;
430
431 std::unique_ptr<graphic_element> elements;
432
433 struct BY_ID
434 {
435 bool operator()(const GEOM_GRAPHIC& lhs, const GEOM_GRAPHIC& rhs) const
436 {
437 return lhs.id < rhs.id;
438 }
439 };
440 };
441
442 std::vector<GEOM_GRAPHIC> board_graphics;
443 std::map<std::string, std::map<int, GEOM_GRAPHIC>> comp_graphics;
444
445
446 // A!VIA_X!VIA_Y!PAD_STACK_NAME!NET_NAME!TEST_POINT!
447 struct FM_VIA
448 {
449 int x;
450 int y;
451 std::string padstack;
452 std::string net;
454 bool mirror;
455 };
456
457 std::vector<std::unique_ptr<FM_VIA>> vias;
458
459 // A!CLASS!SUBCLASS!GRAPHIC_DATA_NAME!GRAPHIC_DATA_NUMBER!RECORD_TAG!GRAPHIC_DATA_1!
460 // GRAPHIC_DATA_2!GRAPHIC_DATA_3!GRAPHIC_DATA_4!GRAPHIC_DATA_5!GRAPHIC_DATA_6!GRAPHIC_DATA_7!
461 // GRAPHIC_DATA_8!GRAPHIC_DATA_9!NET_NAME!
462 struct TRACE
463 {
464 std::string lclass;
465 std::string layer;
466 std::string netname;
467 int id;
468
470
471 struct BY_ID
472 {
473 bool operator()(const std::unique_ptr<TRACE>& lhs, const std::unique_ptr<TRACE>& rhs) const
474 {
475 return lhs->id < rhs->id;
476 }
477 };
478 };
479
480 std::set<std::unique_ptr<TRACE>, TRACE::BY_ID> traces;
481
482 std::set<std::unique_ptr<TRACE>, TRACE::BY_ID> zones;
483
484 std::set<std::unique_ptr<TRACE>, TRACE::BY_ID> polygons;
485
486 std::set<std::unique_ptr<TRACE>, TRACE::BY_ID> refdes;
487
488
489 // A!REFDES!COMP_CLASS!COMP_PART_NUMBER!COMP_HEIGHT!COMP_DEVICE_LABEL!COMP_INSERTION_CODE!SYM_TYPE!
490 // SYM_NAME!SYM_MIRROR!SYM_ROTATE!SYM_X!SYM_Y!COMP_VALUE!COMP_TOL!COMP_VOLTAGE!
492 {
493 std::string refdes;
495 std::string pn;
496 std::string height;
497 std::string dev_label;
498 std::string insert_code;
500 std::string name;
501 bool mirror;
502 double rotate;
503 int x;
504 int y;
505 std::string value;
506 std::string tol;
507 std::string voltage;
508
509 struct HASH
510 {
511 std::size_t operator()( const FABMASTER::COMPONENT& aCmp ) const
512 {
513 return std::hash<std::string>{}( aCmp.refdes );
514 }
515 };
516
517 };
518
519 std::map<std::string, std::vector<std::unique_ptr<COMPONENT>>> components;
520
521
522 // A!SYM_NAME!SYM_MIRROR!PIN_NAME!PIN_NUMBER!PIN_X!PIN_Y!PAD_STACK_NAME!REFDES!PIN_ROTATION!TEST_POINT!
523
524 struct PIN
525 {
526 std::string name;
527 bool mirror;
528 std::string pin_name;
529 std::string pin_number;
530 int pin_x;
531 int pin_y;
532 std::string padstack;
533 std::string refdes;
534 double rotation;
535
536 struct BY_NUM
537 {
538 bool operator()(const std::unique_ptr<PIN>& lhs,
539 const std::unique_ptr<PIN>& rhs) const
540 {
541 return lhs->pin_number < rhs->pin_number;
542 }
543 };
544 };
545
546 std::map<std::string, std::set<std::unique_ptr<PIN>, PIN::BY_NUM>> pins;
547
548 std::map<std::string, PCB_LAYER_ID> layer_map;
549
550 section_type detectType( size_t aOffset );
551
552 void checkpoint();
553
554 int execute_recordbuffer( int filetype );
555 int getColFromName( size_t aRow, const std::string& aStr );
556 SYMTYPE parseSymType( const std::string& aSymType );
557 COMPCLASS parseCompClass( const std::string& aCompClass );
558
565 double processScaleFactor( size_t aRow );
566 size_t processPadStacks( size_t aRow );
567 size_t processCustomPads( size_t aRow );
568 size_t processGeometry( size_t aRow );
569 size_t processVias( size_t aRow );
570 size_t processTraces( size_t aRow );
571 size_t processFootprints( size_t aRow );
572 size_t processNets( size_t aRow );
573 size_t processLayers( size_t aRow );
574 size_t processSimpleLayers( size_t aRow );
575 size_t processPadStackLayers( size_t aRow );
576 size_t processSymbols( size_t aRow );
577 size_t processPins( size_t aRow );
578
586 GRAPHIC_ITEM* processGraphic( const GRAPHIC_DATA& aData, double aScale );
587
588 GRAPHIC_ARC* processArc( const GRAPHIC_DATA& aData, double aScale );
589 GRAPHIC_ARC* processCircle( const GRAPHIC_DATA& aData, double aScale );
590 GRAPHIC_LINE* processLine( const GRAPHIC_DATA& aData, double aScale );
591 GRAPHIC_TEXT* processText( const GRAPHIC_DATA& aData, double aScale );
592 GRAPHIC_RECTANGLE* processRectangle( const GRAPHIC_DATA& aData, double aScale );
593 GRAPHIC_RECTANGLE* processFigRectangle( const GRAPHIC_DATA& aData, double aScale );
594 GRAPHIC_RECTANGLE* processSquare( const GRAPHIC_DATA& aData, double aScale );
595 GRAPHIC_OBLONG* processOblong( const GRAPHIC_DATA& aData, double aScale );
596 GRAPHIC_CROSS* processCross( const GRAPHIC_DATA& aData, double aScale );
597 GRAPHIC_POLYGON* processPolygon( const GRAPHIC_DATA& aData, double aScale );
598
599 PCB_LAYER_ID getLayer( const std::string& aLayerName );
600 bool assignLayers();
601
607 double readDouble( const std::string& aStr ) const;
608 int readInt( const std::string& aStr ) const;
609
616 bool orderZones( BOARD* aBoard );
617
623 bool loadZones( BOARD* aBoard );
624 bool loadOutline( BOARD* aBoard, const std::unique_ptr<TRACE>& aLine);
625 bool loadNets( BOARD* aBoard );
626 bool loadLayers( BOARD* aBoard );
627 bool loadGraphics( BOARD* aBoard );
628 bool loadVias( BOARD* aBoard );
629 bool loadEtch( BOARD* aBoard, const std::unique_ptr<TRACE>& aLine);
630 bool loadZone( BOARD* aBoard, const std::unique_ptr<FABMASTER::TRACE>& aLine);
631 bool loadPolygon( BOARD* aBoard, const std::unique_ptr<FABMASTER::TRACE>& aLine);
632 bool loadFootprints( BOARD* aBoard );
633
639
641
642 static bool traceIsOpen( const FABMASTER::TRACE& aLine );
643
647 static void setupText( const FABMASTER::GRAPHIC_TEXT& aGraphicText, PCB_LAYER_ID aLayer,
648 PCB_TEXT& aText, const BOARD& aBoard, const OPT_VECTOR2I& aMirrorPoint );
649
653 static std::vector<std::unique_ptr<BOARD_ITEM>>
654 createBoardItems( BOARD& aBoard, PCB_LAYER_ID aLayer, FABMASTER::GRAPHIC_ITEM& aGraphic );
655
657 unsigned m_doneCount;
659 unsigned m_totalCount;
660};
661
662
663
664
665#endif /* PCBNEW_IMPORTERS_IMPORT_FABMASTER_H_ */
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition board_item.h:84
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:323
size_t processFootprints(size_t aRow)
A!REFDES!COMP_CLASS!COMP_PART_NUMBER!COMP_HEIGHT!COMP_DEVICE_LABEL!COMP_INSERTION_CODE!...
unsigned m_doneCount
size_t processPins(size_t aRow)
A!SYM_NAME!SYM_MIRROR!PIN_NAME!PIN_NUMBER!PIN_X!PIN_Y!PAD_STACK_NAME!REFDES!PIN_ROTATION!
int readInt(const std::string &aStr) const
wxFileName m_filename
GRAPHIC_OBLONG * processOblong(const GRAPHIC_DATA &aData, double aScale)
size_t processGeometry(size_t aRow)
A!GRAPHIC_DATA_NAME!GRAPHIC_DATA_NUMBER!RECORD_TAG!GRAPHIC_DATA_1!GRAPHIC_DATA_2!GRAPHIC_DATA_3!
std::map< std::string, PCB_LAYER_ID > layer_map
static std::vector< std::unique_ptr< BOARD_ITEM > > createBoardItems(BOARD &aBoard, PCB_LAYER_ID aLayer, FABMASTER::GRAPHIC_ITEM &aGraphic)
Convert one Fabmaster graphic item to one or more PCB items.
bool Read(const std::string &aFile)
bool loadNets(BOARD *aBoard)
std::map< std::string, std::map< int, GEOM_GRAPHIC > > comp_graphics
GRAPHIC_CROSS * processCross(const GRAPHIC_DATA &aData, double aScale)
unsigned m_lastProgressCount
SYMTYPE parseSymType(const std::string &aSymType)
GRAPHIC_TEXT * processText(const GRAPHIC_DATA &aData, double aScale)
bool loadLayers(BOARD *aBoard)
static void setupText(const FABMASTER::GRAPHIC_TEXT &aGraphicText, PCB_LAYER_ID aLayer, PCB_TEXT &aText, const BOARD &aBoard, const OPT_VECTOR2I &aMirrorPoint)
Set parameters for graphic text.
PCB_LAYER_ID getLayer(const std::string &aLayerName)
GRAPHIC_RECTANGLE * processSquare(const GRAPHIC_DATA &aData, double aScale)
int execute_recordbuffer(int filetype)
static bool traceIsOpen(const FABMASTER::TRACE &aLine)
bool loadZones(BOARD *aBoard)
Loads sections of the database into the board.
GRAPHIC_RECTANGLE * processRectangle(const GRAPHIC_DATA &aData, double aScale)
std::vector< std::string > single_row
size_t processSimpleLayers(size_t aRow)
PROGRESS_REPORTER * m_progressReporter
optional; may be nullptr
bool loadFootprints(BOARD *aBoard)
std::set< std::unique_ptr< TRACE >, TRACE::BY_ID > polygons
GRAPHIC_ARC * processCircle(const GRAPHIC_DATA &aData, double aScale)
std::unordered_map< std::string, FM_PAD > pads
int getColFromName(size_t aRow, const std::string &aStr)
bool loadVias(BOARD *aBoard)
size_t processLayers(size_t aRow)
A!LAYER_SORT!LAYER_SUBCLASS!LAYER_ARTWORK!LAYER_USE!LAYER_CONDUCTOR!LAYER_DIELECTRIC_CONSTANT!
size_t processSymbols(size_t aRow)
std::map< std::string, FABMASTER_LAYER > layers
COMPCLASS parseCompClass(const std::string &aCompClass)
bool loadEtch(BOARD *aBoard, const std::unique_ptr< TRACE > &aLine)
GRAPHIC_RECTANGLE * processFigRectangle(const GRAPHIC_DATA &aData, double aScale)
std::map< std::string, std::set< std::unique_ptr< PIN >, PIN::BY_NUM > > pins
std::set< std::unique_ptr< GRAPHIC_ITEM >, GRAPHIC_ITEM::SEQ_CMP > graphic_element
std::map< std::pair< std::string, std::string >, NETNAME > pin_nets
GRAPHIC_ITEM * processGraphic(const GRAPHIC_DATA &aData, double aScale)
Specialty functions for processing graphical data rows into the internal database.
std::deque< single_row > rows
GRAPHIC_POLYGON * processPolygon(const GRAPHIC_DATA &aData, double aScale)
void createComponentsFromOrphanPins()
Creates synthetic COMPONENT entries from pins that have no matching component.
bool loadOutline(BOARD *aBoard, const std::unique_ptr< TRACE > &aLine)
size_t processPadStacks(size_t aRow)
A!PADNAME!RECNUMBER!LAYER!FIXFLAG!VIAFLAG!PADSHAPE1!PADWIDTH!PADHGHT!
std::vector< GEOM_GRAPHIC > board_graphics
section_type detectType(size_t aOffset)
double readDouble(const std::string &aStr) const
Reads the double/integer value from a std string independent of the user locale.
bool loadZone(BOARD *aBoard, const std::unique_ptr< FABMASTER::TRACE > &aLine)
GRAPHIC_ARC * processArc(const GRAPHIC_DATA &aData, double aScale)
std::unordered_map< std::string, SYMBOL > symbols
SHAPE_POLY_SET loadShapePolySet(const graphic_element &aLine)
bool loadGraphics(BOARD *aBoard)
std::unordered_map< std::string, FABMASTER_PAD_SHAPE > pad_shapes
bool LoadBoard(BOARD *aBoard, PROGRESS_REPORTER *aProgressReporter)
std::vector< std::unique_ptr< FM_VIA > > vias
std::set< std::unique_ptr< TRACE >, TRACE::BY_ID > traces
std::set< std::unique_ptr< TRACE >, TRACE::BY_ID > zones
std::map< std::string, std::vector< std::unique_ptr< COMPONENT > > > components
bool loadPolygon(BOARD *aBoard, const std::unique_ptr< FABMASTER::TRACE > &aLine)
std::set< std::unique_ptr< TRACE >, TRACE::BY_ID > refdes
@ GR_SHAPE_OBLONG
!< Actually 360° arcs (for both arcs where start==end and real circles)
@ GR_SHAPE_CROSS
!< X/Y oblongs
size_t processPadStackLayers(size_t aRow)
std::set< std::string > netnames
size_t processTraces(size_t aRow)
A!CLASS!SUBCLASS!GRAPHIC_DATA_NAME!GRAPHIC_DATA_NUMBER!RECORD_TAG!GRAPHIC_DATA_1!GRAPHIC_DATA_2!
size_t processNets(size_t aRow)
A!NET_NAME!REFDES!PIN_NUMBER!PIN_NAME!PIN_GROUND!PIN_POWER!
bool orderZones(BOARD *aBoard)
Sets zone priorities based on zone BB size.
double processScaleFactor(size_t aRow)
Processes data from text vectors into internal database for further ordering.
size_t processVias(size_t aRow)
A!VIA_X!VIA_Y!PAD_STACK_NAME!NET_NAME!TEST_POINT!
unsigned m_totalCount
for progress reporting
size_t processCustomPads(size_t aRow)
A!SUBCLASS!PAD_SHAPE_NAME!GRAPHIC_DATA_NAME!GRAPHIC_DATA_NUMBER!RECORD_TAG!GRAPHIC_DATA_1!
GRAPHIC_LINE * processLine(const GRAPHIC_DATA &aData, double aScale)
A progress reporter interface for use in multi-threaded environments.
Represent a set of closed polygons.
PCB_LAYER_ID
A quick note on layer IDs:
Definition layer_ids.h:60
PAD_SHAPE
The set of pad shapes, used with PAD::{Set,Get}Shape()
Definition padstack.h:52
std::optional< VECTOR2I > OPT_VECTOR2I
Definition seg.h:39
std::string subclass
!< CLASS
std::size_t operator()(const FABMASTER::COMPONENT &aCmp) const
std::string dev_label
! COMP_DEVICE_LABEL
double rotate
! SYM_ROTATE (degrees)
std::string name
! SYM_NAME
SYMTYPE type
! SYM_TYPE
std::string pn
! COMP_PART_NUMBER
std::string value
! COMP_VALUE
std::string insert_code
! COMP_INSERTION_CODE
std::string voltage
! COMP_VOLTAGE
bool mirror
! SYM_MIRROR
std::string height
! COMP_HEIGHT
COMPCLASS cclass
! COMP_CLASS
std::string tol
! COMP_TOL
std::string refdes
! REFDES
bool operator()(const FABMASTER_LAYER *lhs, const FABMASTER_LAYER *rhs) const
A!LAYER_SORT!LAYER_SUBCLASS!LAYER_ARTWORK!LAYER_USE!LAYER_CONDUCTOR!LAYER_DIELECTRIC_CONSTANT !...
bool disable
! if true, prevent the layer elements from being used
std::string name
! LAYER_SUBCLASS
double thickness
! LAYER_THICKNESS
bool shield
! LAYER_SHIELD_LAYER
std::string material
! LAYER_MATERIAL
int layerid
! pcbnew layer (assigned)
bool conductive
! LAYER_CONDUCTOR
bool positive
! LAYER_ARTWORK (either POSITIVE or NEGATIVE)
double conductivity
! LAYER_ELECTRICAL_CONDUCTIVITY
std::string use
! LAYER_USE
double thermal_cond
! LAYER_THERMAL_CONDUCTIVITY
double er
! LAYER_DIELECTRIC_CONSTANT
std::size_t operator()(const std::unique_ptr< FABMASTER_PAD_SHAPE > &aPad) const
A!SUBCLASS!PAD_SHAPE_NAME!GRAPHIC_DATA_NAME!GRAPHIC_DATA_NUMBER!RECORD_TAG!GRAPHIC_DATA_1!
std::map< int, graphic_element > elements
std::string name
! PAD_SHAPE_NAME
std::string padstack
! PAD_STACK_NAME
std::string pinnum
! PIN_NUMBER
std::size_t operator()(const FM_PAD &aPad) const
Per-layer pad geometry within a pad stack.
std::map< std::string, FM_PAD_LAYER > layer_shapes
Per-layer shape overrides.
std::set< std::string > copper_layers
Copper layers with non-zero annular ring.
std::string padstack
! PAD_STACK_NAME
bool mirror
! VIA_MIRROR (VIA_MIRROR is an optional component)
bool test_point
! TEST_POINT
std::string net
! NET_NAME
bool operator()(const GEOM_GRAPHIC &lhs, const GEOM_GRAPHIC &rhs) const
std::string name
! SYM_NAME
std::string refdes
! REFDES
std::string subclass
! SUBCLASS
std::unique_ptr< graphic_element > elements
int end_x
! GRAPHIC_DATA_3
SHAPE_ARC result
! KiCad-style arc representation
int center_x
! GRAPHIC_DATA_5
bool clockwise
! GRAPHIC_DATA_9
int center_y
! GRAPHIC_DATA_6
int end_y
! GRAPHIC_DATA_4
int size_y
! GRAPHIC_DATA_4
int size_x
! GRAPHIC_DATA_3
bool oblong_x
! OBLONG_X (as opposed to OBLONG_Y)
bool operator()(const std::unique_ptr< GRAPHIC_ITEM > &lhs, const std::unique_ptr< GRAPHIC_ITEM > &rhs) const
std::string layer
! SUBCLASS
int subseq
! RECORD_TAG[1]
int width
! Various sections depending on type
GRAPHIC_SHAPE shape
! Shape of the graphic_item
std::string symbol
! SYMBOL
int start_y
! GRAPHIC_DATA_2
virtual ~GRAPHIC_ITEM()=default
int start_x
! GRAPHIC_DATA_1
GRAPHIC_TYPE type
! Type of graphic item
std::string refdes
! REFDES
int end_x
! GRAPHIC_DATA_3
bool oblong_x
! OBLONG_X (as opposed to OBLONG_Y)
int size_x
! GRAPHIC_DATA_3
int size_y
! GRAPHIC_DATA_4
std::vector< VECTOR2I > m_pts
double rotation
! GRAPHIC_DATA_3
std::string text
! GRAPHIC_DATA_7
int height
! GRAPHIC_DATA_6[2]
int thickness
! GRAPHIC_DATA_6[6]
GR_TEXT_H_ALIGN_T orient
! GRAPHIC_DATA_5
bool ital
! GRAPHIC_DATA_6[4] != 0.0
bool mirror
! GRAPHIC_DATA_4
bool operator()(const NETNAME &lhs, const NETNAME &rhs) const
std::string refdes
!< NET_NAME
bool pin_pwr
!< PIN_GND
std::string pin_num
!< REFDES
std::string pin_name
!< PIN_NUMBER
bool pin_gnd
!< PIN_NAME
bool operator()(const std::unique_ptr< PIN > &lhs, const std::unique_ptr< PIN > &rhs) const
int pin_x
! PIN_X - Absolute board units
int pin_y
! PIN_Y - Absolute board units
double rotation
! PIN_ROTATION
bool mirror
! SYM_MIRROR
std::string padstack
! PAD_STACK
std::string name
! SYM_NAME
std::string pin_name
! PIN_NAME
std::string refdes
! REFDES
std::string pin_number
! PIN_NUMBER
std::size_t operator()(const FABMASTER::SYMBOL &aSym) const
std::string refdes
! REFDES
std::map< int, graphic_element > elements
std::string name
! SYM_NAME
int subseq_id
! RECORD_TAG[2] (RECORD_TAG is of the form "x y z")
int seq_id
! RECORD_TAG[1] (RECORD_TAG is of the form "x y z")
int sym_id
! RECORD_TAG[0]
bool operator()(const std::unique_ptr< TRACE > &lhs, const std::unique_ptr< TRACE > &rhs) const
std::string layer
! SUBCLASS
std::string lclass
! CLASS
std::string netname
! NET_NAME
int id
! RECORD_TAG[0]
graphic_element segment
! GRAPHIC_DATA (can be either LINE or ARC)
GR_TEXT_H_ALIGN_T
This is API surface mapped to common.types.HorizontalAlignment.