50 virtual bool Run()
override;
52 virtual const wxString
GetName()
const override {
return wxT(
"hole_size" ); };
69 for(
PAD*
pad : footprint->Pads() )
98 if( exceedMicro && exceedStd )
120 bool fail_min =
false;
121 bool fail_max =
false;
122 int constraintValue = 0;
127 if( constraint.Value().HasMin() && holeMinor < constraint.Value().Min() )
130 constraintValue = constraint.
Value().
Min();
133 if( constraint.Value().HasMax() && holeMajor > constraint.Value().Max() )
136 constraintValue = constraint.Value().Max();
139 if( fail_min || fail_max )
142 wxString constraintName = constraint.GetName();
147 if( constraint.GetParentRule() && constraint.GetParentRule()->m_Implicit )
148 constraintName =
_(
"board setup constraints" );
150 msg =
formatMsg(
_(
"(%s min hole %s; actual %s)" ),
157 msg =
formatMsg(
_(
"(%s max hole %s; actual %s)" ),
163 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
164 drcItem->SetItems( aPad );
165 drcItem->SetViolatingRule( constraint.GetParentRule() );
176 if(
via->GetViaType() == VIATYPE::MICROVIA )
193 bool fail_min =
false;
194 bool fail_max =
false;
195 int constraintValue = 0;
200 if( constraint.Value().HasMin() &&
via->GetDrillValue() < constraint.Value().Min() )
203 constraintValue = constraint.
Value().
Min();
206 if( constraint.Value().HasMax() &&
via->GetDrillValue() > constraint.Value().Max() )
209 constraintValue = constraint.Value().Max();
212 if( fail_min || fail_max )
215 wxString constraintName = constraint.GetName();
220 if( constraint.m_ImplicitMin )
221 constraintName =
_(
"board setup constraints" );
223 msg =
formatMsg(
_(
"(%s min hole %s; actual %s)" ),
226 via->GetDrillValue() );
230 msg =
formatMsg(
_(
"(%s max hole %s; actual %s)" ),
233 via->GetDrillValue() );
236 drcItem->SetErrorMessage( drcItem->GetErrorText() + wxS(
" " ) + msg );
237 drcItem->SetItems(
via );
238 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.
virtual ~DRC_TEST_PROVIDER_HOLE_SIZE()=default
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
Represent a DRC "provider" which runs some DRC functions over a BOARD and spits out DRC_ITEM and posi...
virtual bool reportPhase(const wxString &aStageName)
virtual void reportViolation(std::shared_ptr< DRC_ITEM > &item, const VECTOR2I &aMarkerPos, int aMarkerLayer, DRC_CUSTOM_MARKER_HANDLER *aCustomHandler=nullptr)
wxString formatMsg(const wxString &aFormatString, const wxString &aSource, double aConstraint, double aActual, EDA_DATA_TYPE aDataType=EDA_DATA_TYPE::DISTANCE)
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)