You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							818 lines
						
					
					
						
							26 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							818 lines
						
					
					
						
							26 KiB
						
					
					
				| /* | |
|  * This program source code file is part of KiCad, a free EDA CAD application. | |
|  * | |
|  * Copyright (C) 2009-2015 Jean-Pierre Charras, jp.charras at wanadoo.fr | |
|  * Copyright (C) 1992-2015 KiCad Developers, see CHANGELOG.txt for contributors. | |
|  * | |
|  * This program is free software; you can redistribute it and/or | |
|  * modify it under the terms of the GNU General Public License | |
|  * as published by the Free Software Foundation; either version 2 | |
|  * of the License, or (at your option) any later version. | |
|  * | |
|  * This program is distributed in the hope that it will be useful, | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | |
|  * GNU General Public License for more details. | |
|  * | |
|  * You should have received a copy of the GNU General Public License | |
|  * along with this program; if not, you may find one here: | |
|  * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html | |
|  * or you may search the http://www.gnu.org website for the version 2 license, | |
|  * or you may write to the Free Software Foundation, Inc., | |
|  * 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA | |
|  */ | |
| 
 | |
| #ifndef BOARD_DESIGN_SETTINGS_H_ | |
| #define BOARD_DESIGN_SETTINGS_H_ | |
|  | |
| #include <class_pad.h> | |
| #include <class_track.h> | |
| #include <netclass.h> | |
| #include <config_params.h> | |
|  | |
| #define DEFAULT_SILK_LINE_WIDTH       0.12 | |
| #define DEFAULT_COPPER_LINE_WIDTH     0.20 | |
| #define DEFAULT_EDGE_WIDTH            0.05 | |
| #define DEFAULT_COURTYARD_WIDTH       0.05 | |
| #define DEFAULT_LINE_WIDTH            0.10 | |
|  | |
| #define DEFAULT_SILK_TEXT_SIZE        1.0 | |
| #define DEFAULT_COPPER_TEXT_SIZE      1.5 | |
| #define DEFAULT_TEXT_SIZE             1.0 | |
|  | |
| #define DEFAULT_SILK_TEXT_WIDTH       0.15 | |
| #define DEFAULT_COPPER_TEXT_WIDTH     0.30 | |
| #define DEFAULT_TEXT_WIDTH            0.15 | |
|  | |
| // Board thickness, mainly for 3D view: | |
| #define DEFAULT_BOARD_THICKNESS_MM    1.6 | |
|  | |
| #define DEFAULT_PCB_EDGE_THICKNESS    0.15 | |
|  | |
| #define DEFAULT_SOLDERMASK_CLEARANCE  0.051  // soldermask to pad clearance | |
| #define DEFAULT_SOLDERMASK_MIN_WIDTH  0.25   // soldermask minimum dam size | |
| #define DEFAULT_SOLDERPASTE_CLEARANCE 0.0 | |
| #define DEFAULT_SOLDERPASTE_RATIO     0.0 | |
|  | |
| #define DEFAULT_CUSTOMTRACKWIDTH      0.2 | |
| #define DEFAULT_CUSTOMDPAIRWIDTH      0.125 | |
| #define DEFAULT_CUSTOMDPAIRGAP        0.18 | |
| #define DEFAULT_CUSTOMDPAIRVIAGAP     0.18 | |
|  | |
| #define DEFAULT_TRACKMINWIDTH         0.2     // track width min value | |
| #define DEFAULT_VIASMINSIZE           0.4     // vias (not micro vias) min diameter | |
| #define DEFAULT_VIASMINDRILL          0.3     // vias (not micro vias) min drill diameter | |
| #define DEFAULT_MICROVIASMINSIZE      0.2     // micro vias (not vias) min diameter | |
| #define DEFAULT_MICROVIASMINDRILL     0.1     // micro vias (not vias) min drill diameter | |
| #define DEFAULT_HOLETOHOLEMIN         0.25    // separation between drilled hole edges | |
|  | |
| /** | |
|  * Struct VIA_DIMENSION | |
|  * is a small helper container to handle a stock of specific vias each with | |
|  * unique diameter and drill sizes in the BOARD class. | |
|  */ | |
| struct VIA_DIMENSION | |
| { | |
|     int m_Diameter;     // <= 0 means use Netclass via diameter | |
|     int m_Drill;        // <= 0 means use Netclass via drill | |
|  | |
|     VIA_DIMENSION() | |
|     { | |
|         m_Diameter = 0; | |
|         m_Drill    = 0; | |
|     } | |
| 
 | |
|     VIA_DIMENSION( int aDiameter, int aDrill ) | |
|     { | |
|         m_Diameter = aDiameter; | |
|         m_Drill    = aDrill; | |
|     } | |
| 
 | |
|     bool operator==( const VIA_DIMENSION& aOther ) const | |
|     { | |
|         return ( m_Diameter == aOther.m_Diameter ) && ( m_Drill == aOther.m_Drill ); | |
|     } | |
| 
 | |
|     bool operator<( const VIA_DIMENSION& aOther ) const | |
|     { | |
|         if( m_Diameter != aOther.m_Diameter ) | |
|             return m_Diameter < aOther.m_Diameter; | |
| 
 | |
|         return m_Drill < aOther.m_Drill; | |
|     } | |
| }; | |
| 
 | |
