KiCad PCB EDA Suite
Loading...
Searching...
No Matches
drc_re_via_style_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_VIA_STYLE_PANEL::DRC_RE_VIA_STYLE_PANEL( wxWindow* aParent, wxString* aConstraintTitle,
30 std::shared_ptr<DRC_RE_VIA_STYLE_CONSTRAINT_DATA> aConstraintData ) :
31 DRC_RE_VIA_STYLE_PANEL_BASE( aParent ), m_constraintData( aConstraintData )
32{
34 wxALL | wxEXPAND, 10 );
35}
36
37
41
42
44{
46 {
48 wxString::Format( _( "%.2f" ), m_constraintData->GetMinViaDiameter() ) );
50 wxString::Format( _( "%.2f" ), m_constraintData->GetMaxViaDiameter() ) );
52 wxString::Format( _( "%.2f" ), m_constraintData->GetPreferredViaDiameter() ) );
53
55 wxString::Format( _( "%.2f" ), m_constraintData->GetMinViaHoleSize() ) );
57 wxString::Format( _( "%.2f" ), m_constraintData->GetMaxViaHoleSize() ) );
59 wxString::Format( _( "%.2f" ), m_constraintData->GetPreferredViaHoleSize() ) );
60 }
61
62 return true;
63}
64
65
67{
68 m_constraintData->SetMinViaDiameter(
69 std::stod( m_minViaDiameterTextCtrl->GetValue().ToStdString() ) );
70 m_constraintData->SetMaxViaDiameter(
71 std::stod( m_maxViaDiameterTextCtrl->GetValue().ToStdString() ) );
72 m_constraintData->SetPreferredViaDiameter(
73 std::stod( m_preferredViaDiameterTextCtrl->GetValue().ToStdString() ) );
74
75 m_constraintData->SetMinViaHoleSize(
76 std::stod( m_minViaHoleSizeTextCtrl->GetValue().ToStdString() ) );
77 m_constraintData->SetMaxViaHoleSize(
78 std::stod( m_maxViaHoleSizeTextCtrl->GetValue().ToStdString() ) );
79 m_constraintData->SetPreferredViaHoleSize(
80 std::stod( m_preferredViaHoleSizeTextCtrl->GetValue().ToStdString() ) );
81
82 return true;
83}
84
85
86bool DRC_RE_VIA_STYLE_PANEL::ValidateInputs( int* aErrorCount, std::string* aValidationMessage )
87{
89
91
92 if( !result.isValid )
93 {
94 *aErrorCount = result.errors.size();
95 for( size_t i = 0; i < result.errors.size(); i++ )
96 *aValidationMessage += DRC_RULE_EDITOR_UTILS::FormatErrorMessage( i + 1, result.errors[i] );
97 return false;
98 }
99
100 return true;
101}
102
103
105{
106 if( !m_constraintData )
107 return wxEmptyString;
108
109 return m_constraintData->GenerateRule( aContext );
110}
@ constraint_via_style
DRC_RE_VIA_STYLE_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)
DRC_RE_VIA_STYLE_PANEL(wxWindow *aParent, wxString *aConstraintTitle, std::shared_ptr< DRC_RE_VIA_STYLE_CONSTRAINT_DATA > aConstraintData)
wxString GenerateRule(const RULE_GENERATION_CONTEXT &aContext) override
bool ValidateInputs(int *aErrorCount, std::string *aValidationMessage) override
std::shared_ptr< DRC_RE_VIA_STYLE_CONSTRAINT_DATA > m_constraintData
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.