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
72 template <typename T>
73 const T* expectBlockByKey( uint32_t aKey, uint8_t aType ) const
74 {
75 if( aKey == 0 )
76 return nullptr;
77
78 const BLOCK_BASE* block = m_brdDb.GetObjectByKey( aKey );
79
80 if( !block )
81 {
82 reportMissingBlock( aKey, aType );
83 return nullptr;
84 }
85
86 if( block->GetBlockType() != aType )
87 {
88 reportUnexpectedBlockType( block->GetBlockType(), aType, aKey, block->GetOffset() );
89 return nullptr;
90 }
91
92 return &static_cast<const BLOCK<T>&>( *block ).GetData();
93 }
94
95 void reportMissingBlock( uint32_t aKey, uint8_t aType ) const;
96 void reportUnexpectedBlockType( uint8_t aGot, uint8_t aExpected, uint32_t aKey = 0, size_t aOffset = 0,
97 const wxString& aName = wxEmptyString ) const;
98
99 PCB_LAYER_ID getLayer( const LAYER_INFO& aLayerInfo ) const;
100
106 wxString get0x30StringValue( uint32_t a0x30Key ) const;
107
111 std::unique_ptr<PCB_SHAPE> buildLineSegment( const BLK_0x15_16_17_SEGMENT& aSegment, const LAYER_INFO& aLayerInfo,
112 PCB_LAYER_ID aLayer, BOARD_ITEM_CONTAINER& aParent );
113
114 std::unique_ptr<PCB_SHAPE> buildArc( const BLK_0x01_ARC& aArc, const LAYER_INFO& aLayerInfo, PCB_LAYER_ID aLayer,
115 BOARD_ITEM_CONTAINER& aParent );
116
120 std::vector<std::unique_ptr<PCB_SHAPE>> buildShapes( const BLK_0x14_GRAPHIC& aGraphicList, BOARD_ITEM_CONTAINER& aParent );
121 std::unique_ptr<PCB_TEXT> buildPcbText( const BLK_0x30_STR_WRAPPER& aStrWrapper, BOARD_ITEM_CONTAINER& aParent );
122
126 std::unique_ptr<PCB_SHAPE> buildRect( const BLK_0x24_RECT& aRect, BOARD_ITEM_CONTAINER& aParent );
127
131 std::unique_ptr<PCB_SHAPE> buildRect( const BLK_0x0E_RECT& aShape, BOARD_ITEM_CONTAINER& aParent );
132
133
137 std::unique_ptr<PCB_SHAPE> buildPolygon( const BLK_0x28_SHAPE& aShape, BOARD_ITEM_CONTAINER& aParent );
138
142 std::vector<std::unique_ptr<PCB_SHAPE>> buildPolygonShapes( const BLK_0x28_SHAPE& aShape,
143 BOARD_ITEM_CONTAINER& aParent );
144
148 std::vector<std::unique_ptr<BOARD_ITEM>> buildDrillMarker( const BLK_0x0C_PIN_DEF& aPinDef,
149 BOARD_ITEM_CONTAINER& aParent );
150
154 std::vector<std::unique_ptr<BOARD_ITEM>> buildGraphicItems( const BLOCK_BASE& aBlock,
155 BOARD_ITEM_CONTAINER& aParent );
156
160 std::vector<std::unique_ptr<BOARD_ITEM>> buildPadItems( const BLK_0x1C_PADSTACK& aPadstack, FOOTPRINT& aFp,
161 const wxString& aPadName, int aNetcode );
162 std::unique_ptr<FOOTPRINT> buildFootprint( const BLK_0x2D_FOOTPRINT_INST& aFpInstance );
163 std::vector<std::unique_ptr<BOARD_ITEM>> buildTrack( const BLK_0x05_TRACK& aBlock, int aNetcode );
164 std::unique_ptr<BOARD_ITEM> buildVia( const BLK_0x33_VIA& aBlock, int aNetcode );
165
166 class ZONE_FILL_HANDLER;
167
174 std::unique_ptr<ZONE> buildZone( const BLOCK_BASE& aBoundaryBlock,
175 const std::vector<const BLOCK_BASE*>& aRelatedBlocks,
176 ZONE_FILL_HANDLER& aZoneFillHandler );
177
178 SHAPE_LINE_CHAIN buildOutline( const BLK_0x0E_RECT& aRect ) const;
179 SHAPE_LINE_CHAIN buildOutline( const BLK_0x24_RECT& aRect ) const;
180 SHAPE_LINE_CHAIN buildOutline( const BLK_0x28_SHAPE& aShape ) const;
181
182 SHAPE_POLY_SET shapeToPolySet( const BLK_0x28_SHAPE& aShape ) const;
183
188
193 const SHAPE_LINE_CHAIN& buildSegmentChain( uint32_t aStartKey ) const;
194
198 std::vector<const BLOCK_BASE*> getShapeRelatedBlocks( const BLK_0x28_SHAPE& aShape ) const;
199
209 wxString resolveMatchGroupName( const BLK_0x1B_NET& aNet ) const;
210
218 wxString resolveConstraintSetNameFromField( uint32_t aFieldKey ) const;
219
220 void cacheFontDefs();
221 void setupLayers();
222 void createNets();
223 void createTracks();
224 void createBoardShapes();
225 void createBoardText();
226 void createZones();
227 void createTables();
228 void applyZoneFills();
229 void enablePadTeardrops();
230 void applyConstraintSets();
231 void applyNetConstraints();
232 void applyMatchGroups();
233
240 const BLK_0x36_DEF_TABLE::FontDef_X08* getFontDef( unsigned aIndex ) const;
241
245 const BLK_0x07_COMPONENT_INST* getFpInstRef( const BLK_0x2D_FOOTPRINT_INST& aFpInstance ) const;
246
252
253 // Cached list of font defs in the 0x36 node
254 std::vector<const BLK_0x36_DEF_TABLE::FontDef_X08*> m_fontDefList;
255
256 // Cached list of KiCad nets corresponding to Allegro 0x1B NET keys
257 std::unordered_map<uint32_t, NETINFO_ITEM*> m_netCache;
258
265
266 std::unordered_map<uint32_t, ZoneFillEntry> m_zoneFillShapes;
267
268 // Keys that have been used as zone fills already
269 std::unordered_set<uint32_t> m_usedZoneFillShapes;
270
271 std::unique_ptr<LAYER_MAPPER> m_layerMapper;
272
273 // Cache of computed outlines keyed by shape block key, avoiding redundant geometry rebuilds
274 mutable std::unordered_map<uint32_t, SHAPE_LINE_CHAIN> m_outlineCache;
275
276 // Cache of segment chains keyed by start key, avoiding redundant hole geometry rebuilds
277 mutable std::unordered_map<uint32_t, SHAPE_LINE_CHAIN> m_segChainCache;
278
279 // Conversion factor from internal units to nanometers.
280 double m_scale;
281};
282
283} // namespace ALLEGRO
The base class for all blocks in the main body of an Allegro file.
uint8_t GetBlockType() const
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
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)
const T * expectBlockByKey(uint32_t aKey, uint8_t aType) const
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 database that represents a .brd file (amd presumably .dra)
Definition allegro_db.h:948
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:322
Handle the data for a net.
Definition netinfo.h:54
A progress reporter interface for use in multi-threaded environments.
A pure virtual class used to derive REPORTER objects from.
Definition reporter.h:73
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:695