KiCad PCB EDA Suite
Loading...
Searching...
No Matches
allegro_builder.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 Quilter
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
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#pragma once
26
27#include <functional>
28#include <memory>
29#include <unordered_map>
30#include <vector>
31#include <unordered_set>
32
34#include <convert/allegro_db.h>
35
36#include <board.h>
38#include <reporter.h>
39#include <progress_reporter.h>
41
42
43class BOARD;
44class FOOTPRINT;
45class NETINFO_ITEM;
46class PCB_TEXT;
47
48namespace ALLEGRO
49{
50
51class LAYER_MAPPER;
52
58{
59public:
60 BOARD_BUILDER( const BRD_DB& aBrdDb, BOARD& aBoard, REPORTER& aReporter,
61 PROGRESS_REPORTER* aProgressReporter,
62 const LAYER_MAPPING_HANDLER& aLayerMappingHandler );
64
65 bool BuildBoard();
66
67private:
68 VECTOR2I scale( const VECTOR2I& aVector ) const;
69 VECTOR2I scaleSize( const VECTOR2I& aSize ) const;
70 int scale( int aVal ) const;
71
77 template <ALLEGRO_BLOCK_DATA T>
78 const T* expectBlockByKey( uint32_t aKey ) const
79 {
80 // The type code trait
81 constexpr uint8_t kType = T::BLOCK_TYPE_CODE;
82
83 if( aKey == 0 )
84 return nullptr;
85
86 const BLOCK_BASE* block = m_brdDb.GetObjectByKey( aKey );
87
88 if( !block )
89 {
90 reportMissingBlock( aKey, kType );
91 return nullptr;
92 }
93
94 if( block->GetBlockType() != kType )
95 {
96 reportUnexpectedBlockType( block->GetBlockType(), kType, aKey, block->GetOffset() );
97 return nullptr;
98 }
99
100 return &static_cast<const BLOCK<T>&>( *block ).GetData();
101 }
102
103 void reportMissingBlock( uint32_t aKey, uint8_t aType ) const;
104 void reportUnexpectedBlockType( uint8_t aGot, uint8_t aExpected, uint32_t aKey = 0, size_t aOffset = 0,
105 const wxString& aName = wxEmptyString ) const;
106
107 PCB_LAYER_ID getLayer( const LAYER_INFO& aLayerInfo ) const;
108
114 wxString get0x30StringValue( uint32_t a0x30Key ) const;
115
119 std::unique_ptr<PCB_SHAPE> buildLineSegment( const BLK_0x15_16_17_SEGMENT& aSegment, const LAYER_INFO& aLayerInfo,
120 PCB_LAYER_ID aLayer, BOARD_ITEM_CONTAINER& aParent );
121
122 std::unique_ptr<PCB_SHAPE> buildArc( const BLK_0x01_ARC& aArc, const LAYER_INFO& aLayerInfo, PCB_LAYER_ID aLayer,
123 BOARD_ITEM_CONTAINER& aParent );
124
128 std::vector<std::unique_ptr<PCB_SHAPE>> buildShapes( const BLK_0x14_GRAPHIC& aGraphicList, BOARD_ITEM_CONTAINER& aParent );
129 std::unique_ptr<PCB_TEXT> buildPcbText( const BLK_0x30_STR_WRAPPER& aStrWrapper, BOARD_ITEM_CONTAINER& aParent );
130
134 std::unique_ptr<PCB_SHAPE> buildRect( const BLK_0x24_RECT& aRect, BOARD_ITEM_CONTAINER& aParent );
135
139 std::unique_ptr<PCB_SHAPE> buildRect( const BLK_0x0E_RECT& aShape, BOARD_ITEM_CONTAINER& aParent );
140
141
145 std::unique_ptr<PCB_SHAPE> buildPolygon( const BLK_0x28_SHAPE& aShape, BOARD_ITEM_CONTAINER& aParent );
146
150 std::vector<std::unique_ptr<PCB_SHAPE>> buildPolygonShapes( const BLK_0x28_SHAPE& aShape,
151 BOARD_ITEM_CONTAINER& aParent );
152
156 std::vector<std::unique_ptr<BOARD_ITEM>> buildDrillMarker( const BLK_0x0C_PIN_DEF& aPinDef,
157 BOARD_ITEM_CONTAINER& aParent );
158
162 std::vector<std::unique_ptr<BOARD_ITEM>> buildGraphicItems( const BLOCK_BASE& aBlock,
163 BOARD_ITEM_CONTAINER& aParent );
164
168 std::vector<std::unique_ptr<BOARD_ITEM>> buildPadItems( const BLK_0x1C_PADSTACK& aPadstack, FOOTPRINT& aFp,
169 const wxString& aPadName, int aNetcode );
170 std::unique_ptr<FOOTPRINT> buildFootprint( const BLK_0x2D_FOOTPRINT_INST& aFpInstance );
171 std::vector<std::unique_ptr<BOARD_ITEM>> buildTrack( const BLK_0x05_TRACK& aBlock, int aNetcode );
172 std::unique_ptr<BOARD_ITEM> buildVia( const BLK_0x33_VIA& aBlock, int aNetcode );
173
174 class ZONE_FILL_HANDLER;
175
182 std::unique_ptr<ZONE> buildZone( const BLOCK_BASE& aBoundaryBlock,
183 const std::vector<const BLOCK_BASE*>& aRelatedBlocks,
184 ZONE_FILL_HANDLER& aZoneFillHandler );
185
186 SHAPE_LINE_CHAIN buildOutline( const BLK_0x0E_RECT& aRect ) const;
187 SHAPE_LINE_CHAIN buildOutline( const BLK_0x24_RECT& aRect ) const;
188 SHAPE_LINE_CHAIN buildOutline( const BLK_0x28_SHAPE& aShape ) const;
189
190 SHAPE_POLY_SET shapeToPolySet( const BLK_0x28_SHAPE& aShape ) const;
191
196
201 const SHAPE_LINE_CHAIN& buildSegmentChain( uint32_t aStartKey ) const;
202
206 std::vector<const BLOCK_BASE*> getShapeRelatedBlocks( const BLK_0x28_SHAPE& aShape ) const;
207
217 wxString resolveMatchGroupName( const BLK_0x1B_NET& aNet ) const;
218
226 wxString resolveConstraintSetNameFromField( uint32_t aFieldKey ) const;
227
228 void cacheFontDefs();
229 void setupLayers();
230 void createNets();
231 void createTracks();
232 void createBoardShapes();
233 void createBoardText();
234 void createZones();
235 void createTables();
236 void applyZoneFills();
237 void enablePadTeardrops();
238 void applyConstraintSets();
239 void applyNetConstraints();
240 void applyMatchGroups();
241
248 const BLK_0x36_DEF_TABLE::FontDef_X08* getFontDef( unsigned aIndex ) const;
249
253 const BLK_0x07_COMPONENT_INST* getFpInstRef( const BLK_0x2D_FOOTPRINT_INST& aFpInstance ) const;
254
260
261 // Cached list of font defs in the 0x36 node
262 std::vector<const BLK_0x36_DEF_TABLE::FontDef_X08*> m_fontDefList;
263
264 // Cached list of KiCad nets corresponding to Allegro 0x1B NET keys
265 std::unordered_map<uint32_t, NETINFO_ITEM*> m_netCache;
266
273
274 std::unordered_map<uint32_t, ZoneFillEntry> m_zoneFillShapes;
275
276 // Keys that have been used as zone fills already
277 std::unordered_set<uint32_t> m_usedZoneFillShapes;
278
279 std::unique_ptr<LAYER_MAPPER> m_layerMapper;
280
281 // Cache of computed outlines keyed by shape block key, avoiding redundant geometry rebuilds
282 mutable std::unordered_map<uint32_t, SHAPE_LINE_CHAIN> m_outlineCache;
283
284 // Cache of segment chains keyed by start key, avoiding redundant hole geometry rebuilds
285 mutable std::unordered_map<uint32_t, SHAPE_LINE_CHAIN> m_segChainCache;
286
287 // Conversion factor from internal units to nanometers.
288 double m_scale;
289};
290
291} // namespace ALLEGRO
The base class for all blocks in the main body of an Allegro file.
uint8_t GetBlockType() const
This is the actual type code as read from the file.
const T & GetData() const
SHAPE_POLY_SET shapeToPolySet(const BLK_0x28_SHAPE &aShape) const
wxString resolveMatchGroupName(const BLK_0x1B_NET &aNet) const
Follow m_MatchGroupPtr through the 0x26/0x2C pointer chain to get the match group name for a NET.
const SHAPE_LINE_CHAIN & buildSegmentChain(uint32_t aStartKey) const
Walk a geometry chain (0x01 arcs and 0x15-17 segments) starting from the given key,...
LAYER_MAPPING_HANDLER m_layerMappingHandler
PROGRESS_REPORTER * m_progressReporter
void reportUnexpectedBlockType(uint8_t aGot, uint8_t aExpected, uint32_t aKey=0, size_t aOffset=0, const wxString &aName=wxEmptyString) const
const BLK_0x07_COMPONENT_INST * getFpInstRef(const BLK_0x2D_FOOTPRINT_INST &aFpInstance) const
Look up 0x07 FP instance data (0x07) for a given 0x2D FP instance.
std::vector< const BLOCK_BASE * > getShapeRelatedBlocks(const BLK_0x28_SHAPE &aShape) const
Get blocks that are related to the BOUNDARY shape, i.e.
VECTOR2I scaleSize(const VECTOR2I &aSize) const
PCB_LAYER_ID getLayer(const LAYER_INFO &aLayerInfo) const
std::unordered_map< uint32_t, SHAPE_LINE_CHAIN > m_segChainCache
std::vector< std::unique_ptr< PCB_SHAPE > > buildShapes(const BLK_0x14_GRAPHIC &aGraphicList, BOARD_ITEM_CONTAINER &aParent)
Build the shapes from an 0x14 shape list.
BOARD_BUILDER(const BRD_DB &aBrdDb, BOARD &aBoard, REPORTER &aReporter, PROGRESS_REPORTER *aProgressReporter, const LAYER_MAPPING_HANDLER &aLayerMappingHandler)
std::unique_ptr< LAYER_MAPPER > m_layerMapper
const T * expectBlockByKey(uint32_t aKey) const
Get a block by its key, and check that it is of the expected type.
std::vector< std::unique_ptr< BOARD_ITEM > > buildDrillMarker(const BLK_0x0C_PIN_DEF &aPinDef, BOARD_ITEM_CONTAINER &aParent)
Build a drill marker from a 0x0C PIN_DEF block.
std::unique_ptr< PCB_SHAPE > buildRect(const BLK_0x24_RECT &aRect, BOARD_ITEM_CONTAINER &aParent)
Build a rectangular shape from a 0x24 RECT block.
std::vector< std::unique_ptr< PCB_SHAPE > > buildPolygonShapes(const BLK_0x28_SHAPE &aShape, BOARD_ITEM_CONTAINER &aParent)
Build graphics from an 0x28 SHAPE, with separate items per segment/arc.
std::unique_ptr< PCB_SHAPE > buildArc(const BLK_0x01_ARC &aArc, const LAYER_INFO &aLayerInfo, PCB_LAYER_ID aLayer, BOARD_ITEM_CONTAINER &aParent)
std::unique_ptr< PCB_TEXT > buildPcbText(const BLK_0x30_STR_WRAPPER &aStrWrapper, BOARD_ITEM_CONTAINER &aParent)
std::unique_ptr< FOOTPRINT > buildFootprint(const BLK_0x2D_FOOTPRINT_INST &aFpInstance)
void reportMissingBlock(uint32_t aKey, uint8_t aType) const
std::unordered_map< uint32_t, NETINFO_ITEM * > m_netCache
std::unique_ptr< ZONE > buildZone(const BLOCK_BASE &aBoundaryBlock, const std::vector< const BLOCK_BASE * > &aRelatedBlocks, ZONE_FILL_HANDLER &aZoneFillHandler)
Build a ZONE from an 0x0E, 0x24 or 0x28 block.
SHAPE_LINE_CHAIN buildOutline(const BLK_0x0E_RECT &aRect) const
std::unique_ptr< PCB_SHAPE > buildLineSegment(const BLK_0x15_16_17_SEGMENT &aSegment, const LAYER_INFO &aLayerInfo, PCB_LAYER_ID aLayer, BOARD_ITEM_CONTAINER &aParent)
Build a single line segment.
std::vector< std::unique_ptr< BOARD_ITEM > > buildTrack(const BLK_0x05_TRACK &aBlock, int aNetcode)
std::vector< const BLK_0x36_DEF_TABLE::FontDef_X08 * > m_fontDefList
std::unordered_map< uint32_t, ZoneFillEntry > m_zoneFillShapes
SHAPE_POLY_SET tryBuildZoneShape(const BLOCK_BASE &aBlock)
Try to build a zone shape for the given block, with holes.
std::unordered_map< uint32_t, SHAPE_LINE_CHAIN > m_outlineCache
wxString get0x30StringValue(uint32_t a0x30Key) const
Get just the string value from a 0x31 STRING WRAPPER -> 0x30 STRING GRAPHIC pair.
const BLK_0x36_DEF_TABLE::FontDef_X08 * getFontDef(unsigned aIndex) const
Get the font definition for a given index in a 0x30, etc.
std::vector< std::unique_ptr< BOARD_ITEM > > buildGraphicItems(const BLOCK_BASE &aBlock, BOARD_ITEM_CONTAINER &aParent)
Build a list of graphic items, e.g.
std::unique_ptr< BOARD_ITEM > buildVia(const BLK_0x33_VIA &aBlock, int aNetcode)
std::unique_ptr< PCB_SHAPE > buildPolygon(const BLK_0x28_SHAPE &aShape, BOARD_ITEM_CONTAINER &aParent)
Build a graphic polygon from a 0x28 SHAPE block.
wxString resolveConstraintSetNameFromField(uint32_t aFieldKey) const
Extract constraint set name from a 0x03 FIELD block pointer.
std::unordered_set< uint32_t > m_usedZoneFillShapes
std::vector< std::unique_ptr< BOARD_ITEM > > buildPadItems(const BLK_0x1C_PADSTACK &aPadstack, FOOTPRINT &aFp, const wxString &aPadName, int aNetcode)
Construct "pad" items for a given 0x1C PADSTACK block.
An Allegro board database representing the contents of a .brd (and presumably .dra) file.
Definition allegro_db.h:47
Class to handle the mapping for Allegro CLASS/SUBCLASS idiom to KiCad layers.
Abstract interface for BOARD_ITEMs capable of storing other items inside.
Information pertinent to a Pcbnew printed circuit board.
Definition board.h:323
Handle the data for a net.
Definition netinfo.h:50
A progress reporter interface for use in multi-threaded environments.
A pure virtual class used to derive REPORTER objects from.
Definition reporter.h:75
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
Represent a set of closed polygons.
PCB_LAYER_ID
A quick note on layer IDs:
Definition layer_ids.h:60
std::function< std::map< wxString, PCB_LAYER_ID >(const std::vector< INPUT_LAYER_DESC > &)> LAYER_MAPPING_HANDLER
Pointer to a function that takes a map of source and KiCad layers and returns a re-mapped version.
const int scale
Arc segment used in tracks, zone outlines, and shape boundaries.
Track segment container.
Component instance reference data.
Pin definition with shape type, drill character, coordinates, and size.
Graphics container holding a chain of line segments and arcs.
0x15 , 0x16, 0x17 are segments:
0x1B objects are nets.
Padstack definition containing drill dimensions and a table of per-layer pad/antipad/thermal componen...
Rectangle defined by four coordinates.
Polygon shape defined by a linked list of segments starting at m_FirstSegmentPtr (0x15/0x16/0x17 line...
Placed footprint instance on the board.
Text object with position, rotation, layer, font properties, and alignment.
Via instance with board position, padstack reference (m_Padstack for drill/annular ring definitions),...
VECTOR2< int32_t > VECTOR2I
Definition vector2d.h:687