KiCad PCB EDA Suite
Loading...
Searching...
No Matches
drc_re_rtg_diff_pair_panel.cpp
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
25
26#include <wx/log.h>
27
28
29DRC_RE_ROUTING_DIFF_PAIR_PANEL::DRC_RE_ROUTING_DIFF_PAIR_PANEL( wxWindow* aParent, wxString* aConstraintTitle,
30 std::shared_ptr<DRC_RE_ROUTING_DIFF_PAIR_CONSTRAINT_DATA> aConstraintData ) :
31 DRC_RE_ROUTING_DIFF_PAIR_PANEL_BASE( aParent ), m_constraintData( aConstraintData )
32{
34 0,
35 wxALL | wxEXPAND, 10 );
36}
37
38
42
43
45{
47 {
49 wxString::Format( _( "%.2f" ), m_constraintData->GetMaxUncoupledLength() ) );
50
51 m_minWidthTextCtrl->SetValue(
52 wxString::Format( _( "%.2f" ), m_constraintData->GetMinWidth() ) );
53 m_maxWidthTextCtrl->SetValue(
54 wxString::Format( _( "%.2f" ), m_constraintData->GetMaxWidth() ) );
56 wxString::Format( _( "%.2f" ), m_constraintData->GetPreferredWidth() ) );
57
58 m_minGapTextCtrl->SetValue(
59 wxString::Format( _( "%.2f" ), m_constraintData->GetMinGap() ) );
60 m_maxGapTextCtrl->SetValue(
61 wxString::Format( _( "%.2f" ), m_constraintData->GetMaxGap() ) );
62 m_preferredGapTextCtrl->SetValue(
63 wxString::Format( _( "%.2f" ), m_constraintData->GetPreferredGap() ) );
64 }
65
66 return true;
67}
68
69
71{
72 m_constraintData->SetMaxUncoupledLength(
73 std::stod( m_maxUncoupledLengthTextCtrl->GetValue().ToStdString() ) );
74
75 m_constraintData->SetMinWidth( std::stod( m_minWidthTextCtrl->GetValue().ToStdString() ) );
76 m_constraintData->SetMaxWidth( std::stod( m_maxWidthTextCtrl->GetValue().ToStdString() ) );
77 m_constraintData->SetPreferredWidth(
78 std::stod( m_preferredWidthTextCtrl->GetValue().ToStdString() ) );
79
80 m_constraintData->SetMinGap( std::stod( m_minGapTextCtrl->GetValue().ToStdString() ) );
81 m_constraintData->SetMaxGap( std::stod( m_maxGapTextCtrl->GetValue().ToStdString() ) );
82 m_constraintData->SetPreferredGap(
83 std::stod( m_preferredGapTextCtrl->GetValue().ToStdString() ) );
84
85 return true;
86}
87
88
90 std::string* aValidationMessage )
91{
94
95 if( !result.isValid )
96 {
97 *aErrorCount = result.errors.size();
98
99 for( size_t i = 0; i < result.errors.size(); i++ )
100 *aValidationMessage += DRC_RULE_EDITOR_UTILS::FormatErrorMessage( i + 1, result.errors[i] );
101
102 return false;
103 }
104
105 return true;
106}
107
108
110{
111 if( !m_constraintData )
112 return wxEmptyString;
113
114 auto formatDistance = [&]( double aValue )
115 {
116 return formatDouble( aValue ) + wxS( "mm" );
117 };
118
119 wxString widthClause = wxString::Format(
120 wxS( "(constraint track_width (min %s) (opt %s) (max %s))" ),
121 formatDistance( m_constraintData->GetMinWidth() ),
122 formatDistance( m_constraintData->GetPreferredWidth() ),
123 formatDistance( m_constraintData->GetMaxWidth() ) );
124
125 wxString gapClause = wxString::Format(
126 wxS( "(constraint diff_pair_gap (min %s) (opt %s) (max %s))" ),
127 formatDistance( m_constraintData->GetMinGap() ),
128 formatDistance( m_constraintData->GetPreferredGap() ),
129 formatDistance( m_constraintData->GetMaxGap() ) );
130
131 wxString uncoupledClause = wxString::Format(
132 wxS( "(constraint diff_pair_uncoupled (max %s))" ),
133 formatDistance( m_constraintData->GetMaxUncoupledLength() ) );
134
135 wxLogTrace( wxS( "KI_TRACE_DRC_RULE_EDITOR" ), wxS( "Diff pair clauses: %s | %s | %s" ),
136 widthClause, gapClause, uncoupledClause );
137
138 return buildRule( aContext, { widthClause, gapClause, uncoupledClause } );
139}
@ constraint_routing_diff_pair
DRC_RE_ROUTING_DIFF_PAIR_PANEL_BASE(wxWindow *parent, wxWindowID id=wxID_ANY, const wxPoint &pos=wxDefaultPosition, const wxSize &size=wxSize(-1,-1), long style=wxTAB_TRAVERSAL, const wxString &name=wxEmptyString)
std::shared_ptr< DRC_RE_ROUTING_DIFF_PAIR_CONSTRAINT_DATA > m_constraintData
bool ValidateInputs(int *aErrorCount, std::string *aValidationMessage) override
DRC_RE_ROUTING_DIFF_PAIR_PANEL(wxWindow *aParent, wxString *aConstraintTitle, std::shared_ptr< DRC_RE_ROUTING_DIFF_PAIR_CONSTRAINT_DATA > aConstraintData)
wxString GenerateRule(const RULE_GENERATION_CONTEXT &aContext) override
wxString buildRule(const RULE_GENERATION_CONTEXT &aContext, const std::vector< wxString > &aConstraintClauses) const
static wxString formatDouble(double aValue, int aPrecision=6)
wxStaticBitmap * GetConstraintImage(wxPanel *aParent, BITMAPS aBitMap)
static std::string FormatErrorMessage(const int &aErrorCount, const std::string aErrorMessage)
#define _(s)
Result of a validation operation.
wxString result
Test unit parsing edge cases and error handling.