drc_proto: netclass wip

This commit is contained in:
Tomasz Wlostowski 2020-09-05 01:19:01 +02:00
parent 712215fe12
commit fc58c4a20e
5 changed files with 68 additions and 12 deletions

View File

@ -62,3 +62,4 @@ add_subdirectory( pcbnew_tools )
# add_subdirectory( pcb_test_window ) # add_subdirectory( pcb_test_window )
add_subdirectory( gal/gal_pixel_alignment ) add_subdirectory( gal/gal_pixel_alignment )

View File

@ -297,9 +297,25 @@ void test::DRC_ENGINE::inferLegacyRules()
std::vector<NETCLASS_ENTRY> netclassesByClearance, netclassesByWidth; std::vector<NETCLASS_ENTRY> netclassesByClearance, netclassesByWidth;
m_board->SynchronizeNetsAndNetClasses();
// fixme: make this conditional for standalone tests
bds.SetNetClasses( nullptr ); // load legacy
std::vector<NETCLASSPTR> netclasses;
netclasses.push_back( bds.GetNetClasses().GetDefault() );
for( auto netclass : bds.GetNetClasses() )
netclasses.push_back( netclass.second );
ReportAux( wxString::Format( "Importing %d legacy net classes", (int) netclasses.size() ) );
#if 0
for( auto netclass : bds.GetNetClasses() ) for( auto netclass : bds.GetNetClasses() )
{ {
auto className = netclass.second->GetName(); auto className = netclass.second->GetName();
drc_dbg(1,"Process netclass '%s'\n", className );
NETCLASS_ENTRY ent; NETCLASS_ENTRY ent;
ent.name = className; ent.name = className;
ent.clearance = netclass.second->GetClearance(); ent.clearance = netclass.second->GetClearance();
@ -319,12 +335,17 @@ void test::DRC_ENGINE::inferLegacyRules()
{ {
return a.width > b.width; return a.width > b.width;
} ); } );
#endif
#if 0
for( int i = 0; i < netclassesByClearance.size(); i++ ) for( int i = 0; i < netclassesByClearance.size(); i++ )
{ {
wxString className = netclassesByClearance[i].name; #endif
int i = 0;
for( auto &nc : netclasses )
{
wxString className = nc->GetName();
const auto expr = wxString::Format( "A.NetClass == '%s' || B.NetClass == '%s'", className, className ); const auto expr = wxString::Format( "A.NetClass == '%s' || B.NetClass == '%s'", className, className );
@ -336,25 +357,25 @@ void test::DRC_ENGINE::inferLegacyRules()
netclassRule->SetCondition( inNetclassCondition ); netclassRule->SetCondition( inNetclassCondition );
DRC_CONSTRAINT ncClearanceConstraint ( DRC_CONSTRAINT_TYPE_CLEARANCE ); DRC_CONSTRAINT ncClearanceConstraint ( DRC_CONSTRAINT_TYPE_CLEARANCE );
ncClearanceConstraint.Value().SetMin( netclassesByClearance[i].clearance ); ncClearanceConstraint.Value().SetMin( nc->GetClearance() );
netclassRule->AddConstraint( ncClearanceConstraint ); netclassRule->AddConstraint( ncClearanceConstraint );
className = netclassesByWidth[i].name;
netclassRule = createInferredRule( wxString::Format( "inferred-netclass-width-%s", className ), netclassRule = createInferredRule( wxString::Format( "inferred-netclass-width-%s", className ),
{}, priorityRangeMin + i ); {}, priorityRangeMin + i );
netclassRule->SetCondition( inNetclassCondition ); netclassRule->SetCondition( inNetclassCondition );
DRC_CONSTRAINT ncWidthConstraint ( DRC_CONSTRAINT_TYPE_TRACK_WIDTH ); DRC_CONSTRAINT ncWidthConstraint ( DRC_CONSTRAINT_TYPE_TRACK_WIDTH );
ncWidthConstraint.Value().SetMin( netclassesByWidth[i].width ); ncWidthConstraint.Value().SetMin( nc->GetTrackWidth() );
netclassRule->AddConstraint( ncWidthConstraint ); netclassRule->AddConstraint( ncWidthConstraint );
// TODO: should we import diff pair gaps/widths here? // TODO: should we import diff pair gaps/widths here?
i++;
} }
//clearanceConstraint.SetMin( ) //clearanceConstraint.SetMin( )
//rule->AddConstraint( ) //rule->AddConstraint( )

View File

@ -34,6 +34,10 @@
#include <reporter.h> #include <reporter.h>
#include <widgets/progress_reporter.h> #include <widgets/progress_reporter.h>
#include <project.h>
#include <settings/settings_manager.h>
#include <wildcards_and_files_ext.h>
class CONSOLE_LOG class CONSOLE_LOG
{ {
public: public:
@ -154,6 +158,32 @@ private:
CONSOLE_LOG* m_log; CONSOLE_LOG* m_log;
}; };
struct PROJECT_CONTEXT {
PROJECT* project;
std::shared_ptr<BOARD> board;
};
SETTINGS_MANAGER g_settingsManager( true );
PROJECT_CONTEXT loadKicadProject( wxString filename )
{
PROJECT_CONTEXT rv;
wxFileName pro( filename );
wxFileName brdName ( filename );
pro.SetExt( ProjectFileExtension );
brdName.SetExt( KiCadPcbFileExtension );
g_settingsManager.LoadProject( pro.GetFullPath() );
rv.project = &g_settingsManager.Prj();
rv.board.reset( KI_TEST::ReadBoardFromFileOrStream( (const char *) brdName.GetFullPath().c_str() ).release() );
rv.board->SetProject( rv.project );
return rv;
}
int main( int argc, char *argv[] ) int main( int argc, char *argv[] )
{ {
PROPERTY_MANAGER& propMgr = PROPERTY_MANAGER::Instance(); PROPERTY_MANAGER& propMgr = PROPERTY_MANAGER::Instance();
@ -166,9 +196,11 @@ int main( int argc, char *argv[] )
return -1; return -1;
} }
auto brd = KI_TEST::ReadBoardFromFileOrStream( argv[1] ); PROJECT_CONTEXT project = loadKicadProject( argv[1] );
test::DRC_ENGINE drcEngine( brd.get(), &brd->GetDesignSettings() );
test::DRC_ENGINE drcEngine( project.board.get(), &project.board->GetDesignSettings() );
CONSOLE_LOG consoleLog; CONSOLE_LOG consoleLog;

View File

@ -237,7 +237,7 @@ bool test::DRC_TEST_PROVIDER_HOLE_CLEARANCE::doPadToPadHoleDrc( D_PAD* aRefPad,
// drc_dbg(10," chk2 against -> %p ds %d %d\n", pad, pad->GetDrillSize().x, aRefPad->GetDrillSize().x ); // drc_dbg(10," chk2 against -> %p ds %d %d\n", pad, pad->GetDrillSize().x, aRefPad->GetDrillSize().x );
drc_dbg(1," chk1 against -> %p x0 %d x2 %d\n", pad, pad->GetDrillSize().x, aRefPad->GetDrillSize().x ); drc_dbg(10," chk1 against -> %p x0 %d x2 %d\n", pad, pad->GetDrillSize().x, aRefPad->GetDrillSize().x );
// No problem if pads which are on copper layers are on different copper layers, // No problem if pads which are on copper layers are on different copper layers,
// (pads can be only on a technical layer, to build complex pads) // (pads can be only on a technical layer, to build complex pads)
@ -262,7 +262,7 @@ bool test::DRC_TEST_PROVIDER_HOLE_CLEARANCE::doPadToPadHoleDrc( D_PAD* aRefPad,
continue; continue;
} }
drc_dbg(1," chk3 against -> %p x0 %d x2 %d\n", pad, pad->GetDrillSize().x, aRefPad->GetDrillSize().x ); drc_dbg(10," chk3 against -> %p x0 %d x2 %d\n", pad, pad->GetDrillSize().x, aRefPad->GetDrillSize().x );
/* Here, we must test clearance between holes and pads /* Here, we must test clearance between holes and pads
* pad size and shape is adjusted to pad drill size and shape * pad size and shape is adjusted to pad drill size and shape
@ -275,7 +275,7 @@ bool test::DRC_TEST_PROVIDER_HOLE_CLEARANCE::doPadToPadHoleDrc( D_PAD* aRefPad,
auto minClearance = constraint.GetValue().Min(); auto minClearance = constraint.GetValue().Min();
int actual; int actual;
drc_dbg(1,"check pad %p rule '%s' cl %d\n", pad, constraint.GetParentRule()->GetName(), minClearance ); drc_dbg(10,"check pad %p rule '%s' cl %d\n", pad, constraint.GetParentRule()->GetName(), minClearance );
accountCheck( constraint.GetParentRule() ); accountCheck( constraint.GetParentRule() );
@ -310,7 +310,7 @@ bool test::DRC_TEST_PROVIDER_HOLE_CLEARANCE::doPadToPadHoleDrc( D_PAD* aRefPad,
accountCheck( constraint.GetParentRule() ); accountCheck( constraint.GetParentRule() );
drc_dbg(1,"check pad %p rule '%s' cl %d\n", aRefPad, constraint.GetParentRule()->GetName(), minClearance ); drc_dbg(10,"check pad %p rule '%s' cl %d\n", aRefPad, constraint.GetParentRule()->GetName(), minClearance );
auto padShape = pad->GetEffectiveShape(); auto padShape = pad->GetEffectiveShape();
if( padShape->Collide( aRefPad->GetEffectiveHoleShape(), minClearance, &actual ) ) if( padShape->Collide( aRefPad->GetEffectiveHoleShape(), minClearance, &actual ) )

View File

@ -92,6 +92,8 @@ bool test::DRC_TEST_PROVIDER_HOLE_SIZE::Run()
{ {
ReportStage( ( "Testing pad holes" ), 0, 2 ); ReportStage( ( "Testing pad holes" ), 0, 2 );
m_board = m_drcEngine->GetBoard();
for( auto module : m_board->Modules() ) for( auto module : m_board->Modules() )
{ {
for( auto pad : module->Pads() ) for( auto pad : module->Pads() )