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, see <https://www.gnu.org/licenses/>.
19 */
20
21#pragma once
22
23#include <functional>
24#include <memory>
25#include <optional>
26#include <unordered_map>
27#include <utility>
28#include <vector>
29#include <unordered_set>
30
32#include <convert/allegro_db.h>
33
34#include <board.h>
36#include <reporter.h>
37#include <progress_reporter.h>
39
40
41class BOARD;
42class FOOTPRINT;
43class NETINFO_ITEM;
44class PCB_TEXT;
45
46namespace ALLEGRO
47{
48
49class LAYER_MAPPER;
50
56{
57public:
58 BOARD_BUILDER( const BRD_DB& aBrdDb, BOARD& aBoard, REPORTER& aReporter,
59 PROGRESS_REPORTER* aProgressReporter,
60 const LAYER_MAPPING_HANDLER& aLayerMappingHandler );
62
63 bool BuildBoard();
64
65private:
66 VECTOR2I scale( const VECTOR2I& aVector ) const;
67 VECTOR2I scaleSize( const VECTOR2I& aSize ) const;
68 int scale( int aVal ) const;
69
75 template <ALLEGRO_BLOCK_DATA T>
76 const T* expectBlockByKey( uint32_t aKey ) const
77 {
78 // The type code trait
79 constexpr uint8_t kType = T::BLOCK_TYPE_CODE;
80
81 if( aKey == 0 )
82 return nullptr;
83
84 const BLOCK_BASE* block = m_brdDb.GetObjectByKey( aKey );
85
86 if( !block )
87 {
88 reportMissingBlock( aKey, kType );
89 return nullptr;
90 }
91
92 if( block->GetBlockType() != kType )
93 {
94 reportUnexpectedBlockType( block->GetBlockType(), kType, aKey, block->GetOffset() );
95 return nullptr;
96 }
97
98 return &static_cast<const BLOCK<T>&>( *block ).GetData();
99 }
100
101 void reportMissingBlock( uint32_t aKey, uint8_t aType ) const;
102 void reportUnexpectedBlockType( uint8_t aGot, uint8_t aExpected, uint32_t aKey = 0, size_t aOffset = 0,
103 const wxString& aName = wxEmptyString ) const;
104
105 PCB_LAYER_ID getLayer( const LAYER_INFO& aLayerInfo ) const;
106
112 wxString get0x30StringValue( uint32_t a0x30Key ) const;
113
117 std::unique_ptr<PCB_SHAPE> buildLineSegment( const BLK_0x15_16_17_SEGMENT& aSegment, const LAYER_INFO& aLayerInfo,
118 PCB_LAYER_ID aLayer, BOARD_ITEM_CONTAINER& aParent );
119
120 std::unique_ptr<PCB_SHAPE> buildArc( const BLK_0x01_ARC& aArc, const LAYER_INFO& aLayerInfo, PCB_LAYER_ID aLayer,
121 BOARD_ITEM_CONTAINER& aParent );
122
126 std::vector<std::unique_ptr<PCB_SHAPE>> buildShapes( const BLK_0x14_GRAPHIC& aGraphicList, BOARD_ITEM_CONTAINER& aParent );
127 std::unique_ptr<PCB_TEXT> buildPcbText( const BLK_0x30_STR_WRAPPER& aStrWrapper, BOARD_ITEM_CONTAINER& aParent );
128
132 std::unique_ptr<PCB_SHAPE> buildRect( const BLK_0x24_RECT& aRect, BOARD_ITEM_CONTAINER& aParent );
133
137 std::unique_ptr<PCB_SHAPE> buildRect( const BLK_0x0E_RECT& aShape, BOARD_ITEM_CONTAINER& aParent );
138
139
143 std::unique_ptr<PCB_SHAPE> buildPolygon( const BLK_0x28_SHAPE& aShape, BOARD_ITEM_CONTAINER& aParent );
144
148 std::vector<std::unique_ptr<PCB_SHAPE>> buildPolygonShapes( const BLK_0x28_SHAPE& aShape,
149 BOARD_ITEM_CONTAINER& aParent );
150
154 std::vector<std::unique_ptr<BOARD_ITEM>> buildDrillMarker( const BLK_0x0C_PIN_DEF& aPinDef,
155 BOARD_ITEM_CONTAINER& aParent );
156
160 std::vector<std::unique_ptr<BOARD_ITEM>> buildGraphicItems( const BLOCK_BASE& aBlock,
161 BOARD_ITEM_CONTAINER& aParent );
162
166 std::vector<std::unique_ptr<BOARD_ITEM>> buildPadItems( const BLK_0x1C_PADSTACK& aPadstack, FOOTPRINT& aFp,
167 const wxString& aPadName, int aNetcode );
168 std::unique_ptr<FOOTPRINT> buildFootprint( const BLK_0x2D_FOOTPRINT_INST& aFpInstance );
169 std::vector<std::unique_ptr<BOARD_ITEM>> buildTrack( const BLK_0x05_TRACK& aBlock, int aNetcode );
170 std::unique_ptr<BOARD_ITEM> buildVia( const BLK_0x33_VIA& aBlock, int aNetcode );
171
175 std::optional<std::pair<int, int>> resolveViaSpan( const BLK_0x1C_PADSTACK& aPadstack,
176 const VECTOR2I& aViaCenterRaw, int aTotalCu,
177 bool& aResolved );
178
182
183 class ZONE_FILL_HANDLER;
184
191 std::unique_ptr<ZONE> buildZone( const BLOCK_BASE& aBoundaryBlock,
192 const std::vector<const BLOCK_BASE*>& aRelatedBlocks,
193 ZONE_FILL_HANDLER& aZoneFillHandler );
194
195 SHAPE_LINE_CHAIN buildOutline( const BLK_0x0E_RECT& aRect ) const;
196 SHAPE_LINE_CHAIN buildOutline( const BLK_0x24_RECT& aRect ) const;
197 SHAPE_LINE_CHAIN buildOutline( const BLK_0x28_SHAPE& aShape ) const;
198
199 SHAPE_POLY_SET shapeToPolySet( const BLK_0x28_SHAPE& aShape ) const;
200
205
210 const SHAPE_LINE_CHAIN& buildSegmentChain( uint32_t aStartKey ) const;
211
215 std::vector<const BLOCK_BASE*> getShapeRelatedBlocks( const BLK_0x28_SHAPE& aShape ) const;
216
226 wxString resolveMatchGroupName( const BLK_0x1B_NET& aNet ) const;
227
235 wxString resolveConstraintSetNameFromField( uint32_t aFieldKey ) const;
236
237 void cacheFontDefs();
238 void setupLayers();
239 void createNets();
240 void createTracks();
241 void createBoardShapes();
242 void createBoardText();
243 void createZones();
244 void createTables();
245 void applyZoneFills();
246 void enablePadTeardrops();
247 void applyConstraintSets();
248 void applyNetConstraints();
249 void applyMatchGroups();
250
257 const BLK_0x36_DEF_TABLE::FontDef_X08* getFontDef( unsigned aIndex ) const;
258
262 const BLK_0x07_COMPONENT_INST* getFpInstRef( const BLK_0x2D_FOOTPRINT_INST& aFpInstance ) const;
263
269
270 // Cached list of font defs in the 0x36 node
271 std::vector<const BLK_0x36_DEF_TABLE::FontDef_X08*> m_fontDefList;
272
273 // Cached list of KiCad nets corresponding to Allegro 0x1B NET keys
274 std::unordered_map<uint32_t, NETINFO_ITEM*> m_netCache;
275
282
283 std::unordered_map<uint32_t, ZoneFillEntry> m_zoneFillShapes;
284
285 // Keys that have been used as zone fills already
286 std::unordered_set<uint32_t> m_usedZoneFillShapes;
287
288 std::unique_ptr<LAYER_MAPPER> m_layerMapper;
289
290 // Cache of computed outlines keyed by shape block key, avoiding redundant geometry rebuilds
291 mutable std::unordered_map<uint32_t, SHAPE_LINE_CHAIN> m_outlineCache;
292
293 // Cache of segment chains keyed by start key, avoiding redundant hole geometry rebuilds
294 mutable std::unordered_map<uint32_t, SHAPE_LINE_CHAIN> m_segChainCache;
295
296 // Resolved copper span (0-based) per via padstack key, or nullopt for a through via.
297 std::unordered_map<uint32_t, std::optional<std::pair<int, int>>> m_viaSpanCache;
298
299 // Packed track segment endpoint -> [min,max] copper layer index of tracks ending there.
300 std::unordered_map<int64_t, std::pair<int, int>> m_trackEndpointCopper;
301
302 // True once m_trackEndpointCopper has been populated.
304
305 // Conversion factor from internal units to nanometers.
306 double m_scale;
307};
308
309} // 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:43
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:372
Handle the data for a net.
Definition netinfo.h:46
A progress reporter interface for use in multi-threaded environments.
A pure virtual class used to derive REPORTER objects from.
Definition reporter.h:71
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:56
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:683