53 virtual bool Run()
override;
55 virtual const wxString
GetName()
const override
57 return wxT(
"hole_size" );
62 return wxT(
"Tests sizes of drilled holes (via/pad drills)" );
80 for(
PAD*
pad : footprint->Pads() )
109 if( exceedMicro && exceedStd )
132 bool fail_min =
false;
133 bool fail_max =
false;
134 int constraintValue = 0;
139 if( constraint.Value().HasMin() && holeMinor < constraint.Value().Min() )
142 constraintValue = constraint.
Value().
Min();
145 if( constraint.Value().HasMax() && holeMajor > constraint.Value().Max() )
148 constraintValue = constraint.Value().Max();
151 if( fail_min || fail_max )
158 msg =
formatMsg(
_(
"(%s min width %s; actual %s)" ),
159 constraint.GetName(),
165 msg =
formatMsg(
_(
"(%s max width %s; actual %s)" ),
166 constraint.GetName(),
171 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
172 drcItem->SetItems( aPad );
173 drcItem->SetViolatingRule( constraint.GetParentRule() );
184 if(
via->GetViaType() == VIATYPE::MICROVIA )
201 bool fail_min =
false;
202 bool fail_max =
false;
203 int constraintValue = 0;
208 if( constraint.Value().HasMin() &&
via->GetDrillValue() < constraint.Value().Min() )
211 constraintValue = constraint.
Value().
Min();
214 if( constraint.Value().HasMax() &&
via->GetDrillValue() > constraint.Value().Max() )
217 constraintValue = constraint.Value().Max();
220 if( fail_min || fail_max )
227 msg =
formatMsg(
_(
"(%s min width %s; actual %s)" ),
228 constraint.GetName(),
230 via->GetDrillValue() );
234 msg =
formatMsg(
_(
"(%s max width %s; actual %s)" ),
235 constraint.GetName(),
237 via->GetDrillValue() );
240 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
241 drcItem->SetItems(
via );
242 drcItem->SetViolatingRule( constraint.GetParentRule() );
const FOOTPRINTS & Footprints() const
const TRACKS & Tracks() const
MINOPTMAX< int > & Value()
bool IsErrorLimitExceeded(int error_code)
DRC_CONSTRAINT EvalRules(DRC_CONSTRAINT_T aConstraintType, const BOARD_ITEM *a, const BOARD_ITEM *b, PCB_LAYER_ID aLayer, REPORTER *aReporter=nullptr)
static std::shared_ptr< DRC_ITEM > Create(int aErrorCode)
Constructs a DRC_ITEM for the given error code.
void checkPadHole(PAD *aPad)
virtual bool Run() override
Run this provider against the given PCB with configured options (if any).
DRC_TEST_PROVIDER_HOLE_SIZE()
void checkViaHole(PCB_VIA *via, bool aExceedMicro, bool aExceedStd)
virtual const wxString GetName() const override
virtual const wxString GetDescription() const override
virtual ~DRC_TEST_PROVIDER_HOLE_SIZE()
Represent a DRC "provider" which runs some DRC functions over a BOARD and spits out DRC_ITEM and posi...
wxString formatMsg(const wxString &aFormatString, const wxString &aSource, double aConstraint, double aActual)
virtual bool reportPhase(const wxString &aStageName)
virtual void reportViolation(std::shared_ptr< DRC_ITEM > &item, const VECTOR2I &aMarkerPos, int aMarkerLayer)
virtual void reportRuleStatistics()
const VECTOR2I & GetDrillSize() const
VECTOR2I GetPosition() const override
@ DRCE_DRILL_OUT_OF_RANGE
@ DRCE_MICROVIA_DRILL_OUT_OF_RANGE
static DRC_REGISTER_TEST_PROVIDER< DRC_TEST_PROVIDER_ANNULAR_WIDTH > dummy
@ PCB_VIA_T
class PCB_VIA, a via (like a track segment on a copper layer)