drc_engine: Fix via type names

There was a mismatch between the via type names used in the DRC engine
and the via type names defined in the class_track.cpp ENUM_MAP for
VIATYPE.

This fixes the discrepancy; which was breaking microvias altogether as
the route tool also uses the DRC code to determine the correct
diameter/drill (without this patch it was incorrectly using regular
dimensions for microvias.)
This commit is contained in:
David Shah 2020-10-24 13:24:56 +01:00 committed by Jeff Young
parent cc81d97f78
commit 66bcfb3ffc
1 changed files with 4 additions and 4 deletions

View File

@ -160,7 +160,7 @@ void DRC_ENGINE::loadImplicitRules()
DRC_RULE* uViaRule = createImplicitRule( _( "board setup micro-via constraints" ) ); DRC_RULE* uViaRule = createImplicitRule( _( "board setup micro-via constraints" ) );
uViaRule->m_Condition = new DRC_RULE_CONDITION( "A.Via_Type == 'micro_via'" ); uViaRule->m_Condition = new DRC_RULE_CONDITION( "A.Via_Type == 'Micro'" );
DRC_CONSTRAINT uViaDrillConstraint( DRC_CONSTRAINT_TYPE_HOLE_SIZE ); DRC_CONSTRAINT uViaDrillConstraint( DRC_CONSTRAINT_TYPE_HOLE_SIZE );
uViaDrillConstraint.Value().SetMin( bds.m_MicroViasMinDrill ); uViaDrillConstraint.Value().SetMin( bds.m_MicroViasMinDrill );
@ -181,7 +181,7 @@ void DRC_ENGINE::loadImplicitRules()
{ {
DRC_RULE* bbViaRule = createImplicitRule( _( "board setup constraints" ) ); DRC_RULE* bbViaRule = createImplicitRule( _( "board setup constraints" ) );
bbViaRule->m_Condition = new DRC_RULE_CONDITION( "A.Via_Type == 'buried_via'" ); bbViaRule->m_Condition = new DRC_RULE_CONDITION( "A.Via_Type == 'Blind/buried'" );
DRC_CONSTRAINT disallowConstraint( DRC_CONSTRAINT_TYPE_DISALLOW ); DRC_CONSTRAINT disallowConstraint( DRC_CONSTRAINT_TYPE_DISALLOW );
disallowConstraint.m_DisallowFlags = DRC_DISALLOW_BB_VIAS; disallowConstraint.m_DisallowFlags = DRC_DISALLOW_BB_VIAS;
@ -262,7 +262,7 @@ void DRC_ENGINE::loadImplicitRules()
rule->m_Name = wxString::Format( _( "netclass '%s'" ), ncName ); rule->m_Name = wxString::Format( _( "netclass '%s'" ), ncName );
rule->m_Implicit = true; rule->m_Implicit = true;
expr = wxString::Format( "A.NetClass == '%s' && A.Via_Type != 'micro_via'", expr = wxString::Format( "A.NetClass == '%s' && A.Via_Type != 'Micro'",
ncName ); ncName );
rule->m_Condition = new DRC_RULE_CONDITION( expr ); rule->m_Condition = new DRC_RULE_CONDITION( expr );
netclassItemSpecificRules.push_back( rule ); netclassItemSpecificRules.push_back( rule );
@ -290,7 +290,7 @@ void DRC_ENGINE::loadImplicitRules()
rule->m_Name = wxString::Format( _( "netclass '%s'" ), ncName ); rule->m_Name = wxString::Format( _( "netclass '%s'" ), ncName );
rule->m_Implicit = true; rule->m_Implicit = true;
expr = wxString::Format( "A.NetClass == '%s' && A.Via_Type == 'micro_via'", expr = wxString::Format( "A.NetClass == '%s' && A.Via_Type == 'Micro'",
ncName ); ncName );
rule->m_Condition = new DRC_RULE_CONDITION( expr ); rule->m_Condition = new DRC_RULE_CONDITION( expr );
netclassItemSpecificRules.push_back( rule ); netclassItemSpecificRules.push_back( rule );