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;
128 if( constraint.Value().HasMax() && holeMajor > constraint.Value().Max() )
131 constraintValue = constraint.Value().Max();
143 if( constraint.Value().HasMin() && holeMinor < constraint.Value().Min() )
146 constraintValue = constraint.Value().Min();
158 if( fail_min || fail_max )
161 wxString constraintName = constraint.GetName();
165 if( constraint.GetParentRule() && constraint.GetParentRule()->IsImplicit() )
166 constraintName =
_(
"board setup constraints" );
168 drcItem->SetErrorDetail(
formatMsg(
_(
"(%s min hole %s; actual %s)" ),
175 drcItem->SetErrorDetail(
formatMsg(
_(
"(%s max hole %s; actual %s)" ),
181 drcItem->SetItems( aPad );
182 drcItem->SetViolatingRule( constraint.GetParentRule() );
209 bool fail_min =
false;
210 bool fail_max =
false;
211 int constraintValue = 0;
212 int drill =
via->GetDrillValue();
217 if( constraint.Value().HasMin() && drill < constraint.Value().Min() )
220 constraintValue = constraint.Value().Min();
223 if( constraint.Value().HasMax() && drill > constraint.Value().Max() )
226 constraintValue = constraint.Value().Max();
229 if( fail_min || fail_max )
232 wxString constraintName = constraint.GetName();
236 if( constraint.m_ImplicitMin )
237 constraintName =
_(
"board setup constraints" );
239 drcItem->SetErrorDetail(
formatMsg(
_(
"(%s min hole %s; actual %s)" ),
246 drcItem->SetErrorDetail(
formatMsg(
_(
"(%s max hole %s; actual %s)" ),
252 drcItem->SetItems(
via );
253 drcItem->SetViolatingRule( constraint.GetParentRule() );
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
virtual bool reportPhase(const wxString &aStageName)
void reportTwoPointGeometry(std::shared_ptr< DRC_ITEM > &aDrcItem, const VECTOR2I &aMarkerPos, const VECTOR2I &ptA, const VECTOR2I &ptB, PCB_LAYER_ID aLayer)
wxString formatMsg(const wxString &aFormatString, const wxString &aSource, double aConstraint, double aActual, EDA_DATA_TYPE aDataType=EDA_DATA_TYPE::DISTANCE)
int GetDrillSizeY() const
const VECTOR2I & GetDrillSize() const
VECTOR2I GetPosition() const override
int GetDrillSizeX() const
VECTOR2< T > Resize(T aNewLength) const
Return a vector of the same direction, but length specified in aNewLength.
@ 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)
VECTOR2< int32_t > VECTOR2I