| 
 | |
| /** | |
|  * Struct DIFF_PAIR_DIMENSION | |
|  * is a small helper container to handle a stock of specific differential pairs each with | |
|  * unique track width, gap and via gap. | |
|  */ | |
| struct DIFF_PAIR_DIMENSION | |
| { | |
|     int m_Width;         // <= 0 means use Netclass differential pair width | |
|     int m_Gap;           // <= 0 means use Netclass differential pair gap | |
|     int m_ViaGap;        // <= 0 means use Netclass differential pair via gap | |
|  | |
|     DIFF_PAIR_DIMENSION() | |
|     { | |
|         m_Width  = 0; | |
|         m_Gap    = 0; | |
|         m_ViaGap = 0; | |
|     } | |
| 
 | |
|     DIFF_PAIR_DIMENSION( int aWidth, int aGap, int aViaGap ) | |
|     { | |
|         m_Width  = aWidth; | |
|         m_Gap    = aGap; | |
|         m_ViaGap = aViaGap; | |
|     } | |
| 
 | |
|     bool operator==( const DIFF_PAIR_DIMENSION& aOther ) const | |
|     { | |
|         return ( m_Width == aOther.m_Width ) | |
|                 && ( m_Gap == aOther.m_Gap ) | |
|                 && ( m_ViaGap == aOther.m_ViaGap ); | |
|     } | |
| 
 | |
|     bool operator<( const DIFF_PAIR_DIMENSION& aOther ) const | |
|     { | |
|         if( m_Width != aOther.m_Width ) | |
|             return m_Width < aOther.m_Width; | |
| 
 | |
|         if( m_Gap != aOther.m_Gap ) | |
|             return m_Gap < aOther.m_Gap; | |
| 
 | |
|         return m_ViaGap < aOther.m_ViaGap; | |
|     } | |
| }; | |
| 
 | |
| 
 | |
| enum | |
| { | |
|     LAYER_CLASS_SILK = 0, | |
|     LAYER_CLASS_COPPER, | |
|     LAYER_CLASS_EDGES, | |
|     LAYER_CLASS_COURTYARD, | |
|     LAYER_CLASS_OTHERS, | |
| 
 | |
|     LAYER_CLASS_COUNT | |
| }; | |
| 
 | |
| 
 | |
