41 virtual bool Run()
override;
43 virtual const wxString
GetName()
const override {
return wxT(
"diameter" ); };
51 REPORT_AUX( wxT(
"Via diameter violations ignored. Tests not run." ) );
57 REPORT_AUX( wxT(
"No via diameter constraints found. Tests not run." ) );
64 auto checkViaDiameter =
78 bool fail_min =
false;
79 bool fail_max =
false;
80 int constraintDiameter = 0;
86 if( constraint.Value().HasMin() &&
actual < constraint.Value().Min() )
89 constraintDiameter = constraint.Value().Min();
92 if( constraint.Value().HasMax() &&
actual > constraint.Value().Max() )
95 constraintDiameter = constraint.Value().Max();
99 if( fail_min || fail_max )
102 wxString constraintName = constraint.GetName();
107 if( constraint.m_ImplicitMin )
108 constraintName =
_(
"board setup constraints" );
110 msg =
formatMsg(
_(
"(%s min diameter %s; actual %s)" ),
117 msg =
formatMsg(
_(
"(%s max diameter %s; actual %s)" ),
123 drcItem->SetErrorDetail( msg );
124 drcItem->SetItems( item );
125 drcItem->SetViolatingRule( constraint.GetParentRule() );
133 const int progressDelta = 500;
141 if( !checkViaDiameter( item ) )
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
static std::shared_ptr< DRC_ITEM > Create(int aErrorCode)
Constructs a DRC_ITEM for the given error code.
virtual ~DRC_TEST_PROVIDER_VIA_DIAMETER()=default
virtual bool Run() override
Run this provider against the given PCB with configured options (if any).
virtual const wxString GetName() const override
DRC_TEST_PROVIDER_VIA_DIAMETER()
virtual bool reportPhase(const wxString &aStageName)
void reportViolation(std::shared_ptr< DRC_ITEM > &item, const VECTOR2I &aMarkerPos, int aMarkerLayer, const std::function< void(PCB_MARKER *)> &aPathGenerator=[](PCB_MARKER *){})
wxString formatMsg(const wxString &aFormatString, const wxString &aSource, double aConstraint, double aActual, EDA_DATA_TYPE aDataType=EDA_DATA_TYPE::DISTANCE)
virtual bool reportProgress(size_t aCount, size_t aSize, size_t aDelta=1)
static constexpr PCB_LAYER_ID ALL_LAYERS
! Temporary layer identifier to identify code that is not padstack-aware
@ VIA_DIAMETER_CONSTRAINT
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)