61 virtual bool Run()
override;
63 virtual const wxString
GetName()
const override {
return wxT(
"library_parity" ); };
72#define TEST( a, b, msg ) \
78 if( aReporter && wxString( msg ).length() ) \
79 aReporter->Report( msg ); \
82 if( diff && !aReporter ) \
87#define TEST_PT( a, b, msg ) \
89 if( abs( a.x - b.x ) > EPSILON \
90 || abs( a.y - b.y ) > EPSILON ) \
94 if( aReporter && wxString( msg ).length() ) \
95 aReporter->Report( msg ); \
98 if( diff && !aReporter ) \
102#define EPSILON_D 0.000002
103#define TEST_D( a, b, msg ) \
105 if( abs( a - b ) > EPSILON_D ) \
109 if( aReporter && wxString( msg ).length() ) \
110 aReporter->Report( msg ); \
113 if( diff && !aReporter ) \
117#define ITEM_DESC( item ) ( item )->GetItemDescription( &g_unitsProvider, true )
118#define PAD_DESC( pad ) wxString::Format( _( "Pad %s" ), ( pad )->GetNumber() )
136 bool aAllowCuExpansion )
138 if( !aAllowCuExpansion )
140 return aItem == bLib;
145 const LSET aNonCu = aItem & nonCuMask;
146 const LSET bNonCu = bLib & nonCuMask;
148 if( aNonCu != bNonCu )
163 const LSET missingInnerInA = bInner & ~aInner;
164 if( missingInnerInA.count() )
172 const std::shared_ptr<PCB_SHAPE>& b )
177 TEST( a->GetShape(), b->GetShape(),
"" );
179 switch( a->GetShape() )
183 BOX2I aRect( a->GetStart(), a->GetEnd() - a->GetStart() );
184 BOX2I bRect( b->GetStart(), b->GetEnd() - b->GetStart() );
196 TEST_PT( a->GetStart(), b->GetStart(),
"" );
197 TEST_PT( a->GetEnd(), b->GetEnd(),
"" );
201 TEST_PT( a->GetStart(), b->GetStart(),
"" );
202 TEST_PT( a->GetEnd(), b->GetEnd(),
"" );
206 if( ( a->GetArcMid() - b->GetArcMid() ).EuclideanNorm() >
pcbIUScale.mmToIU( 0.0005 ) )
212 TEST_PT( a->GetStart(), b->GetStart(),
"" );
213 TEST_PT( a->GetEnd(), b->GetEnd(),
"" );
214 TEST_PT( a->GetBezierC1(), b->GetBezierC1(),
"" );
215 TEST_PT( a->GetBezierC2(), b->GetBezierC2(),
"" );
219 TEST( a->GetPolyShape().TotalVertices(), b->GetPolyShape().TotalVertices(),
"" );
221 for(
int ii = 0; ii < a->GetPolyShape().TotalVertices(); ++ii )
222 TEST_PT( a->GetPolyShape().CVertex( ii ), b->GetPolyShape().CVertex( ii ),
"" );
230 TEST( a->GetStroke(), b->GetStroke(),
"" );
231 TEST( a->GetFillMode(), b->GetFillMode(),
"" );
241#define REPORT_MSG( s, p ) aReporter.Report( wxString::Format( s, p ) )
313 wxString::Format(
_(
"%s pad to die length differs." ),
PAD_DESC( a ) ) );
315 wxString::Format(
_(
"%s position differs." ),
PAD_DESC( a ) ) );
318 wxString::Format(
_(
"%s has different numbers." ),
PAD_DESC( a ) ) );
330 bool allowExpansion =
false;
334 if( layerSettingsDiffer
342 aReporter->
Report( wxString::Format(
_(
"%s layers differ." ),
PAD_DESC( a ) ) );
348 wxString::Format(
_(
"%s pad type differs." ),
PAD_DESC( a ) ) );
350 wxString::Format(
_(
"%s fabrication property differs." ),
PAD_DESC( a ) ) );
355 wxString::Format(
_(
"%s orientation differs." ),
PAD_DESC( a ) ) );
366 wxString::Format(
_(
"%s pad shape type differs on layer %s." ),
371 wxString::Format(
_(
"%s size differs on layer %s." ),
376 wxString::Format(
_(
"%s trapezoid delta differs on layer %s." ),
384 wxString::Format(
_(
"%s rounded corners differ on layer %s." ),
393 wxString::Format(
_(
"%s chamfered corner sizes differ on layer %s." ),
399 wxString::Format(
_(
"%s chamfered corners differ on layer %s." ),
405 wxString::Format(
_(
"%s shape offset from hole differs on layer %s." ),
411 wxString::Format(
_(
"%s drill shape differs." ),
PAD_DESC( a ) ) );
413 wxString::Format(
_(
"%s drill size differs." ),
PAD_DESC( a ) ) );
428 bool primitivesDiffer =
false;
436 primitivesDiffer =
true;
440 for(
size_t ii = 0; ii < a->
GetPrimitives( aLayer ).size(); ++ii )
445 primitivesDiffer =
true;
452 firstDifferingLayer = aLayer;
456 if( primitivesDiffer )
459 layerName = board ? board->
GetLayerName( firstDifferingLayer )
464 aReporter->
Report( wxString::Format(
_(
"%s shape primitives differ on layer %s." ),
484 wxString::Format(
_(
"%s text differs." ),
ITEM_DESC( &curr_barcode ) ) );
487 wxString::Format(
_(
"%s position differs." ),
ITEM_DESC( &curr_barcode ) ) );
490 wxString::Format(
_(
"%s width differs." ),
ITEM_DESC( &curr_barcode ) ) );
492 wxString::Format(
_(
"%s height differs." ),
ITEM_DESC( &curr_barcode ) ) );
495 wxString::Format(
_(
"%s text size differs." ),
ITEM_DESC( &curr_barcode ) ) );
498 wxString::Format(
_(
"%s code differs." ),
ITEM_DESC( &curr_barcode ) ) );
500 wxString::Format(
_(
"%s error correction level differs." ),
ITEM_DESC( &curr_barcode ) ) );
556 for(
int ii = 0; ii < curr_shape.
GetPolyShape().TotalVertices(); ++ii )
581 wxString::Format(
_(
"%s corner smoothing setting differs." ),
ITEM_DESC( a ) ) );
583 wxString::Format(
_(
"%s corner smoothing radius differs." ),
ITEM_DESC( a ) ) );
585 wxString::Format(
_(
"%s name differs." ),
ITEM_DESC( a ) ) );
587 wxString::Format(
_(
"%s priority differs." ),
ITEM_DESC( a ) ) );
590 wxString::Format(
_(
"%s keep-out property differs." ),
ITEM_DESC( a ) ) );
592 wxString::Format(
_(
"%s keep out zone fill setting differs." ),
ITEM_DESC( a ) ) );
594 wxString::Format(
_(
"%s keep out footprints setting differs." ),
ITEM_DESC( a ) ) );
596 wxString::Format(
_(
"%s keep out pads setting differs." ),
ITEM_DESC( a ) ) );
598 wxString::Format(
_(
"%s keep out tracks setting differs." ),
ITEM_DESC( a ) ) );
600 wxString::Format(
_(
"%s keep out vias setting differs." ),
ITEM_DESC( a ) ) );
608 innerLayerExpansionAllowed ) )
614 aReporter->
Report( wxString::Format(
_(
"%s layers differ." ),
ITEM_DESC( a ) ) );
623 wxString::Format(
_(
"%s pad connection property differs." ),
ITEM_DESC( a ) ) );
625 wxString::Format(
_(
"%s local clearance differs." ),
ITEM_DESC( a ) ) );
627 wxString::Format(
_(
"%s thermal relief gap differs." ),
ITEM_DESC( a ) ) );
629 wxString::Format(
_(
"%s thermal relief spoke width differs." ),
ITEM_DESC( a ) ) );
632 wxString::Format(
_(
"%s min thickness differs." ),
ITEM_DESC( a ) ) );
635 wxString::Format(
_(
"%s remove islands setting differs." ),
ITEM_DESC( a ) ) );
637 wxString::Format(
_(
"%s minimum island size setting differs." ),
ITEM_DESC( a ) ) );
640 wxString::Format(
_(
"%s fill type differs." ),
ITEM_DESC( a ) ) );
642 wxString::Format(
_(
"%s hatch width differs." ),
ITEM_DESC( a ) ) );
644 wxString::Format(
_(
"%s hatch gap differs." ),
ITEM_DESC( a ) ) );
646 wxString::Format(
_(
"%s hatch orientation differs." ),
ITEM_DESC( a ) ) );
648 wxString::Format(
_(
"%s hatch smoothing level differs." ),
ITEM_DESC( a ) ) );
650 wxString::Format(
_(
"%s hatch smoothing amount differs." ),
ITEM_DESC( a ) ) );
652 wxString::Format(
_(
"%s minimum hatch hole setting differs." ),
ITEM_DESC( a ) ) );
658 wxString::Format(
_(
"%s outline corner count differs." ),
ITEM_DESC( a ) ) );
660 bool cornersDiffer =
false;
662 for(
int ii = 0; ii < a->
Outline()->TotalVertices(); ++ii )
667 cornersDiffer =
true;
672 if( cornersDiffer && aReporter )
673 aReporter->
Report( wxString::Format(
_(
"%s corners differ." ),
ITEM_DESC( a ) ) );
689 wxString::Format(
_(
"Footprint stackup mode differs." ) ) );
694 TEST( aLayers, bLayers,
695 wxString::Format(
_(
"Footprint layers differ." ) ) );
718 bool mismatch =
false;
721 const LSET onlyInFp = fpLayers & ~brdLayers;
723 if( onlyInFp.count() )
727 aReporter->
Report( wxString::Format(
_(
"Footprint has %lu layers not on board: %s" ), onlyInFp.count(),
734 if( cuOnlyInBoard.count() )
738 aReporter->
Report( wxString::Format(
_(
"Board has %lu copper layers not in footprint: %s" ),
739 cuOnlyInBoard.count(),
758 std::unique_ptr<FOOTPRINT> temp(
static_cast<FOOTPRINT*
>( aLibFP->
Clone() ) );
774 for(
BOARD_ITEM* item : temp->GraphicalItems() )
775 item->NormalizeForCompare();
779 temp->SetParent(
nullptr );
786#define TEST_ATTR( a, b, attr, msg ) TEST( ( a & attr ), ( b & attr ), msg )
789 _(
"Footprint types differ." ) );
792 wxString::Format(
_(
"'%s' settings differ." ),
793 _(
"Allow bridged solder mask apertures between pads" ) ) );
799 wxString::Format(
_(
"'%s' settings differ." ),
800 _(
"Not in schematic" ) ) );
803 wxString::Format(
_(
"'%s' settings differ." ),
804 _(
"Exclude from position files" ) ) );
807 wxString::Format(
_(
"'%s' settings differ." ),
808 _(
"Exclude from bill of materials" ) ) );
811 wxString::Format(
_(
"'%s' settings differ." ),
812 _(
"Do not populate" ) ) );
815#define REPORT( msg ) { if( aReporter ) aReporter->Report( msg ); }
816#define CHECKPOINT { if( diff && !aReporter ) return diff; }
821 REPORT(
_(
"Footprint stackup differs." ) );
839 REPORT(
_(
"Pad clearance overridden." ) );
846 REPORT(
_(
"Solder mask expansion overridden." ) );
854 REPORT(
_(
"Solder paste absolute clearance overridden." ) );
861 REPORT(
_(
"Solder paste relative clearance overridden." ) );
868 REPORT(
_(
"Zone connection overridden." ) );
873 _(
"Net tie pad groups differ." ) );
878 _(
"Net tie pad groups differ." ) );
900 dummy.SetParentGroup(
nullptr );
901 dummy.SetParent(
nullptr );
904 item->NormalizeForCompare();
906 std::set<BOARD_ITEM*, FOOTPRINT::cmp_drawings> aShapes;
907 std::copy_if(
dummy.GraphicalItems().begin(),
dummy.GraphicalItems().end(),
908 std::inserter( aShapes, aShapes.begin() ),
911 return item->Type() == PCB_SHAPE_T;
914 std::set<BOARD_ITEM*, FOOTPRINT::cmp_drawings> bShapes;
916 std::inserter( bShapes, bShapes.begin() ),
919 return item->Type() == PCB_SHAPE_T;
922 if( aShapes.size() != bShapes.size() )
925 REPORT(
_(
"Graphic item count differs." ) );
929 for(
auto aIt = aShapes.begin(), bIt = bShapes.begin(); aIt != aShapes.end(); aIt++, bIt++ )
946 std::set<BOARD_ITEM*, FOOTPRINT::cmp_drawings> aBarcodes;
947 std::copy_if(
dummy.GraphicalItems().begin(),
dummy.GraphicalItems().end(),
948 std::inserter( aBarcodes, aBarcodes.begin() ),
951 return item->Type() == PCB_BARCODE_T;
954 std::set<BOARD_ITEM*, FOOTPRINT::cmp_drawings> bBarcodes;
956 std::inserter( bBarcodes, bBarcodes.begin() ),
959 return item->Type() == PCB_BARCODE_T;
962 if( aBarcodes.size() != bBarcodes.size() )
965 REPORT(
_(
"Barcode count differs." ) );
969 for(
auto aIt = aBarcodes.begin(), bIt = bBarcodes.begin(); aIt != aBarcodes.end(); aIt++, bIt++ )
986 std::set<PAD*, FOOTPRINT::cmp_pads> aPads(
Pads().begin(),
Pads().
end() );
987 std::set<PAD*, FOOTPRINT::cmp_pads> bLibPads( aLibFP->
Pads().begin(), aLibFP->
Pads().end() );
989 if( aPads.size() != bLibPads.size() )
992 REPORT(
_(
"Pad count differs." ) );
996 for(
auto aIt = aPads.begin(), bLibIt = bLibPads.begin(); aIt != aPads.end(); aIt++, bLibIt++ )
1007 std::set<ZONE*, FOOTPRINT::cmp_zones> aZones(
Zones().begin(),
Zones().
end() );
1008 std::set<ZONE*, FOOTPRINT::cmp_zones> bZones( aLibFP->
Zones().begin(), aLibFP->
Zones().end() );
1010 if( aZones.size() != bZones.size() )
1013 REPORT(
_(
"Rule area count differs." ) );
1017 for(
auto aIt = aZones.begin(), bIt = bZones.begin(); aIt != aZones.end(); aIt++, bIt++ )
1032 REPORT_AUX(
_(
"No project loaded, skipping library parity tests." ) );
1036 if( !
reportPhase(
_(
"Loading footprint library table..." ) ) )
1039 std::map<LIB_ID, std::shared_ptr<FOOTPRINT>> libFootprintCache;
1044 const int progressDelta = 250;
1046 if( !
reportPhase(
_(
"Checking board footprints against library..." ) ) )
1060 LIB_ID fpID = footprint->GetFPID();
1065 if( libName.IsEmpty() )
1071 if( std::optional<LIBRARY_TABLE_ROW*> optRow = adapter->
GetRow( libName ); optRow )
1072 libTableRow = *optRow;
1079 msg.Printf(
_(
"The current configuration does not include the footprint library '%s'" ),
1081 drcItem->SetErrorMessage( msg );
1082 drcItem->SetItems( footprint );
1088 else if( !adapter->
HasLibrary( libName,
true ) )
1093 msg.Printf(
_(
"The footprint library '%s' is not enabled in the current configuration" ),
1095 drcItem->SetErrorMessage( msg );
1096 drcItem->SetItems( footprint );
1107 msg.Printf(
_(
"The footprint library '%s' was not found at '%s'" ),
1110 drcItem->SetErrorMessage( msg );
1111 drcItem->SetItems( footprint );
1118 auto cacheIt = libFootprintCache.find( fpID );
1119 std::shared_ptr<FOOTPRINT> libFootprint;
1121 if( cacheIt != libFootprintCache.end() )
1123 libFootprint = cacheIt->second;
1129 libFootprint.reset( adapter->
LoadFootprint( libName, fpName,
true ) );
1132 libFootprintCache[ fpID ] = libFootprint;
1144 msg.Printf(
_(
"Footprint '%s' not found in library '%s'" ),
1147 drcItem->SetErrorMessage( msg );
1148 drcItem->SetItems( footprint );
1157 msg.Printf(
_(
"Footprint '%s' does not match copy in library '%s'" ),
1160 drcItem->SetErrorMessage( msg );
1161 drcItem->SetItems( footprint );
constexpr EDA_IU_SCALE pcbIUScale
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
BOARD_ITEM(BOARD_ITEM *aParent, KICAD_T idtype, PCB_LAYER_ID aLayer=F_Cu)
virtual const BOARD * GetBoard() const
Return the BOARD in which this BOARD_ITEM resides, or NULL if none.
FOOTPRINT * GetParentFootprint() const
VECTOR2I GetFPRelativePosition() const
virtual LSET GetLayerSet() const
Return a std::bitset of all layers on which the item physically resides.
virtual bool IsOnCopperLayer() const
Information pertinent to a Pcbnew printed circuit board.
const FOOTPRINTS & Footprints() const
const wxString GetLayerName(PCB_LAYER_ID aLayer) const
Return the name of a aLayer.
PROJECT * GetProject() const
const LSET & GetEnabledLayers() const
A proxy function that calls the corresponding function in m_BoardSettings.
constexpr const Vec GetEnd() const
constexpr BOX2< Vec > & Normalize()
Ensure that the height and width are positive.
constexpr const Vec & GetOrigin() const
static std::shared_ptr< DRC_ITEM > Create(int aErrorCode)
Constructs a DRC_ITEM for the given error code.
virtual ~DRC_TEST_PROVIDER_LIBRARY_PARITY()=default
virtual bool Run() override
Run this provider against the given PCB with configured options (if any).
virtual const wxString GetName() const override
DRC_TEST_PROVIDER_LIBRARY_PARITY()
virtual bool reportPhase(const wxString &aStageName)
void reportViolation(std::shared_ptr< DRC_ITEM > &item, const VECTOR2I &aMarkerPos, int aMarkerLayer, const std::function< void(PCB_MARKER *)> &aPathGenerator=[](PCB_MARKER *){})
virtual bool reportProgress(size_t aCount, size_t aSize, size_t aDelta=1)
const VECTOR2I & GetBezierC2() const
FILL_T GetFillMode() const
SHAPE_POLY_SET & GetPolyShape()
const VECTOR2I & GetEnd() const
Return the ending point of the graphic.
const VECTOR2I & GetStart() const
Return the starting point of the graphic.
wxString SHAPE_T_asString() const
const VECTOR2I & GetBezierC1() const
VECTOR2I GetArcMid() const
Hold an error message and may be used when throwing exceptions containing meaningful error messages.
bool IsLibraryLoaded(const wxString &aNickname)
bool HasLibrary(const wxString &aNickname, bool aCheckEnabled=false) const
Test for the existence of aNickname in the library tables.
std::optional< LIBRARY_TABLE_ROW * > GetRow(const wxString &aNickname, LIBRARY_TABLE_SCOPE aScope=LIBRARY_TABLE_SCOPE::BOTH) const
Like LIBRARY_MANAGER::GetRow but filtered to the LIBRARY_TABLE_TYPE of this adapter.
std::optional< wxString > GetFullURI(LIBRARY_TABLE_TYPE aType, const wxString &aNickname, bool aSubstituted=false) const
Return the full location specifying URI for the LIB, either in original UI form or in environment var...
A logical library item identifier and consists of various portions much like a URI.
const UTF8 & GetLibItemName() const
const UTF8 & GetLibNickname() const
Return the logical library name portion of a LIB_ID.
LSET is a set of PCB_LAYER_IDs.
static LSET AllNonCuMask()
Return a mask holding all layer minus CU layers.
static const LSET & ExternalCuMask()
Return a mask holding the Front and Bottom layers.
static LSET AllCuMask(int aCuLayerCount)
Return a mask holding the requested number of Cu PCB_LAYER_IDs.
static LSET UserDefinedLayersMask(int aUserDefinedLayerCount=MAX_USER_DEFINED_LAYERS)
Return a mask with the requested number of user defined layers.
static LSET AllCuMask()
return AllCuMask( MAX_CU_LAYERS );
bool Contains(PCB_LAYER_ID aLayer) const
See if the layer set contains a PCB layer.
void ForEachUniqueLayer(const std::function< void(PCB_LAYER_ID)> &aMethod) const
Runs the given callable for each active unique copper layer in this padstack, meaning F_Cu for MODE::...
std::vector< PCB_LAYER_ID > UniqueLayers() const
PAD_PROP GetProperty() const
bool GetRemoveUnconnected() const
const std::vector< std::shared_ptr< PCB_SHAPE > > & GetPrimitives(PCB_LAYER_ID aLayer) const
Accessor to the basic shape list for custom-shaped pads.
std::optional< double > GetLocalSolderPasteMarginRatio() const
const VECTOR2I & GetDrillSize() const
PAD_ATTRIB GetAttribute() const
const wxString & GetNumber() const
const VECTOR2I & GetDelta(PCB_LAYER_ID aLayer) const
EDA_ANGLE GetThermalSpokeAngle() const
double GetRoundRectRadiusRatio(PCB_LAYER_ID aLayer) const
PAD_SHAPE GetShape(PCB_LAYER_ID aLayer) const
bool GetKeepTopBottom() const
std::optional< int > GetLocalClearance() const override
Return any local clearances set in the "classic" (ie: pre-rule) system.
const PADSTACK & Padstack() const
const VECTOR2I & GetOffset(PCB_LAYER_ID aLayer) const
PAD_DRILL_SHAPE GetDrillShape() const
int GetChamferPositions(PCB_LAYER_ID aLayer) const
std::optional< int > GetLocalSolderPasteMargin() const
std::optional< int > GetLocalSolderMaskMargin() const
EDA_ANGLE GetFPRelativeOrientation() const
double GetChamferRectRatio(PCB_LAYER_ID aLayer) const
std::optional< int > GetLocalThermalSpokeWidthOverride() const
ZONE_CONNECTION GetLocalZoneConnection() const
CUSTOM_SHAPE_ZONE_MODE GetCustomShapeInZoneOpt() const
int GetThermalGap() const
int GetLocalThermalGapOverride(wxString *aSource) const
int GetPadToDieLength() const
const VECTOR2I & GetSize(PCB_LAYER_ID aLayer) const
VECTOR2I GetPosition() const override
Get the position (center) of the barcode in internal units.
int GetHeight() const
Get the barcode height (in internal units).
BARCODE_ECC_T GetErrorCorrection() const
BARCODE_T GetKind() const
Returns the type of the barcode (QR, CODE_39, etc.).
int GetWidth() const
Get the barcode width (in internal units).
STROKE_PARAMS GetStroke() const override
PCB_LAYER_ID GetLayer() const override
Return the primary layer this item is on.
static FOOTPRINT_LIBRARY_ADAPTER * FootprintLibAdapter(PROJECT *aProject)
Container for project specific data.
A pure virtual class used to derive REPORTER objects from.
virtual REPORTER & Report(const wxString &aText, SEVERITY aSeverity=RPT_SEVERITY_UNDEFINED)
Report a string with a given severity.
int TotalVertices() const
Return total number of vertices stored in the set.
const VECTOR2I & CVertex(int aIndex, int aOutline, int aHole) const
Return the index-th vertex in a given hole outline within a given outline.
Handle a list of polygons defining a copper zone.
bool GetIsRuleArea() const
Accessors to parameters used in Rule Area zones:
std::optional< int > GetLocalClearance() const override
bool GetDoNotAllowVias() const
bool GetDoNotAllowPads() const
bool GetDoNotAllowTracks() const
ISLAND_REMOVAL_MODE GetIslandRemovalMode() const
SHAPE_POLY_SET * Outline()
long long int GetMinIslandArea() const
const wxString & GetZoneName() const
int GetMinThickness() const
ZONE_CONNECTION GetPadConnection() const
int GetHatchThickness() const
double GetHatchHoleMinArea() const
int GetThermalReliefSpokeWidth() const
EDA_ANGLE GetHatchOrientation() const
bool GetDoNotAllowFootprints() const
ZONE_FILL_MODE GetFillMode() const
virtual LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
double GetHatchSmoothingValue() const
bool GetDoNotAllowZoneFills() const
int GetHatchSmoothingLevel() const
unsigned int GetCornerRadius() const
int GetCornerSmoothingType() const
int GetThermalReliefGap() const
unsigned GetAssignedPriority() const
@ DRCE_LIB_FOOTPRINT_ISSUES
@ DRCE_LIB_FOOTPRINT_MISMATCH
UNITS_PROVIDER g_unitsProvider(pcbIUScale, EDA_UNITS::MM)
bool footprintVsBoardStackup(const FOOTPRINT &aFp, const BOARD &aBoard, REPORTER *aReporter)
Report board->footprint stackup differences.
#define TEST_PT(a, b, msg)
bool padNeedsUpdate(const PAD *a, const PAD *bLib, REPORTER *aReporter)
bool primitiveNeedsUpdate(const std::shared_ptr< PCB_SHAPE > &a, const std::shared_ptr< PCB_SHAPE > &b)
static bool boardLayersMatchWithInnerLayerExpansion(const LSET &aItem, const LSET &bLib, bool aAllowCuExpansion)
bool padHasOverrides(const PAD *a, const PAD *b, REPORTER &aReporter)
bool shapeNeedsUpdate(const PCB_SHAPE &curr_shape, const PCB_SHAPE &ref_shape)
bool zoneNeedsUpdate(const ZONE *a, const ZONE *b, REPORTER *aReporter)
bool barcodeNeedsUpdate(const PCB_BARCODE &curr_barcode, const PCB_BARCODE &ref_barcode)
#define TEST_ATTR(a, b, attr, msg)
#define TEST_D(a, b, msg)
bool stackupNeedsUpdate(const FOOTPRINT &a, const FOOTPRINT &b, REPORTER *aReporter)
Compare the stackup related settings of two footprints.
LSET getBoardNormalizedLayerSet(const BOARD_ITEM *aLibItem, const BOARD *aBoard)
@ RECTANGLE
Use RECTANGLE instead of RECT to avoid collision in a Windows header.
wxString LayerName(int aLayer)
Returns the default display name for a given layer.
PCB_LAYER_ID
A quick note on layer IDs:
This file contains miscellaneous commonly used macros and functions.
#define UNIMPLEMENTED_FOR(type)
@ TOP_BOTTOM
Flip top to bottom (around the X axis)
wxString AccumulateNames(const LSEQ &aLayers, const BOARD *aBoard)
Accumulate layer names from a layer set into a comma separated string.
static DRC_REGISTER_TEST_PROVIDER< DRC_TEST_PROVIDER_ANNULAR_WIDTH > dummy
BARCODE class definition.
std::vector< FAB_LAYER_COLOR > dummy
wxString UnescapeString(const wxString &aSource)