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 <optional>
30#include <unordered_map>
31#include <utility>
32#include <vector>
33#include <unordered_set>
34
36#include <convert/allegro_db.h>
37
38#include <board.h>
40#include <reporter.h>
41#include <progress_reporter.h>
43
44
45class BOARD;
46class FOOTPRINT;
47class NETINFO_ITEM;
48class PCB_TEXT;
49
50namespace ALLEGRO
51{
52
53class LAYER_MAPPER;
54
60{
61public:
62 BOARD_BUILDER( const BRD_DB& aBrdDb, BOARD& aBoard, REPORTER& aReporter,
63 PROGRESS_REPORTER* aProgressReporter,
64 const LAYER_MAPPING_HANDLER& aLayerMappingHandler );
66
67 bool BuildBoard();
68
69private:
70 VECTOR2I scale( const VECTOR2I& aVector ) const;
71 VECTOR2I scaleSize( const VECTOR2I& aSize ) const;
72 int scale( int aVal ) const;
73
79 template <ALLEGRO_BLOCK_DATA T>
80 const T* expectBlockByKey( uint32_t aKey ) const
81 {
82 // The type code trait
83 constexpr uint8_t kType = T::BLOCK_TYPE_CODE;
84
85 if( aKey == 0 )
86 return nullptr;
87
88 const BLOCK_BASE* block = m_brdDb.GetObjectByKey( aKey );
89
90 if( !block )
91 {
92 reportMissingBlock( aKey, kType );
93 return nullptr;
94 }
95
96 if( block->GetBlockType() != kType )
97 {
98 reportUnexpectedBlockType( block->GetBlockType(), kType, aKey, block->GetOffset() );
99 return nullptr;
100 }
101
102 return &static_cast<const BLOCK<T>&>( *block ).GetData();
103 }
104
105 void reportMissingBlock( uint32_t aKey, uint8_t aType ) const;
106 void reportUnexpectedBlockType( uint8_t aGot, uint8_t aExpected, uint32_t aKey = 0, size_t aOffset = 0,
107 const wxString& aName = wxEmptyString ) const;
108
109 PCB_LAYER_ID getLayer( const LAYER_INFO& aLayerInfo ) const;
110
116 wxString get0x30StringValue( uint32_t a0x30Key ) const;
117
121 std::unique_ptr<PCB_SHAPE> buildLineSegment( const BLK_0x15_16_17_SEGMENT& aSegment, const LAYER_INFO& aLayerInfo,
122 PCB_LAYER_ID aLayer, BOARD_ITEM_CONTAINER& aParent );
123
124 std::unique_ptr<PCB_SHAPE> buildArc( const BLK_0x01_ARC& aArc, const LAYER_INFO& aLayerInfo, PCB_LAYER_ID aLayer,
125 BOARD_ITEM_CONTAINER& aParent );
126
130 std::vector<std::unique_ptr<PCB_SHAPE>> buildShapes( const BLK_0x14_GRAPHIC& aGraphicList, BOARD_ITEM_CONTAINER& aParent );
131 std::unique_ptr<PCB_TEXT> buildPcbText( const BLK_0x30_STR_WRAPPER& aStrWrapper, BOARD_ITEM_CONTAINER& aParent );
132
136 std::unique_ptr<PCB_SHAPE> buildRect( const BLK_0x24_RECT& aRect, BOARD_ITEM_CONTAINER& aParent );
137
141 std::unique_ptr<PCB_SHAPE> buildRect( const BLK_0x0E_RECT& aShape, BOARD_ITEM_CONTAINER& aParent );
142
143
147 std::unique_ptr<PCB_SHAPE> buildPolygon( const BLK_0x28_SHAPE& aShape, BOARD_ITEM_CONTAINER& aParent );
148
152 std::vector<std::unique_ptr<PCB_SHAPE>> buildPolygonShapes( const BLK_0x28_SHAPE& aShape,
153 BOARD_ITEM_CONTAINER& aParent );
154
158 std::vector<std::unique_ptr<BOARD_ITEM>> buildDrillMarker( const BLK_0x0C_PIN_DEF& aPinDef,
159 BOARD_ITEM_CONTAINER& aParent );
160
164 std::vector<std::unique_ptr<BOARD_ITEM>> buildGraphicItems( const BLOCK_BASE& aBlock,
165 BOARD_ITEM_CONTAINER& aParent );
166
170 std::vector<std::unique_ptr<BOARD_ITEM>> buildPadItems( const BLK_0x1C_PADSTACK& aPadstack, FOOTPRINT& aFp,
171 const wxString& aPadName, int aNetcode );
172 std::unique_ptr<FOOTPRINT> buildFootprint( const BLK_0x2D_FOOTPRINT_INST& aFpInstance );
173 std::vector<std::unique_ptr<BOARD_ITEM>> buildTrack( const BLK_0x05_TRACK& aBlock, int aNetcode );
174 std::unique_ptr<BOARD_ITEM> buildVia( const BLK_0x33_VIA& aBlock, int aNetcode );
175
179 std::optional<std::pair<int, int>> resolveViaSpan( const BLK_0x1C_PADSTACK& aPadstack,
180 const VECTOR2I& aViaCenterRaw, int aTotalCu,
181 bool& aResolved );
182
186
187 class ZONE_FILL_HANDLER;
188
195 std::unique_ptr<ZONE> buildZone( const BLOCK_BASE& aBoundaryBlock,
196 const std::vector<const BLOCK_BASE*>& aRelatedBlocks,
197 ZONE_FILL_HANDLER& aZoneFillHandler );
198
199 SHAPE_LINE_CHAIN buildOutline( const BLK_0x0E_RECT& aRect ) const;
200 SHAPE_LINE_CHAIN buildOutline( const BLK_0x24_RECT& aRect ) const;
201 SHAPE_LINE_CHAIN buildOutline( const BLK_0x28_SHAPE& aShape ) const;
202
203 SHAPE_POLY_SET shapeToPolySet( const BLK_0x28_SHAPE& aShape ) const;
204
209
214 const SHAPE_LINE_CHAIN& buildSegmentChain( uint32_t aStartKey ) const;
215
219 std::vector<const BLOCK_BASE*> getShapeRelatedBlocks( const BLK_0x28_SHAPE& aShape ) const;
220
230 wxString resolveMatchGroupName( const BLK_0x1B_NET& aNet ) const;
231
239 wxString resolveConstraintSetNameFromField( uint32_t aFieldKey ) const;
240
241 void cacheFontDefs();
242 void setupLayers();
243 void createNets();
244 void createTracks();
245 void createBoardShapes();
246 void createBoardText();
247 void createZones();
248 void createTables();
249 void applyZoneFills();
250 void enablePadTeardrops();
251 void applyConstraintSets();
252 void applyNetConstraints();
253 void applyMatchGroups();
254
261 const BLK_0x36_DEF_TABLE::FontDef_X08* getFontDef( unsigned aIndex ) const;
262
266 const BLK_0x07_COMPONENT_INST* getFpInstRef( const BLK_0x2D_FOOTPRINT_INST& aFpInstance ) const;
267
273
274 // Cached list of font defs in the 0x36 node
275 std::vector<const BLK_0x36_DEF_TABLE::FontDef_X08*> m_fontDefList;
276
277 // Cached list of KiCad nets corresponding to Allegro 0x1B NET keys
278 std::unordered_map<uint32_t, NETINFO_ITEM*> m_netCache;
279
286
287 std::unordered_map<uint32_t, ZoneFillEntry> m_zoneFillShapes;
288
289 // Keys that have been used as zone fills already
290 std::unordered_set<uint32_t> m_usedZoneFillShapes;
291
292 std::unique_ptr<LAYER_MAPPER> m_layerMapper;
293
294 // Cache of computed outlines keyed by shape block key, avoiding redundant geometry rebuilds
295 mutable std::unordered_map<uint32_t, SHAPE_LINE_CHAIN> m_outlineCache;
296
297 // Cache of segment chains keyed by start key, avoiding redundant hole geometry rebuilds
298 mutable std::unordered_map<uint32_t, SHAPE_LINE_CHAIN> m_segChainCache;
299
300 // Resolved copper span (0-based) per via padstack key, or nullopt for a through via.
301 std::unordered_map<uint32_t, std::optional<std::pair<int, int>>> m_viaSpanCache;
302
303 // Packed track segment endpoint -> [min,max] copper layer index of tracks ending there.
304 std::unordered_map<int64_t, std::pair<int, int>> m_trackEndpointCopper;
305
306 // True once m_trackEndpointCopper has been populated.
308
309 // Conversion factor from internal units to nanometers.
310 double m_scale;
311};
312
313} // 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::unordered_map< uint32_t, std::optional< std::pair< int, int > > > m_viaSpanCache
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.
std::unordered_map< int64_t, std::pair< int, int > > m_trackEndpointCopper
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
void collectTrackEndpointCopper()
Populate m_trackEndpointCopper, mapping each copper track segment endpoint to the copper layers termi...
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::optional< std::pair< int, int > > resolveViaSpan(const BLK_0x1C_PADSTACK &aPadstack, const VECTOR2I &aViaCenterRaw, int aTotalCu, bool &aResolved)
Resolve a via padstack's copper span (0-based first/last copper index), or nullopt for a through via,...
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