From caa18568e002b68d0c96b02be2f7bd6922238d82 Mon Sep 17 00:00:00 2001 From: Seth Hillbrand Date: Thu, 11 Apr 2024 14:59:34 -0700 Subject: [PATCH] Handle DRC rules that limit PTH/NPTH in courtyards Allows custom rules that explicitly allow holes from one footprint to overlap the courtyard from another --- .../drc_test_provider_courtyard_clearance.cpp | 30 +++++++++++++++++-- 1 file changed, 28 insertions(+), 2 deletions(-) diff --git a/pcbnew/drc/drc_test_provider_courtyard_clearance.cpp b/pcbnew/drc/drc_test_provider_courtyard_clearance.cpp index d9239bb78e..49acd73a28 100644 --- a/pcbnew/drc/drc_test_provider_courtyard_clearance.cpp +++ b/pcbnew/drc/drc_test_provider_courtyard_clearance.cpp @@ -283,6 +283,32 @@ bool DRC_TEST_PROVIDER_COURTYARD_CLEARANCE::testCourtyardClearances() // NB: via holes are not checked. There is a presumption that a physical object goes // through a pad hole, which is not the case for via holes. // + bool checkFront = false; + bool checkBack = false; + + constraint = m_drcEngine->EvalRules( COURTYARD_CLEARANCE_CONSTRAINT, fpA, fpB, F_Cu ); + clearance = constraint.GetValue().Min(); + + if( constraint.GetSeverity() != RPT_SEVERITY_IGNORE && clearance >= 0 ) + checkFront = true; + + constraint = m_drcEngine->EvalRules( COURTYARD_CLEARANCE_CONSTRAINT, fpB, fpA, F_Cu ); + clearance = constraint.GetValue().Min(); + + if( constraint.GetSeverity() != RPT_SEVERITY_IGNORE && clearance >= 0 ) + checkFront = true; + + constraint = m_drcEngine->EvalRules( COURTYARD_CLEARANCE_CONSTRAINT, fpA, fpB, B_Cu ); + clearance = constraint.GetValue().Min(); + + if( constraint.GetSeverity() != RPT_SEVERITY_IGNORE && clearance >= 0 ) + checkBack = true; + + constraint = m_drcEngine->EvalRules( COURTYARD_CLEARANCE_CONSTRAINT, fpB, fpA, B_Cu ); + clearance = constraint.GetValue().Min(); + + if( constraint.GetSeverity() != RPT_SEVERITY_IGNORE && clearance >= 0 ) + checkBack = true; auto testPadAgainstCourtyards = [&]( const PAD* pad, const FOOTPRINT* fp ) @@ -305,13 +331,13 @@ bool DRC_TEST_PROVIDER_COURTYARD_CLEARANCE::testCourtyardClearances() const SHAPE_POLY_SET& front = fp->GetCourtyard( F_CrtYd ); const SHAPE_POLY_SET& back = fp->GetCourtyard( B_CrtYd ); - if( front.OutlineCount() > 0 && front.Collide( hole.get(), 0 ) ) + if( checkFront && front.OutlineCount() > 0 && front.Collide( hole.get(), 0 ) ) { std::shared_ptr drce = DRC_ITEM::Create( errorCode ); drce->SetItems( pad, fp ); reportViolation( drce, pad->GetPosition(), F_CrtYd ); } - else if( back.OutlineCount() > 0 && back.Collide( hole.get(), 0 ) ) + else if( checkBack && back.OutlineCount() > 0 && back.Collide( hole.get(), 0 ) ) { std::shared_ptr drce = DRC_ITEM::Create( errorCode ); drce->SetItems( pad, fp );