KiCad PCB EDA Suite
Loading...
Searching...
No Matches
drc_re_routing_width_constraint_data.h
Go to the documentation of this file.
1
/*
2
* This program source code file is part of KiCad, a free EDA CAD application.
3
*
4
* Copyright (C) 2024 KiCad Developers, see AUTHORS.txt for contributors.
5
*
6
* This program is free software; you can redistribute it and/or
7
* modify it under the terms of the GNU General Public License
8
* as published by the Free Software Foundation; either version 2
9
* of the License, or (at your option) any later version.
10
*
11
* This program is distributed in the hope that it will be useful,
12
* but WITHOUT ANY WARRANTY; without even the implied warranty of
13
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
* GNU General Public License for more details.
15
*
16
* You should have received a copy of the GNU General Public License
17
* along with this program; if not, you may find one here:
18
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
19
* or you may search the http://www.gnu.org website for the version 2 license,
20
* or you may write to the Free Software Foundation, Inc.,
21
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
22
*/
23
24
#ifndef DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA_H_
25
#define DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA_H_
26
27
#include "
drc_re_base_constraint_data.h
"
28
29
30
class
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA
:
public
DRC_RE_BASE_CONSTRAINT_DATA
31
{
32
public
:
33
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA
() =
default
;
34
35
explicit
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA
(
const
DRC_RE_BASE_CONSTRAINT_DATA
& aBaseData ) :
36
DRC_RE_BASE_CONSTRAINT_DATA
( aBaseData )
37
{
38
}
39
40
explicit
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA
(
int
aId,
int
aParentId, wxString aRuleName,
41
double
aMinRoutingWidth,
42
double
aPreferredRoutingWidth,
43
double
aMaxRoutingWidth ) :
44
DRC_RE_BASE_CONSTRAINT_DATA
( aId, aParentId, aRuleName ),
45
m_minRoutingWidth
( aMinRoutingWidth ),
46
m_preferredRoutingWidth
( aPreferredRoutingWidth ),
m_maxRoutingWidth
( aMaxRoutingWidth )
47
{
48
}
49
50
virtual
~DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA
() =
default
;
51
52
VALIDATION_RESULT
Validate
()
const override
53
{
54
VALIDATION_RESULT
result
;
55
56
// Validate routing width values are positive
57
if
(
m_minRoutingWidth
<= 0 )
58
result
.AddError(
"Minimum Routing Width must be greater than 0"
);
59
60
if
(
m_preferredRoutingWidth
<= 0 )
61
result
.AddError(
"Preferred Routing Width must be greater than 0"
);
62
63
if
(
m_maxRoutingWidth
<= 0 )
64
result
.AddError(
"Maximum Routing Width must be greater than 0"
);
65
66
// Validate min <= preferred <= max
67
if
(
m_minRoutingWidth
>
m_preferredRoutingWidth
)
68
result
.AddError(
"Minimum Routing Width cannot be greater than Preferred Routing Width"
);
69
70
if
(
m_preferredRoutingWidth
>
m_maxRoutingWidth
)
71
result
.AddError(
"Preferred Routing Width cannot be greater than Maximum Routing Width"
);
72
73
if
(
m_minRoutingWidth
>
m_maxRoutingWidth
)
74
result
.AddError(
"Minimum Routing Width cannot be greater than Maximum Routing Width"
);
75
76
return
result
;
77
}
78
79
wxString
GenerateRule
(
const
RULE_GENERATION_CONTEXT
& aContext )
override
80
{
81
auto
formatDistance = [&](
double
aValue )
82
{
83
return
formatDouble
( aValue ) + wxS(
"mm"
);
84
};
85
86
wxString code =
GetConstraintCode
();
87
88
if
( code.IsEmpty() )
89
code = wxS(
"track_width"
);
90
91
wxString clause = wxString::Format(
92
wxS(
"(constraint %s (min %s) (opt %s) (max %s))"
),
93
code,
94
formatDistance(
m_minRoutingWidth
),
95
formatDistance(
m_preferredRoutingWidth
),
96
formatDistance(
m_maxRoutingWidth
) );
97
98
return
buildRule
( aContext, { clause } );
99
}
100
101
double
GetMinRoutingWidth
() {
return
m_minRoutingWidth
; }
102
103
void
SetMinRoutingWidth
(
double
aMinRoutingWidth ) {
m_minRoutingWidth
= aMinRoutingWidth; }
104
105
double
GetPreferredRoutingWidth
() {
return
m_preferredRoutingWidth
; }
106
107
void
SetPreferredRoutingWidth
(
double
aPreferredRoutingWidth )
108
{
109
m_preferredRoutingWidth
= aPreferredRoutingWidth;
110
}
111
112
double
GetMaxRoutingWidth
() {
return
m_maxRoutingWidth
; }
113
114
void
SetMaxRoutingWidth
(
double
aMaxRoutingWidth ) {
m_maxRoutingWidth
= aMaxRoutingWidth; }
115
116
void
CopyFrom
(
const
ICopyable
& aSource )
override
117
{
118
const
auto
& source =
dynamic_cast<
const
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA
&
>
( aSource );
119
120
DRC_RE_BASE_CONSTRAINT_DATA::CopyFrom
( source );
121
122
m_minRoutingWidth
= source.m_minRoutingWidth;
123
m_preferredRoutingWidth
= source.m_preferredRoutingWidth;
124
m_maxRoutingWidth
= source.m_maxRoutingWidth;
125
}
126
127
private
:
128
double
m_minRoutingWidth
{ 0 };
129
double
m_preferredRoutingWidth
{ 0 };
130
double
m_maxRoutingWidth
{ 0 };
131
};
132
133
#endif
// DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA_H_
DRC_RE_BASE_CONSTRAINT_DATA::formatDouble
static wxString formatDouble(double aValue, int aPrecision=6)
Definition
drc_re_base_constraint_data.h:145
DRC_RE_BASE_CONSTRAINT_DATA::GetConstraintCode
wxString GetConstraintCode()
Definition
drc_re_base_constraint_data.h:63
DRC_RE_BASE_CONSTRAINT_DATA::buildRule
wxString buildRule(const RULE_GENERATION_CONTEXT &aContext, const std::vector< wxString > &aConstraintClauses) const
Definition
drc_re_base_constraint_data.h:151
DRC_RE_BASE_CONSTRAINT_DATA::CopyFrom
void CopyFrom(const ICopyable &aSource) override
Definition
drc_re_base_constraint_data.h:79
DRC_RE_BASE_CONSTRAINT_DATA::DRC_RE_BASE_CONSTRAINT_DATA
DRC_RE_BASE_CONSTRAINT_DATA()=default
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::SetMinRoutingWidth
void SetMinRoutingWidth(double aMinRoutingWidth)
Definition
drc_re_routing_width_constraint_data.h:103
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::m_minRoutingWidth
double m_minRoutingWidth
Definition
drc_re_routing_width_constraint_data.h:128
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::GetMinRoutingWidth
double GetMinRoutingWidth()
Definition
drc_re_routing_width_constraint_data.h:101
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA(const DRC_RE_BASE_CONSTRAINT_DATA &aBaseData)
Definition
drc_re_routing_width_constraint_data.h:35
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA(int aId, int aParentId, wxString aRuleName, double aMinRoutingWidth, double aPreferredRoutingWidth, double aMaxRoutingWidth)
Definition
drc_re_routing_width_constraint_data.h:40
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::GenerateRule
wxString GenerateRule(const RULE_GENERATION_CONTEXT &aContext) override
Definition
drc_re_routing_width_constraint_data.h:79
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::GetMaxRoutingWidth
double GetMaxRoutingWidth()
Definition
drc_re_routing_width_constraint_data.h:112
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::m_preferredRoutingWidth
double m_preferredRoutingWidth
Definition
drc_re_routing_width_constraint_data.h:129
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::Validate
VALIDATION_RESULT Validate() const override
Validates the constraint data.
Definition
drc_re_routing_width_constraint_data.h:52
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::m_maxRoutingWidth
double m_maxRoutingWidth
Definition
drc_re_routing_width_constraint_data.h:130
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::CopyFrom
void CopyFrom(const ICopyable &aSource) override
Definition
drc_re_routing_width_constraint_data.h:116
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::~DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA
virtual ~DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA()=default
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::SetMaxRoutingWidth
void SetMaxRoutingWidth(double aMaxRoutingWidth)
Definition
drc_re_routing_width_constraint_data.h:114
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA()=default
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::SetPreferredRoutingWidth
void SetPreferredRoutingWidth(double aPreferredRoutingWidth)
Definition
drc_re_routing_width_constraint_data.h:107
DRC_RE_ROUTING_WIDTH_CONSTRAINT_DATA::GetPreferredRoutingWidth
double GetPreferredRoutingWidth()
Definition
drc_re_routing_width_constraint_data.h:105
ICopyable
Abstract interface class to enable polymorphic copying between objects.
Definition
rule_editor_data_base.h:35
drc_re_base_constraint_data.h
RULE_GENERATION_CONTEXT
Definition
drc_rule_editor_enums.h:59
VALIDATION_RESULT
Result of a validation operation.
Definition
drc_rule_editor_enums.h:37
result
wxString result
Test unit parsing edge cases and error handling.
Definition
test_text_eval_numeric_compat.cpp:602
src
pcbnew
drc
rule_editor
drc_re_routing_width_constraint_data.h
Generated on Sun Feb 1 2026 00:08:31 for KiCad PCB EDA Suite by
1.13.2