KiCad PCB EDA Suite
Loading...
Searching...
No Matches
board_design_settings.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) 2009-2019 Jean-Pierre Charras, jp.charras at wanadoo.fr
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
19 */
20
21#pragma once
22
23#include <memory>
24#include <optional>
25#include <vector>
26
28#include <eda_units.h>
29#include <lset.h>
31#include <widgets/ui_common.h>
32#include <zone_settings.h>
34#include <router/pns_meander.h>
35
36
37#define DEFAULT_SILK_LINE_WIDTH 0.1
38#define DEFAULT_COPPER_LINE_WIDTH 0.2
39#define DEFAULT_EDGE_WIDTH 0.05
40#define DEFAULT_COURTYARD_WIDTH 0.05
41#define DEFAULT_LINE_WIDTH 0.10
42
43#define DEFAULT_SILK_TEXT_SIZE 1.0
44#define DEFAULT_COPPER_TEXT_SIZE 1.5
45#define DEFAULT_TEXT_SIZE 1.0
46
47#define DEFAULT_SILK_TEXT_WIDTH 0.1
48#define DEFAULT_COPPER_TEXT_WIDTH 0.30
49#define DEFAULT_TEXT_WIDTH 0.15
50
51#define DEFAULT_DIMENSION_ARROW_LENGTH 50 // mils, for legacy purposes
52#define DEFAULT_DIMENSION_EXTENSION_OFFSET 0.5
53
54// Board thickness, mainly for 3D view:
55#define DEFAULT_BOARD_THICKNESS_MM 1.6
56
57#define DEFAULT_PCB_EDGE_THICKNESS 0.15
58
59// soldermask to pad clearance. The default is 0 because usually board houses
60// create a clearance depending on their fab process: mask material, color, price, etc.
61#define DEFAULT_SOLDERMASK_EXPANSION 0.0
62
63#define DEFAULT_SOLDERMASK_TO_COPPER_CLEARANCE 0.0
64
65#define DEFAULT_SOLDERMASK_MIN_WIDTH 0.0
66
67#define DEFAULT_SOLDERPASTE_CLEARANCE 0.0
68#define DEFAULT_SOLDERPASTE_RATIO 0.0
69
70#define DEFAULT_CUSTOMTRACKWIDTH 0.2
71#define DEFAULT_CUSTOMDPAIRWIDTH 0.125
72#define DEFAULT_CUSTOMDPAIRGAP 0.18
73#define DEFAULT_CUSTOMDPAIRVIAGAP 0.18
74
75#define DEFAULT_MEANDER_SPACING 0.6
76#define DEFAULT_DP_MEANDER_SPACING 1.0
77
78#define DEFAULT_MINCLEARANCE 0.0 // overall min clearance
79#define DEFAULT_MINCONNECTION 0.0 // overall min connection width
80#define DEFAULT_TRACKMINWIDTH 0.2 // track width min value (mm)
81#define DEFAULT_VIASMINSIZE 0.5 // vias (not micro vias) min diameter
82#define DEFAULT_MINTHROUGHDRILL 0.3 // through holes (not micro vias) min drill diameter
83#define DEFAULT_MICROVIASMINSIZE 0.2 // micro vias (not vias) min diameter
84#define DEFAULT_MICROVIASMINDRILL 0.1 // micro vias (not vias) min drill diameter
85#define DEFAULT_HOLETOHOLEMIN 0.25 // minimum web thickness between two drilled holes
86#define DEFAULT_HOLECLEARANCE 0.25 // copper-to-hole clearance (from IPC level A)
87
88#define DEFAULT_COPPEREDGECLEARANCE 0.5 // clearance between copper items and edge cuts
89#define LEGACY_COPPEREDGECLEARANCE -0.01 // A flag to indicate the legacy method (based
90 // on edge cut line thicknesses) should be used.
91#define DEFAULT_SILKCLEARANCE 0.0
92#define DEFAULT_MINGROOVEWIDTH 0.0
93
94#define DEFAULT_MINRESOLVEDSPOKES 2 // Fewer resolved spokes indicates a starved thermal
95
96#define MINIMUM_ERROR_SIZE_MM 0.001 // For arc approximation
97#define MAXIMUM_ERROR_SIZE_MM 0.1 // For arc approximation
98
99class DRC_ENGINE;
100class NET_SETTINGS;
101class NETCLASS;
102
103#define MAXIMUM_CLEARANCE pcbIUScale.mmToIU( 500 ) // to prevent int-overflows
104
105// Min/max values used in dialogs to validate settings
106#define MINIMUM_LINE_WIDTH_MM 0.005 // minimal line width entered in a dialog
107#define MAXIMUM_LINE_WIDTH_MM 100.0 // max line width entered in a dialog
108
109// Default pad properties
110#define DEFAULT_PAD_WIDTH_MM 2.54
111#define DEFAULT_PAD_HEIGTH_MM 1.27
112#define DEFAULT_PAD_DRILL_DIAMETER_MM 0.8
113#define DEFAULT_PAD_RR_RADIUS_RATIO 0.15
114
120{
121 int m_Diameter; // <= 0 means use Netclass via diameter
122 int m_Drill; // <= 0 means use Netclass via drill
123
125 {
126 m_Diameter = 0;
127 m_Drill = 0;
128 }
129
130 VIA_DIMENSION( int aDiameter, int aDrill )
131 {
132 m_Diameter = aDiameter;
133 m_Drill = aDrill;
134 }
135
136 bool operator==( const VIA_DIMENSION& aOther ) const
137 {
138 return ( m_Diameter == aOther.m_Diameter ) && ( m_Drill == aOther.m_Drill );
139 }
140
141 bool operator!=( const VIA_DIMENSION& aOther ) const { return !operator==( aOther ); }
142
143 bool operator<( const VIA_DIMENSION& aOther ) const
144 {
145 if( m_Diameter != aOther.m_Diameter )
146 return m_Diameter < aOther.m_Diameter;
147
148 return m_Drill < aOther.m_Drill;
149 }
150};
151
152
158{
159 int m_Width; // <= 0 means use Netclass differential pair width
160 int m_Gap; // <= 0 means use Netclass differential pair gap
161 int m_ViaGap; // <= 0 means use Netclass differential pair via gap
162
164 {
165 m_Width = 0;
166 m_Gap = 0;
167 m_ViaGap = 0;
168 }
169
170 DIFF_PAIR_DIMENSION( int aWidth, int aGap, int aViaGap )
171 {
172 m_Width = aWidth;
173 m_Gap = aGap;
174 m_ViaGap = aViaGap;
175 }
176
177 bool operator==( const DIFF_PAIR_DIMENSION& aOther ) const
178 {
179 return ( m_Width == aOther.m_Width )
180 && ( m_Gap == aOther.m_Gap )
181 && ( m_ViaGap == aOther.m_ViaGap );
182 }
183
184 bool operator!=( const DIFF_PAIR_DIMENSION& aOther ) const { return !operator==( aOther ); }
185
186 bool operator<( const DIFF_PAIR_DIMENSION& aOther ) const
187 {
188 if( m_Width != aOther.m_Width )
189 return m_Width < aOther.m_Width;
190
191 if( m_Gap != aOther.m_Gap )
192 return m_Gap < aOther.m_Gap;
193
194 return m_ViaGap < aOther.m_ViaGap;
195 }
196};
197
198
199enum
200{
207
209};
210
211
213{
214 wxString m_Text;
217
218 TEXT_ITEM_INFO( const wxString& aText, bool aVisible, PCB_LAYER_ID aLayer )
219 {
220 m_Text = aText;
221 m_Visible = aVisible;
222 m_Layer = aLayer;
223 }
224
225 bool operator==( const TEXT_ITEM_INFO& aOther ) const
226 {
227 return m_Text.IsSameAs( aOther.m_Text )
228 && ( m_Visible == aOther.m_Visible )
229 && ( m_Layer == aOther.m_Layer );
230 }
231};
232
233
234// forward declaration from class_track.h
235enum class VIATYPE : int;
236
237// forward declarations from dimension.h
238enum class DIM_UNITS_FORMAT : int;
239enum class DIM_TEXT_POSITION : int;
240enum class DIM_UNITS_MODE : int;
241enum class DIM_PRECISION : int;
242
243class PAD;
244
249{
250public:
251 BOARD_DESIGN_SETTINGS( JSON_SETTINGS* aParent, const std::string& aPath );
252
253 virtual ~BOARD_DESIGN_SETTINGS();
254
256 {
257 wxString setting_name;
259 };
260
261 bool operator==( const BOARD_DESIGN_SETTINGS& aOther ) const;
262 bool operator!=( const BOARD_DESIGN_SETTINGS& aOther ) const
263 {
264 return !operator==( aOther );
265 }
266
268
270
271 bool LoadFromFile( const wxString& aDirectory = "" ) override;
272
275
280
281 SEVERITY GetSeverity( int aDRCErrorCode );
282
286 bool Ignore( int aDRCErrorCode );
287
293 std::vector<VALIDATION_ERROR> ValidateDesignRules(
294 std::optional<EDA_UNITS> aUnits = std::nullopt ) const;
295
300
301 void SetDefaultZoneSettings( const ZONE_SETTINGS& aSettings )
302 {
303 m_defaultZoneSettings = aSettings;
304 }
305
309 inline const wxString& GetCurrentNetClassName() const
310 {
312 }
313
317 inline bool UseNetClassTrack() const { return ( m_trackWidthIndex <= 0 && !m_useCustomTrackVia ); }
318
322 inline bool UseNetClassVia() const { return ( m_viaSizeIndex <= 0 && !m_useCustomTrackVia ); }
323
327 inline bool UseNetClassDiffPair() const
328 {
329 return ( m_diffPairIndex == 0 && !m_useCustomDiffPair );
330 }
331
335 int GetBiggestClearanceValue() const;
336
340 int GetSmallestClearanceValue() const;
341
345 inline int GetTrackWidthIndex() const { return m_trackWidthIndex; }
346
352 void SetTrackWidthIndex( int aIndex );
353
360 int GetNextTrackWidthIndex( int aIndex, bool aForward ) const;
361
367 int GetCurrentTrackWidth() const;
368
377 inline void SetCustomTrackWidth( int aWidth ) { m_customTrackWidth = aWidth; }
378 inline int GetCustomTrackWidth() const { return m_customTrackWidth; }
379
383 inline int GetViaSizeIndex() const { return m_viaSizeIndex; }
384
390 void SetViaSizeIndex( int aIndex );
391
398 int GetNextViaSizeIndex( int aIndex, bool aForward ) const;
399
405 int GetCurrentViaSize() const;
406
415 inline void SetCustomViaSize( int aSize )
416 {
417 m_customViaSize.m_Diameter = aSize;
418 }
419
423 inline int GetCustomViaSize() const
424 {
425 return m_customViaSize.m_Diameter;
426 }
427
433 int GetCurrentViaDrill() const;
434
443 inline void SetCustomViaDrill( int aDrill )
444 {
445 m_customViaSize.m_Drill = aDrill;
446 }
447
451 inline int GetCustomViaDrill() const
452 {
453 return m_customViaSize.m_Drill;
454 }
455
464 inline void UseCustomTrackViaSize( bool aEnabled )
465 {
466 m_useCustomTrackVia = aEnabled;
467 }
468
472 inline bool UseCustomTrackViaSize() const
473 {
474 return m_useCustomTrackVia;
475 }
476
480 inline int GetDiffPairIndex() const { return m_diffPairIndex; }
481
485 void SetDiffPairIndex( int aIndex );
486
493 int GetNextDiffPairIndex( int aIndex, bool aForward ) const;
494
501 inline void SetCustomDiffPairWidth( int aWidth )
502 {
503 m_customDiffPair.m_Width = aWidth;
504 }
505
510 {
511 return m_customDiffPair.m_Width;
512 }
513
519 inline void SetCustomDiffPairGap( int aGap )
520 {
521 m_customDiffPair.m_Gap = aGap;
522 }
523
529 {
530 return m_customDiffPair.m_Gap;
531 }
532
539 inline void SetCustomDiffPairViaGap( int aGap )
540 {
541 m_customDiffPair.m_ViaGap = aGap;
542 }
543
548 {
549 return m_customDiffPair.m_ViaGap > 0 ? m_customDiffPair.m_ViaGap : m_customDiffPair.m_Gap;
550 }
551
557 inline void UseCustomDiffPairDimensions( bool aEnabled )
558 {
559 m_useCustomDiffPair = aEnabled;
560 }
561
565 inline bool UseCustomDiffPairDimensions() const
566 {
567 return m_useCustomDiffPair;
568 }
569
574 int GetCurrentDiffPairWidth() const;
575
580 int GetCurrentDiffPairGap() const;
581
587 int GetCurrentDiffPairViaGap() const;
588
594 inline const LSET& GetEnabledLayers() const
595 {
596 return m_enabledLayers;
597 }
598
604 void SetEnabledLayers( const LSET& aMask );
605
612 inline bool IsLayerEnabled( PCB_LAYER_ID aLayerId ) const
613 {
614 if( aLayerId >= 0 && aLayerId < PCB_LAYER_ID_COUNT )
615 return m_enabledLayers[aLayerId];
616
617 return false;
618 }
619
623 inline int GetCopperLayerCount() const
624 {
625 return m_copperLayerCount;
626 }
627
633 void SetCopperLayerCount( int aNewLayerCount );
634
638 inline int GetUserDefinedLayerCount() const
639 {
641 }
642
648 void SetUserDefinedLayerCount( int aNewLayerCount );
649
654 inline int GetBoardThickness() const { return m_boardThickness; }
655 inline void SetBoardThickness( int aThickness ) { m_boardThickness = aThickness; }
656
663 int GetDRCEpsilon() const;
664
670 int GetHolePlatingThickness() const;
671
675 int GetLineThickness( PCB_LAYER_ID aLayer ) const;
676
680 VECTOR2I GetTextSize( PCB_LAYER_ID aLayer ) const;
681
685 int GetTextThickness( PCB_LAYER_ID aLayer ) const;
686
687 bool GetTextItalic( PCB_LAYER_ID aLayer ) const;
688 bool GetTextUpright( PCB_LAYER_ID aLayer ) const;
689
690 int GetLayerClass( PCB_LAYER_ID aLayer ) const;
691
692 void SetAuxOrigin( const VECTOR2I& aOrigin ) { m_auxOrigin = aOrigin; }
693 const VECTOR2I& GetAuxOrigin() const { return m_auxOrigin; }
694
695 void SetGridOrigin( const VECTOR2I& aOrigin ) { m_gridOrigin = aOrigin; }
696 const VECTOR2I& GetGridOrigin() const { return m_gridOrigin; }
697
698 void SetDefaultMasterPad();
699
700private:
701 void initFromOther( const BOARD_DESIGN_SETTINGS& aOther );
702
703 bool migrateSchema0to1();
704
705public:
706 // Note: the first value in each dimensions list is the current netclass value
707 std::vector<int> m_TrackWidthList;
708 std::vector<VIA_DIMENSION> m_ViasDimensionsList;
709 std::vector<DIFF_PAIR_DIMENSION> m_DiffPairDimensionsList;
710
717
721
723
724 bool m_UseConnectedTrackWidth; // use width of existing track when creating a new,
725 // connected track
726 bool m_TempOverrideTrackWidth; // use selected track width temporarily even when
727 // using connected track width
728 int m_MinClearance; // overall min
729 int m_MinGrooveWidth; // Minimum groove width for creepage checks
730 int m_MinConn; // overall min connection width
731 int m_TrackMinWidth; // overall min track width
732 int m_ViasMinAnnularWidth; // overall minimum width of the via copper ring
733 int m_ViasMinSize; // overall vias (not micro vias) min diameter
734 int m_MinThroughDrill; // through hole (not micro vias) min drill diameter
735 int m_MicroViasMinSize; // micro vias min diameter
736 int m_MicroViasMinDrill; // micro vias min drill diameter
738 int m_HoleClearance; // Hole to copper clearance
739 int m_HoleToHoleMin; // Min width of web between two drilled holes
740 int m_SilkClearance; // Min dist between two silk items
741 int m_MinResolvedSpokes; // Min spoke count to not be a starved thermal
742 int m_MinSilkTextHeight; // Min text height for silkscreen layers
743 int m_MinSilkTextThickness; // Min text thickness for silkscreen layers
744
745 std::shared_ptr<DRC_ENGINE> m_DRCEngine;
746 std::map<int, SEVERITY> m_DRCSeverities; // Map from DRCErrorCode to SEVERITY
747 std::set<wxString> m_DrcExclusions; // Serialized excluded DRC markers
748 std::map<wxString, wxString> m_DrcExclusionComments; // Map from serialization to comment
749
750 // When smoothing the zone's outline there's the question of external fillets (that is, those
751 // applied to concave corners). While it seems safer to never have copper extend outside the
752 // zone outline, 5.1.x and prior did indeed fill them so we leave the mode available.
754
755 // Maximum error allowed when approximating circles and arcs to segments
757
758 // Global mask margins:
759 int m_SolderMaskExpansion; // Solder mask inflation around the pad or via
760 int m_SolderMaskMinWidth; // Solder mask min width (2 areas closer than this
761 // width are merged)
762 int m_SolderMaskToCopperClearance; // Min distance allowed from copper to a mask
763 // aperture of another net
764
765 int m_SolderPasteMargin; // Solder paste margin absolute value
766 double m_SolderPasteMarginRatio; // Solder mask margin ratio value of pad size
767 // The final margin is the sum of these 2 values
769
770 bool m_TentViasFront; // The default tenting option if not overridden on an
771 bool m_TentViasBack; // individual via
772
773 bool m_CoverViasFront; // The default covering option if not overridden on an
774 bool m_CoverViasBack; // individual via
775
776 bool m_PlugViasFront; // The default plugging option if not overridden on an
777 bool m_PlugViasBack; // individual via
778
779 bool m_CapVias; // The default capping option if not overridden on an
780 // individual via
781
782 bool m_FillVias; // The default filling option if not overridden on ana
783 // individual via
784
785 std::shared_ptr<NET_SETTINGS> m_NetSettings;
786
787 // Variables used in footprint editing (default value in item/footprint creation)
788 std::vector<TEXT_ITEM_INFO> m_DefaultFPTextItems;
789
790 // Map between user layer default names and custom names
791 std::map<std::string, wxString> m_UserLayerNames;
792
793 // Default zone hatching offsets
794 std::map<PCB_LAYER_ID, ZONE_LAYER_PROPERTIES> m_ZoneLayerProperties;
795
796 // Arrays of default values for the various layer classes.
802
803 // Default values for dimension objects
812
818
819 // Miscellaneous
820 std::unique_ptr<PAD> m_Pad_Master; // A dummy pad to store all default parameters
821 // when importing values or creating a new pad
822
823 // Set to true if the board has a stackup management.
824 // If not set a default basic stackup will be used to generate the gbrjob file.
825 // Could be removed later, or at least always set to true
827
830
831private:
834
835 // Indices into the trackWidth, viaSizes and diffPairDimensions lists.
836 // The 0 index is always the current netclass value(s)
840
841 // Custom values for track/via sizes (specified via dialog instead of netclass or lists)
845
846 // Custom values for differential pairs (specified via dialog instead of netclass/lists)
849
853
855
859
867
870};
@ LAYER_CLASS_OTHERS
@ LAYER_CLASS_COUNT
@ LAYER_CLASS_FAB
@ LAYER_CLASS_COURTYARD
@ LAYER_CLASS_SILK
@ LAYER_CLASS_COPPER
@ LAYER_CLASS_EDGES
Container for design settings for a BOARD object.
DIM_PRECISION m_DimensionPrecision
Number of digits after the decimal.
TEARDROP_PARAMETERS_LIST * GetTeadropParamsList()
void UseCustomTrackViaSize(bool aEnabled)
Enables/disables custom track/via size settings.
std::vector< TEXT_ITEM_INFO > m_DefaultFPTextItems
int GetHolePlatingThickness() const
Pad & via drills are finish size.
void SetCustomDiffPairWidth(int aWidth)
Sets custom track width for differential pairs (i.e.
VIATYPE m_CurrentViaType
(VIA_BLIND_BURIED, VIA_THROUGH, VIA_MICROVIA)
int GetCustomDiffPairGap()
Function GetCustomDiffPairGap.
void SetEnabledLayers(const LSET &aMask)
Change the bit-mask of enabled layers to aMask.
std::shared_ptr< NET_SETTINGS > m_NetSettings
bool operator==(const BOARD_DESIGN_SETTINGS &aOther) const
void SetCustomTrackWidth(int aWidth)
Sets custom width for track (i.e.
std::map< wxString, wxString > m_DrcExclusionComments
DIM_UNITS_FORMAT m_DimensionUnitsFormat
void initFromOther(const BOARD_DESIGN_SETTINGS &aOther)
bool GetTextUpright(PCB_LAYER_ID aLayer) const
std::map< int, SEVERITY > m_DRCSeverities
VECTOR2I m_gridOrigin
origin for grid offsets
int GetTextThickness(PCB_LAYER_ID aLayer) const
Return the default text thickness from the layer class for the given layer.
std::map< PCB_LAYER_ID, ZONE_LAYER_PROPERTIES > m_ZoneLayerProperties
void SetGridOrigin(const VECTOR2I &aOrigin)
VECTOR2I m_auxOrigin
origin for plot exports
bool m_TextUpright[LAYER_CLASS_COUNT]
BOARD_DESIGN_SETTINGS(JSON_SETTINGS *aParent, const std::string &aPath)
bool GetTextItalic(PCB_LAYER_ID aLayer) const
int GetNextDiffPairIndex(int aIndex, bool aForward) const
Compute the next diff pair dimensions list index when cycling predefined sizes, skipping the index-0 ...
const wxString & GetCurrentNetClassName() const
wxString m_currentNetClassName
Current net class name used to display netclass info.
void SetViaSizeIndex(int aIndex)
Set the current via size list index to aIndex.
std::shared_ptr< DRC_ENGINE > m_DRCEngine
std::vector< DIFF_PAIR_DIMENSION > m_DiffPairDimensionsList
std::set< wxString > m_DrcExclusions
bool Ignore(int aDRCErrorCode)
Return true if the DRC error code's severity is SEVERITY_IGNORE.
void SetCustomViaSize(int aSize)
Set custom size for via diameter (i.e.
const LSET & GetEnabledLayers() const
Return a bit-mask of all the layers that are enabled.
std::map< std::string, wxString > m_UserLayerNames
const VECTOR2I & GetGridOrigin() const
int GetBoardThickness() const
The full thickness of the board including copper and masks.
std::unique_ptr< PAD > m_Pad_Master
void SetCustomDiffPairGap(int aGap)
Sets custom gap for differential pairs (i.e.
int GetNextTrackWidthIndex(int aIndex, bool aForward) const
Compute the next track width list index when cycling predefined sizes, skipping the index-0 netclass ...
bool IsLayerEnabled(PCB_LAYER_ID aLayerId) const
Test whether a given layer aLayerId is enabled.
TEARDROP_PARAMETERS_LIST m_TeardropParamsList
The parameters of teardrops for the different teardrop targets (via/pad, track end).
void SetUserDefinedLayerCount(int aNewLayerCount)
Set the number of user defined layers to aNewLayerCount.
void SetAuxOrigin(const VECTOR2I &aOrigin)
const VECTOR2I & GetAuxOrigin() const
bool operator!=(const BOARD_DESIGN_SETTINGS &aOther) const
int GetDRCEpsilon() const
Return an epsilon which accounts for rounding errors, etc.
int GetLayerClass(PCB_LAYER_ID aLayer) const
PNS::MEANDER_SETTINGS m_DiffPairMeanderSettings
bool UseNetClassVia() const
Return true if netclass values should be used to obtain appropriate via size.
BOARD_STACKUP & GetStackupDescriptor()
int m_boardThickness
Board thickness for 3D viewer.
int m_copperLayerCount
Number of copper layers for this design.
bool UseNetClassTrack() const
Return true if netclass values should be used to obtain appropriate track width.
int m_userDefinedLayerCount
Number of user defined layers for this design.
bool UseNetClassDiffPair() const
Return true if netclass values should be used to obtain appropriate diff pair dimensions.
void SetCustomViaDrill(int aDrill)
Sets custom size for via drill (i.e.
bool LoadFromFile(const wxString &aDirectory="") override
Loads the backing file from disk and then calls Load()
void SetDefaultZoneSettings(const ZONE_SETTINGS &aSettings)
PNS::MEANDER_SETTINGS m_SingleTrackMeanderSettings
void SetTrackWidthIndex(int aIndex)
Set the current track width list index to aIndex.
int m_TextThickness[LAYER_CLASS_COUNT]
ZONE_SETTINGS m_defaultZoneSettings
The default settings that will be used for new zones.
const BOARD_STACKUP & GetStackupDescriptor() const
void UseCustomDiffPairDimensions(bool aEnabled)
Enables/disables custom differential pair dimensions.
int GetNextViaSizeIndex(int aIndex, bool aForward) const
Compute the next via size list index when cycling predefined sizes, skipping the index-0 netclass pla...
SEVERITY GetSeverity(int aDRCErrorCode)
std::vector< int > m_TrackWidthList
DIFF_PAIR_DIMENSION m_customDiffPair
std::vector< VALIDATION_ERROR > ValidateDesignRules(std::optional< EDA_UNITS > aUnits=std::nullopt) const
Validate design settings values and return per-field errors.
int m_LineThickness[LAYER_CLASS_COUNT]
VECTOR2I GetTextSize(PCB_LAYER_ID aLayer) const
Return the default text size from the layer class for the given layer.
void SetBoardThickness(int aThickness)
int GetLineThickness(PCB_LAYER_ID aLayer) const
Return the default graphic segment thickness from the layer class for the given layer.
ZONE_SETTINGS & GetDefaultZoneSettings()
bool m_UseHeightForLengthCalcs
Enable inclusion of stackup height in track length measurements and length tuning.
VECTOR2I m_TextSize[LAYER_CLASS_COUNT]
PNS::MEANDER_SETTINGS m_SkewMeanderSettings
LSET m_enabledLayers
Bit-mask for layer enabling.
bool m_TextItalic[LAYER_CLASS_COUNT]
void SetCopperLayerCount(int aNewLayerCount)
Set the copper layer count to aNewLayerCount.
DIM_TEXT_POSITION m_DimensionTextPosition
BOARD_STACKUP m_stackup
The description of layers stackup, for board fabrication only physical layers are in layers stackup.
std::vector< VIA_DIMENSION > m_ViasDimensionsList
BOARD_DESIGN_SETTINGS & operator=(const BOARD_DESIGN_SETTINGS &aOther)
void SetCustomDiffPairViaGap(int aGap)
Sets custom via gap for differential pairs (i.e.
Manage layers needed to make a physical board.
Design Rule Checker object that performs all the DRC tests.
Definition drc_engine.h:129
JSON_SETTINGS(const wxString &aFilename, SETTINGS_LOC aLocation, int aSchemaVersion)
LSET is a set of PCB_LAYER_IDs.
Definition lset.h:37
NESTED_SETTINGS(const std::string &aName, int aSchemaVersion, JSON_SETTINGS *aParent, const std::string &aPath, bool aLoadFromFile=true)
A collection of nets and the parameters used to route or test these nets.
Definition netclass.h:38
NET_SETTINGS stores various net-related settings in a project context.
Definition pad.h:61
Dimensions for the meandering algorithm.
Definition pns_meander.h:70
TEARDROP_PARAMETERS_LIST is a helper class to handle the list of TEARDROP_PARAMETERS needed to build ...
ZONE_SETTINGS handles zones parameters.
PCB_LAYER_ID
A quick note on layer IDs:
Definition layer_ids.h:56
@ PCB_LAYER_ID_COUNT
Definition layer_ids.h:167
DIM_TEXT_POSITION
Where to place the text on a dimension.
DIM_UNITS_FORMAT
How to display the units in a dimension's text.
DIM_UNITS_MODE
Used for storing the units selection in the file because EDA_UNITS alone doesn't cut it.
DIM_PRECISION
VIATYPE
SEVERITY
Container to handle a stock of specific differential pairs each with unique track width,...
DIFF_PAIR_DIMENSION(int aWidth, int aGap, int aViaGap)
bool operator<(const DIFF_PAIR_DIMENSION &aOther) const
bool operator==(const DIFF_PAIR_DIMENSION &aOther) const
bool operator!=(const DIFF_PAIR_DIMENSION &aOther) const
TEXT_ITEM_INFO(const wxString &aText, bool aVisible, PCB_LAYER_ID aLayer)
bool operator==(const TEXT_ITEM_INFO &aOther) const
Container to handle a stock of specific vias each with unique diameter and drill sizes in the BOARD c...
bool operator==(const VIA_DIMENSION &aOther) const
VIA_DIMENSION(int aDiameter, int aDrill)
bool operator!=(const VIA_DIMENSION &aOther) const
bool operator<(const VIA_DIMENSION &aOther) const
Functions to provide common constants and other functions to assist in making a consistent UI.
VECTOR2< int32_t > VECTOR2I
Definition vector2d.h:683
Class ZONE_SETTINGS used to handle zones parameters in dialogs.