| /** | |
|  * Class BOARD_DESIGN_SETTINGS | |
|  * contains design settings for a BOARD object. | |
|  */ | |
| class BOARD_DESIGN_SETTINGS | |
| { | |
| public: | |
|     // Note: the first value in each dimensions list is the current netclass value | |
|     std::vector<int>                 m_TrackWidthList; | |
|     std::vector<VIA_DIMENSION>       m_ViasDimensionsList; | |
|     std::vector<DIFF_PAIR_DIMENSION> m_DiffPairDimensionsList; | |
| 
 | |
|     // List of netclasses. There is always the default netclass. | |
|     NETCLASSES m_NetClasses; | |
| 
 | |
|     bool       m_MicroViasAllowed;          ///< true to allow micro vias | |
|     bool       m_BlindBuriedViaAllowed;     ///< true to allow blind/buried vias | |
|     VIATYPE_T  m_CurrentViaType;            ///< (VIA_BLIND_BURIED, VIA_THROUGH, VIA_MICROVIA) | |
|  | |
|     bool       m_RequireCourtyards;         ///< require courtyard definitions in footprints | |
|     bool       m_ProhibitOverlappingCourtyards;  ///< check for overlapping courtyards in DRC | |
|  | |
|     // if true, when creating a new track starting on an existing track, use this track width | |
|     bool       m_UseConnectedTrackWidth; | |
|     int        m_TrackMinWidth;             ///< track min value for width ((min copper size value | |
|     int        m_ViasMinSize;               ///< vias (not micro vias) min diameter | |
|     int        m_ViasMinDrill;              ///< vias (not micro vias) min drill diameter | |
|     int        m_MicroViasMinSize;          ///< micro vias (not vias) min diameter | |
|     int        m_MicroViasMinDrill;         ///< micro vias (not vias) min drill diameter | |
|  | |
|     // Global mask margins: | |
|     int        m_SolderMaskMargin;          ///< Solder mask margin | |
|     int        m_SolderMaskMinWidth;        ///< Solder mask min width | |
|                                             // 2 areas near than m_SolderMaskMinWidth | |
|                                             // are merged | |
|     int        m_SolderPasteMargin;         ///< Solder paste margin absolute value | |
|     double     m_SolderPasteMarginRatio;    ///< Solder pask margin ratio value of pad size | |
|                                             ///< The final margin is the sum of these 2 values | |
|  | |
|     int        m_HoleToHoleMin;             ///< Min width of peninsula between two drilled holes | |
|  | |
|     // Arrays of default values for the various layer classes. | |
|     int        m_LineThickness[ LAYER_CLASS_COUNT ]; | |
|     wxSize     m_TextSize[ LAYER_CLASS_COUNT ]; | |
|     int        m_TextThickness[ LAYER_CLASS_COUNT ]; | |
|     bool       m_TextItalic[ LAYER_CLASS_COUNT ]; | |
|     bool       m_TextUpright[ LAYER_CLASS_COUNT ]; | |
| 
 | |
|     // Variables used in footprint editing (default value in item/footprint creation) | |
|  | |
|     wxString   m_RefDefaultText;            ///< Default ref text on fp creation | |
|                                             // if empty, use footprint name as default | |
|     bool       m_RefDefaultVisibility;      ///< Default ref text visibility on fp creation | |
|     int        m_RefDefaultlayer;           ///< Default ref text layer on fp creation | |
|                                             // should be a PCB_LAYER_ID, but use an int | |
|                                             // to save this param in config | |
|  | |
|     wxString   m_ValueDefaultText;          ///< Default value text on fp creation | |
|                                             // if empty, use footprint name as default | |
|     bool       m_ValueDefaultVisibility;    ///< Default value text visibility on fp creation | |
|     int        m_ValueDefaultlayer;         ///< Default value text layer on fp creation | |
|                                             // should be a PCB_LAYER_ID, but use an int | |
|                                             // to save this param in config | |
|  | |
|     // Miscellaneous | |
|     wxPoint    m_AuxOrigin;                 ///< origin for plot exports | |
|     wxPoint    m_GridOrigin;                ///< origin for grid offsets | |
|  | |
|     D_PAD      m_Pad_Master;                ///< A dummy pad to store all default parameters | |
|                                             // when importing values or create a new pad | |
|  | |
| private: | |
|     // Indicies into the trackWidth, viaSizes and diffPairDimensions lists. | |
|     // The 0 index is always the current netclass value(s) | |
|     unsigned   m_trackWidthIndex; | |
|     unsigned   m_viaSizeIndex; | |
|     unsigned   m_diffPairIndex; | |
| 
 | |
|     // Custom values for track/via sizes (specified via dialog instead of netclass or lists) | |
|     bool       m_useCustomTrackVia; | |
|     int        m_customTrackWidth; | |
|     VIA_DIMENSION m_customViaSize; | |
| 
 | |
|     // Custom values for differential pairs (specified via dialog instead of netclass/lists) | |
|     bool       m_useCustomDiffPair; | |
|     DIFF_PAIR_DIMENSION m_customDiffPair; | |
| 
 | |
|     int        m_copperLayerCount; ///< Number of copper layers for this design | |
|  | |
|     LSET       m_enabledLayers;    ///< Bit-mask for layer enabling | |
|     LSET       m_visibleLayers;    ///< Bit-mask for layer visibility | |
|  | |
|     int        m_visibleElements;  ///< Bit-mask for element category visibility | |
|     int        m_boardThickness;   ///< Board thickness for 3D viewer | |
|  | |
|     /// Current net class name used to display netclass info. | |
|     /// This is also the last used netclass after starting a track. | |
|     wxString   m_currentNetClassName; | |
| 
 | |
| public: | |
|     BOARD_DESIGN_SETTINGS(); | |
| 
 | |
|     /** | |
|      * Function GetDefault | |
|      * @return the default netclass. | |
|      */ | |
|     inline NETCLASSPTR GetDefault() const | |
|     { | |
|         return m_NetClasses.GetDefault(); | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCurrentNetClassName | |
|      * @return the current net class name. | |
|      */ | |
|     inline const wxString& GetCurrentNetClassName() const | |
|     { | |
|         return m_currentNetClassName; | |
|     } | |
| 
 | |
|     /** | |
|      * Function UseNetClassTrack | |
|      * returns true if netclass values should be used to obtain appropriate track width. | |
|      */ | |
|     inline bool UseNetClassTrack() const | |
|     { | |
|         return ( m_trackWidthIndex == 0 && !m_useCustomTrackVia ); | |
|     } | |
| 
 | |
|     /** | |
|      * Function UseNetClassVia | |
|      * returns true if netclass values should be used to obtain appropriate via size. | |
|      */ | |
|     inline bool UseNetClassVia() const | |
|     { | |
|         return ( m_viaSizeIndex == 0 && !m_useCustomTrackVia ); | |
|     } | |
| 
 | |
|     /** | |
|      * Function UseNetClassDiffPair | |
|      * returns true if netclass values should be used to obtain appropriate diff pair dimensions. | |
|      */ | |
|     inline bool UseNetClassDiffPair() const | |
|     { | |
|         return ( m_diffPairIndex == 0 && !m_useCustomDiffPair ); | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetCurrentNetClass | |
|      * Must be called after a netclass selection (or after a netclass parameter change | |
|      * Initialize vias and tracks values displayed in comb boxes of the auxiliary toolbar | |
|      * and some others parameters (netclass name ....) | |
|      * @param aNetClassName = the new netclass name | |
|      * @return true if lists of tracks and vias sizes are modified | |
|      */ | |
|     bool SetCurrentNetClass( const wxString& aNetClassName ); | |
| 
 | |
|     /** | |
|      * Function GetBiggestClearanceValue | |
|      * @return the biggest clearance value found in NetClasses list | |
|      */ | |
|     int GetBiggestClearanceValue(); | |
| 
 | |
|     /** | |
|      * Function GetSmallestClearanceValue | |
|      * @return the smallest clearance value found in NetClasses list | |
|      */ | |
|     int GetSmallestClearanceValue(); | |
| 
 | |
|     /** | |
|      * Function GetCurrentMicroViaSize | |
|      * @return the current micro via size, | |
|      * that is the current netclass value | |
|      */ | |
|     int GetCurrentMicroViaSize(); | |
| 
 | |
|     /** | |
|      * Function GetCurrentMicroViaDrill | |
|      * @return the current micro via drill, | |
|      * that is the current netclass value | |
|      */ | |
|     int GetCurrentMicroViaDrill(); | |
| 
 | |
|     /** | |
|      * Function GetTrackWidthIndex | |
|      * @return the current track width list index. | |
|      */ | |
|     inline unsigned GetTrackWidthIndex() const { return m_trackWidthIndex; } | |
| 
 | |
|     /** | |
|      * Function SetTrackWidthIndex | |
|      * sets the current track width list index to \a aIndex. | |
|      * | |
|      * @param aIndex is the track width list index. | |
|      */ | |
|     void SetTrackWidthIndex( unsigned aIndex ); | |
| 
 | |
|     /** | |
|      * Function GetCurrentTrackWidth | |
|      * @return the current track width, according to the selected options | |
|      * ( using the default netclass value or a preset/custom value ) | |
|      * the default netclass is always in m_TrackWidthList[0] | |
|      */ | |
|     inline int GetCurrentTrackWidth() const | |
|     { | |
|         return m_useCustomTrackVia ? m_customTrackWidth : m_TrackWidthList[m_trackWidthIndex]; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetCustomTrackWidth | |
|      * Sets custom width for track (i.e. not available in netclasses or preset list). To have | |
|      * it returned with GetCurrentTrackWidth() you need to enable custom track & via sizes | |
|      * (UseCustomTrackViaSize()). | |
|      * @param aWidth is the new track width. | |
|      */ | |
|     inline void SetCustomTrackWidth( int aWidth ) | |
|     { | |
|         m_customTrackWidth = aWidth; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCustomTrackWidth | |
|      * @return Current custom width for a track. | |
|      */ | |
|     inline int GetCustomTrackWidth() const | |
|     { | |
|         return m_customTrackWidth; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetViaSizeIndex | |
|      * @return the current via size list index. | |
|      */ | |
|     inline unsigned GetViaSizeIndex() const | |
|     { | |
|         return m_viaSizeIndex; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetViaSizeIndex | |
|      * sets the current via size list index to \a aIndex. | |
|      * | |
|      * @param aIndex is the via size list index. | |
|      */ | |
|     void SetViaSizeIndex( unsigned aIndex ); | |
| 
 | |
|     /** | |
|      * Function GetCurrentViaSize | |
|      * @return the current via size, according to the selected options | |
|      * ( using the default netclass value or a preset/custom value ) | |
|      * the default netclass is always in m_TrackWidthList[0] | |
|      */ | |
|     inline int GetCurrentViaSize() const | |
|     { | |
|         if( m_useCustomTrackVia ) | |
|             return m_customViaSize.m_Diameter; | |
|         else | |
|             return m_ViasDimensionsList[m_viaSizeIndex].m_Diameter; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetCustomViaSize | |
|      * Sets custom size for via diameter (i.e. not available in netclasses or preset list). To have | |
|      * it returned with GetCurrentViaSize() you need to enable custom track & via sizes | |
|      * (UseCustomTrackViaSize()). | |
|      * @param aSize is the new drill diameter. | |
|      */ | |
|     inline void SetCustomViaSize( int aSize ) | |
|     { | |
|         m_customViaSize.m_Diameter = aSize; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCustomViaSize | |
|      * @return Current custom size for the via diameter. | |
|      */ | |
|     inline int GetCustomViaSize() const | |
|     { | |
|         return m_customViaSize.m_Diameter; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCurrentViaDrill | |
|      * @return the current via size, according to the selected options | |
|      * ( using the default netclass value or a preset/custom value ) | |
|      * the default netclass is always in m_TrackWidthList[0] | |
|      */ | |
|     int GetCurrentViaDrill() const; | |
| 
 | |
|     /** | |
|      * Function SetCustomViaDrill | |
|      * Sets custom size for via drill (i.e. not available in netclasses or preset list). To have | |
|      * it returned with GetCurrentViaDrill() you need to enable custom track & via sizes | |
|      * (UseCustomTrackViaSize()). | |
|      * @param aDrill is the new drill size. | |
|      */ | |
|     inline void SetCustomViaDrill( int aDrill ) | |
|     { | |
|         m_customViaSize.m_Drill = aDrill; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCustomViaDrill | |
|      * @return Current custom size for the via drill. | |
|      */ | |
|     inline int GetCustomViaDrill() const | |
|     { | |
|         return m_customViaSize.m_Drill; | |
|     } | |
| 
 | |
|     /** | |
|      * Function UseCustomTrackViaSize | |
|      * Enables/disables custom track/via size settings. If enabled, values set with | |
|      * SetCustomTrackWidth()/SetCustomViaSize()/SetCustomViaDrill() are used for newly created | |
|      * tracks and vias. | |
|      * @param aEnabled decides if custom settings should be used for new tracks/vias. | |
|      */ | |
|     inline void UseCustomTrackViaSize( bool aEnabled ) | |
|     { | |
|         m_useCustomTrackVia = aEnabled; | |
|     } | |
| 
 | |
|     /** | |
|      * Function UseCustomTrackViaSize | |
|      * @return True if custom sizes of tracks & vias are enabled, false otherwise. | |
|      */ | |
|     inline bool UseCustomTrackViaSize() const | |
|     { | |
|         return m_useCustomTrackVia; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetDiffPairIndex | |
|      * @return the current diff pair dimension list index. | |
|      */ | |
|     inline unsigned GetDiffPairIndex() const { return m_diffPairIndex; } | |
| 
 | |
|     /** | |
|      * Function SetDiffPairIndex | |
|      * @param aIndex is the diff pair dimensions list index to set. | |
|      */ | |
|     void SetDiffPairIndex( unsigned aIndex ); | |
| 
 | |
|     /** | |
|      * Function SetCustomDiffPairWidth | |
|      * Sets custom track width for differential pairs (i.e. not available in netclasses or | |
|      * preset list). | |
|      * @param aDrill is the new track wdith. | |
|      */ | |
|     inline void SetCustomDiffPairWidth( int aWidth ) | |
|     { | |
|         m_customDiffPair.m_Width = aWidth; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCustomDiffPairWidth | |
|      * @return Current custom track width for differential pairs. | |
|      */ | |
|     inline int GetCustomDiffPairWidth() | |
|     { | |
|         return m_customDiffPair.m_Width; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetCustomDiffPairGap | |
|      * Sets custom gap for differential pairs (i.e. not available in netclasses or preset | |
|      * list). | |
|      * @param aGap is the new gap. | |
|      */ | |
|     inline void SetCustomDiffPairGap( int aGap ) | |
|     { | |
|         m_customDiffPair.m_Gap = aGap; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCustomDiffPairGap | |
|      * @return Current custom gap width for differential pairs. | |
|      */ | |
|     inline int GetCustomDiffPairGap() | |
|     { | |
|         return m_customDiffPair.m_Gap; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetCustomDiffPairViaGap | |
|      * Sets custom via gap for differential pairs (i.e. not available in netclasses or | |
|      * preset list). | |
|      * @param aGap is the new gap.  Specify 0 to use the DiffPairGap for vias as well. | |
|      */ | |
|     inline void SetCustomDiffPairViaGap( int aGap ) | |
|     { | |
|         m_customDiffPair.m_ViaGap = aGap; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCustomDiffPairViaGap | |
|      * @return Current custom via gap width for differential pairs. | |
|      */ | |
|     inline int GetCustomDiffPairViaGap() | |
|     { | |
|         return m_customDiffPair.m_ViaGap > 0 ? m_customDiffPair.m_ViaGap : m_customDiffPair.m_Gap; | |
|     } | |
| 
 | |
|     /** | |
|      * Function UseCustomDiffPairDimensions | |
|      * Enables/disables custom differential pair dimensions. | |
|      * @param aEnabled decides if custom settings should be used for new differential pairs. | |
|      */ | |
|     inline void UseCustomDiffPairDimensions( bool aEnabled ) | |
|     { | |
|         m_useCustomDiffPair = aEnabled; | |
|     } | |
| 
 | |
|     /** | |
|      * Function UseCustomDiffPairDimensions | |
|      * @return True if custom sizes of diff pairs are enabled, false otherwise. | |
|      */ | |
|     inline bool UseCustomDiffPairDimensions() const | |
|     { | |
|         return m_useCustomDiffPair; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCurrentDiffPairWidth | |
|      * @return the current diff pair track width, according to the selected options | |
|      * ( using the default netclass value or a preset/custom value ) | |
|      * the default netclass is always in m_DiffPairDimensionsList[0] | |
|      */ | |
|     inline int GetCurrentDiffPairWidth() const | |
|     { | |
|         if( m_useCustomDiffPair ) | |
|             return m_customDiffPair.m_Width; | |
|         else | |
|             return m_DiffPairDimensionsList[m_diffPairIndex].m_Width; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCurrentDiffPairGap | |
|      * @return the current diff pair gap, according to the selected options | |
|      * ( using the default netclass value or a preset/custom value ) | |
|      * the default netclass is always in m_DiffPairDimensionsList[0] | |
|      */ | |
|     inline int GetCurrentDiffPairGap() const | |
|     { | |
|         if( m_useCustomDiffPair ) | |
|             return m_customDiffPair.m_Gap; | |
|         else | |
|             return m_DiffPairDimensionsList[m_diffPairIndex].m_Gap; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCurrentDiffPairViaGap | |
|      * @return the current diff pair via gap, according to the selected options | |
|      * ( using the default netclass value or a preset/custom value ) | |
|      * the default netclass is always in m_DiffPairDimensionsList[0] | |
|      */ | |
|     inline int GetCurrentDiffPairViaGap() const | |
|     { | |
|         if( m_useCustomDiffPair ) | |
|             return m_customDiffPair.m_ViaGap; | |
|         else | |
|             return m_DiffPairDimensionsList[m_diffPairIndex].m_ViaGap; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetMinHoleSeparation | |
|      * @param aValue The minimum distance between the edges of two holes or 0 to disable | |
|      * hole-to-hole separation checking. | |
|      */ | |
|     void SetMinHoleSeparation( int aDistance ); | |
| 
 | |
|     /** | |
|      * Function SetRequireCourtyardDefinitions | |
|      * @param aRequire Set to true to generate DRC violations from missing courtyards. | |
|      */ | |
|     void SetRequireCourtyardDefinitions( bool aRequire ); | |
| 
 | |
|     /** | |
|      * Function SetProhibitOverlappingCourtyards | |
|      * @param aProhibit Set to true to generate DRC violations from overlapping courtyards. | |
|      */ | |
|     void SetProhibitOverlappingCourtyards( bool aProhibit ); | |
| 
 | |
|     /** | |
|      * Function GetVisibleLayers | |
|      * returns a bit-mask of all the layers that are visible | |
|      * @return int - the visible layers in bit-mapped form. | |
|      */ | |
|     inline LSET GetVisibleLayers() const | |
|     { | |
|         return m_visibleLayers; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetVisibleAlls | |
|      * Set the bit-mask of all visible elements categories, | |
|      * including enabled layers | |
|      */ | |
|     void SetVisibleAlls(); | |
| 
 | |
|     /** | |
|      * Function SetVisibleLayers | |
|      * changes the bit-mask of visible layers | |
|      * @param aMask = The new bit-mask of visible layers | |
|      */ | |
|     inline void SetVisibleLayers( LSET aMask ) | |
|     { | |
|         m_visibleLayers = aMask & m_enabledLayers; | |
|     } | |
| 
 | |
|     /** | |
|      * Function IsLayerVisible | |
|      * tests whether a given layer is visible | |
|      * @param aLayerId = The layer to be tested | |
|      * @return bool - true if the layer is visible. | |
|      */ | |
|     inline bool IsLayerVisible( PCB_LAYER_ID aLayerId ) const | |
|     { | |
|         // If a layer is disabled, it is automatically invisible | |
|         return (m_visibleLayers & m_enabledLayers)[aLayerId]; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetLayerVisibility | |
|      * changes the visibility of a given layer | |
|      * @param aLayerId = The layer to be changed | |
|      * @param aNewState = The new visibility state of the layer | |
|      */ | |
|     void SetLayerVisibility( PCB_LAYER_ID aLayerId, bool aNewState ); | |
| 
 | |
|     /** | |
|      * Function GetVisibleElements | |
|      * returns a bit-mask of all the element categories that are visible | |
|      * @return int - the visible element categories in bit-mapped form. | |
|      */ | |
|     inline int GetVisibleElements() const | |
|     { | |
|         return m_visibleElements; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetVisibleElements | |
|      * changes the bit-mask of visible element categories | |
|      * @param aMask = The new bit-mask of visible element categories | |
|      */ | |
|     inline void SetVisibleElements( int aMask ) | |
|     { | |
|         m_visibleElements = aMask; | |
|     } | |
| 
 | |
|     /** | |
|      * Function IsElementVisible | |
|      * tests whether a given element category is visible. Keep this as an | |
|      * inline function. | |
|      * @param aElementCategory is from the enum by the same name | |
|      * @return bool - true if the element is visible. | |
|      * @see enum GAL_LAYER_ID | |
|      */ | |
|     inline bool IsElementVisible( GAL_LAYER_ID aElementCategory ) const | |
|     { | |
|         return ( m_visibleElements & ( 1 << GAL_LAYER_INDEX( aElementCategory ) ) ); | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetElementVisibility | |
|      * changes the visibility of an element category | |
|      * @param aElementCategory is from the enum by the same name | |
|      * @param aNewState = The new visibility state of the element category | |
|      * @see enum GAL_LAYER_ID | |
|      */ | |
|     void SetElementVisibility( GAL_LAYER_ID aElementCategory, bool aNewState ); | |
| 
 | |
|     /** | |
|      * Function GetEnabledLayers | |
|      * returns a bit-mask of all the layers that are enabled | |
|      * @return int - the enabled layers in bit-mapped form. | |
|      */ | |
|     inline LSET GetEnabledLayers() const | |
|     { | |
|         return m_enabledLayers; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetEnabledLayers | |
|      * changes the bit-mask of enabled layers | |
|      * @param aMask = The new bit-mask of enabled layers | |
|      */ | |
|     void SetEnabledLayers( LSET aMask ); | |
| 
 | |
|     /** | |
|      * Function IsLayerEnabled | |
|      * tests whether a given layer is enabled | |
|      * @param aLayerId = The layer to be tested | |
|      * @return bool - true if the layer is enabled | |
|      */ | |
|     inline bool IsLayerEnabled( PCB_LAYER_ID aLayerId ) const | |
|     { | |
|         return m_enabledLayers[aLayerId]; | |
|     } | |
| 
 | |
|     /** | |
|      * Function GetCopperLayerCount | |
|      * @return int - the number of neabled copper layers | |
|      */ | |
|     inline int GetCopperLayerCount() const | |
|     { | |
|         return m_copperLayerCount; | |
|     } | |
| 
 | |
|     /** | |
|      * Function SetCopperLayerCount | |
|      * do what its name says... | |
|      * @param aNewLayerCount = The new number of enabled copper layers | |
|      */ | |
|     void SetCopperLayerCount( int aNewLayerCount ); | |
| 
 | |
|     /** | |
|      * Function AppendConfigs | |
|      * appends to @a aResult the configuration setting accessors which will later | |
|      * allow reading or writing of configuration file information directly into | |
|      * this object. | |
|      */ | |
|     void AppendConfigs( BOARD* aBoard, PARAM_CFG_ARRAY* aResult ); | |
| 
 | |
|     inline int GetBoardThickness() const { return m_boardThickness; } | |
|     inline void SetBoardThickness( int aThickness ) { m_boardThickness = aThickness; } | |
| 
 | |
|     /** | |
|      * Function GetLineThickness | |
|      * Returns the default graphic segment thickness from the layer class for the given layer. | |
|      */ | |
|     int GetLineThickness( PCB_LAYER_ID aLayer ) const; | |
| 
 | |
|     /** | |
|      * Function GetTextSize | |
|      * Returns the default text size from the layer class for the given layer. | |
|      */ | |
|     wxSize GetTextSize( PCB_LAYER_ID aLayer ) const; | |
| 
 | |
|     /** | |
|      * Function GetTextThickness | |
|      * Returns the default text thickness from the layer class for the given layer. | |
|      */ | |
|     int GetTextThickness( PCB_LAYER_ID aLayer ) const; | |
| 
 | |
|     bool GetTextItalic( PCB_LAYER_ID aLayer ) const; | |
|     bool GetTextUpright( PCB_LAYER_ID aLayer ) const; | |
| 
 | |
|     int GetLayerClass( PCB_LAYER_ID aLayer ) const; | |
| 
 | |
| private: | |
|     void formatNetClass( NETCLASS* aNetClass, OUTPUTFORMATTER* aFormatter, int aNestLevel, | |
|                          int aControlBits ) const; | |
| }; | |
| 
 | |
| #endif  // BOARD_DESIGN_SETTINGS_H_
 |