drc_test_provider_library_parity: fix a crash due to a incorrect if()...else() logic.
The incorrect logic allowed execution of the else sequence when it should not be executed.
This commit is contained in:
parent
a533d64417
commit
bc77a1e2dd
|
@ -322,6 +322,8 @@ bool modelsNeedUpdate( const FP_3DMODEL& a, const FP_3DMODEL& b )
|
||||||
|
|
||||||
bool FOOTPRINT::FootprintNeedsUpdate( const FOOTPRINT* aLibFootprint )
|
bool FOOTPRINT::FootprintNeedsUpdate( const FOOTPRINT* aLibFootprint )
|
||||||
{
|
{
|
||||||
|
wxASSERT( aLibFootprint );
|
||||||
|
|
||||||
if( IsFlipped() )
|
if( IsFlipped() )
|
||||||
{
|
{
|
||||||
std::unique_ptr<FOOTPRINT> temp( static_cast<FOOTPRINT*>( Clone() ) );
|
std::unique_ptr<FOOTPRINT> temp( static_cast<FOOTPRINT*>( Clone() ) );
|
||||||
|
@ -444,7 +446,9 @@ bool DRC_TEST_PROVIDER_LIBRARY_PARITY::Run()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
if( !libTableRow && !m_drcEngine->IsErrorLimitExceeded( DRCE_LIB_FOOTPRINT_ISSUES ) )
|
if( !libTableRow )
|
||||||
|
{
|
||||||
|
if( !m_drcEngine->IsErrorLimitExceeded( DRCE_LIB_FOOTPRINT_ISSUES ) )
|
||||||
{
|
{
|
||||||
std::shared_ptr<DRC_ITEM> drcItem = DRC_ITEM::Create( DRCE_LIB_FOOTPRINT_ISSUES );
|
std::shared_ptr<DRC_ITEM> drcItem = DRC_ITEM::Create( DRCE_LIB_FOOTPRINT_ISSUES );
|
||||||
msg.Printf( _( "The current configuration does not include the library '%s'." ),
|
msg.Printf( _( "The current configuration does not include the library '%s'." ),
|
||||||
|
@ -452,11 +456,13 @@ bool DRC_TEST_PROVIDER_LIBRARY_PARITY::Run()
|
||||||
drcItem->SetErrorMessage( msg );
|
drcItem->SetErrorMessage( msg );
|
||||||
drcItem->SetItems( footprint );
|
drcItem->SetItems( footprint );
|
||||||
reportViolation( drcItem, footprint->GetCenter(), UNDEFINED_LAYER );
|
reportViolation( drcItem, footprint->GetCenter(), UNDEFINED_LAYER );
|
||||||
|
}
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else if( !libTable->HasLibrary( libName, true )
|
else if( !libTable->HasLibrary( libName, true ) )
|
||||||
&& !m_drcEngine->IsErrorLimitExceeded( DRCE_LIB_FOOTPRINT_ISSUES ))
|
{
|
||||||
|
if( !m_drcEngine->IsErrorLimitExceeded( DRCE_LIB_FOOTPRINT_ISSUES ) )
|
||||||
{
|
{
|
||||||
std::shared_ptr<DRC_ITEM> drcItem = DRC_ITEM::Create( DRCE_LIB_FOOTPRINT_ISSUES );
|
std::shared_ptr<DRC_ITEM> drcItem = DRC_ITEM::Create( DRCE_LIB_FOOTPRINT_ISSUES );
|
||||||
msg.Printf( _( "The library '%s' is not enabled in the current configuration." ),
|
msg.Printf( _( "The library '%s' is not enabled in the current configuration." ),
|
||||||
|
@ -464,6 +470,7 @@ bool DRC_TEST_PROVIDER_LIBRARY_PARITY::Run()
|
||||||
drcItem->SetErrorMessage( msg );
|
drcItem->SetErrorMessage( msg );
|
||||||
drcItem->SetItems( footprint );
|
drcItem->SetItems( footprint );
|
||||||
reportViolation( drcItem, footprint->GetCenter(), UNDEFINED_LAYER );
|
reportViolation( drcItem, footprint->GetCenter(), UNDEFINED_LAYER );
|
||||||
|
}
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -489,7 +496,9 @@ bool DRC_TEST_PROVIDER_LIBRARY_PARITY::Run()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if( !libFootprint && !m_drcEngine->IsErrorLimitExceeded( DRCE_LIB_FOOTPRINT_ISSUES ) )
|
if( !libFootprint )
|
||||||
|
{
|
||||||
|
if( !m_drcEngine->IsErrorLimitExceeded( DRCE_LIB_FOOTPRINT_ISSUES ) )
|
||||||
{
|
{
|
||||||
std::shared_ptr<DRC_ITEM> drcItem = DRC_ITEM::Create( DRCE_LIB_FOOTPRINT_ISSUES );
|
std::shared_ptr<DRC_ITEM> drcItem = DRC_ITEM::Create( DRCE_LIB_FOOTPRINT_ISSUES );
|
||||||
msg.Printf( "Footprint '%s' not found in library '%s'.",
|
msg.Printf( "Footprint '%s' not found in library '%s'.",
|
||||||
|
@ -499,8 +508,10 @@ bool DRC_TEST_PROVIDER_LIBRARY_PARITY::Run()
|
||||||
drcItem->SetItems( footprint );
|
drcItem->SetItems( footprint );
|
||||||
reportViolation( drcItem, footprint->GetCenter(), UNDEFINED_LAYER );
|
reportViolation( drcItem, footprint->GetCenter(), UNDEFINED_LAYER );
|
||||||
}
|
}
|
||||||
else if( footprint->FootprintNeedsUpdate( libFootprint.get() )
|
}
|
||||||
&& !m_drcEngine->IsErrorLimitExceeded( DRCE_LIB_FOOTPRINT_MISMATCH ))
|
else if( footprint->FootprintNeedsUpdate( libFootprint.get() ) )
|
||||||
|
{
|
||||||
|
if( !m_drcEngine->IsErrorLimitExceeded( DRCE_LIB_FOOTPRINT_MISMATCH ) )
|
||||||
{
|
{
|
||||||
std::shared_ptr<DRC_ITEM> drcItem = DRC_ITEM::Create( DRCE_LIB_FOOTPRINT_MISMATCH );
|
std::shared_ptr<DRC_ITEM> drcItem = DRC_ITEM::Create( DRCE_LIB_FOOTPRINT_MISMATCH );
|
||||||
msg.Printf( "Footprint '%s' does not match copy in library '%s'.",
|
msg.Printf( "Footprint '%s' does not match copy in library '%s'.",
|
||||||
|
@ -511,6 +522,7 @@ bool DRC_TEST_PROVIDER_LIBRARY_PARITY::Run()
|
||||||
reportViolation( drcItem, footprint->GetCenter(), UNDEFINED_LAYER );
|
reportViolation( drcItem, footprint->GetCenter(), UNDEFINED_LAYER );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue