Some situations require more than one dummy

Fixes https://gitlab.com/kicad/code/kicad/-/issues/7820
This commit is contained in:
Jon Evans 2021-04-07 21:30:18 -04:00
parent 9432484394
commit 26835f582c
2 changed files with 16 additions and 16 deletions

View File

@ -88,9 +88,9 @@ private:
private: private:
PNS::ROUTER_IFACE* m_routerIface; PNS::ROUTER_IFACE* m_routerIface;
BOARD* m_board; BOARD* m_board;
TRACK m_dummyTrack; TRACK m_dummyTracks[2];
ARC m_dummyArc; ARC m_dummyArcs[2];
VIA m_dummyVia; VIA m_dummyVias[2];
int m_clearanceEpsilon; int m_clearanceEpsilon;
std::map<std::pair<const PNS::ITEM*, const PNS::ITEM*>, int> m_clearanceCache; std::map<std::pair<const PNS::ITEM*, const PNS::ITEM*>, int> m_clearanceCache;
@ -103,9 +103,9 @@ PNS_PCBNEW_RULE_RESOLVER::PNS_PCBNEW_RULE_RESOLVER( BOARD* aBoard,
PNS::ROUTER_IFACE* aRouterIface ) : PNS::ROUTER_IFACE* aRouterIface ) :
m_routerIface( aRouterIface ), m_routerIface( aRouterIface ),
m_board( aBoard ), m_board( aBoard ),
m_dummyTrack( aBoard ), m_dummyTracks{ { aBoard }, { aBoard } },
m_dummyArc( aBoard ), m_dummyArcs{ { aBoard }, { aBoard } },
m_dummyVia( aBoard ) m_dummyVias{ { aBoard }, { aBoard } }
{ {
if( aBoard ) if( aBoard )
m_clearanceEpsilon = aBoard->GetDesignSettings().GetDRCEpsilon(); m_clearanceEpsilon = aBoard->GetDesignSettings().GetDRCEpsilon();
@ -217,10 +217,10 @@ bool PNS_PCBNEW_RULE_RESOLVER::QueryConstraint( PNS::CONSTRAINT_TYPE aType,
{ {
switch( aItemA->Kind() ) switch( aItemA->Kind() )
{ {
case PNS::ITEM::ARC_T: parentA = &m_dummyArc; break; case PNS::ITEM::ARC_T: parentA = &m_dummyArcs[0]; break;
case PNS::ITEM::VIA_T: parentA = &m_dummyVia; break; case PNS::ITEM::VIA_T: parentA = &m_dummyVias[0]; break;
case PNS::ITEM::SEGMENT_T: parentA = &m_dummyTrack; break; case PNS::ITEM::SEGMENT_T: parentA = &m_dummyTracks[0]; break;
case PNS::ITEM::LINE_T: parentA = &m_dummyTrack; break; case PNS::ITEM::LINE_T: parentA = &m_dummyTracks[0]; break;
default: break; default: break;
} }
@ -235,10 +235,10 @@ bool PNS_PCBNEW_RULE_RESOLVER::QueryConstraint( PNS::CONSTRAINT_TYPE aType,
{ {
switch( aItemB->Kind() ) switch( aItemB->Kind() )
{ {
case PNS::ITEM::ARC_T: parentB = &m_dummyArc; break; case PNS::ITEM::ARC_T: parentB = &m_dummyArcs[1]; break;
case PNS::ITEM::VIA_T: parentB = &m_dummyVia; break; case PNS::ITEM::VIA_T: parentB = &m_dummyVias[1]; break;
case PNS::ITEM::SEGMENT_T: parentB = &m_dummyTrack; break; case PNS::ITEM::SEGMENT_T: parentB = &m_dummyTracks[1]; break;
case PNS::ITEM::LINE_T: parentB = &m_dummyTrack; break; case PNS::ITEM::LINE_T: parentB = &m_dummyTracks[1]; break;
default: break; default: break;
} }