2009-04-05 20:49:15 +00:00
|
|
|
/*
|
2011-09-30 18:15:37 +00:00
|
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
2009-04-05 20:49:15 +00:00
|
|
|
*
|
|
|
|
* Copyright (C) 2008 Wayne Stambaugh <stambaughw@verizon.net>
|
2011-09-30 18:15:37 +00:00
|
|
|
* Copyright (C) 1992-2008 KiCad Developers, see change_log.txt for contributors.
|
2009-04-05 20:49:15 +00:00
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file contains the global constants and variables used in the PCB
|
2011-09-30 18:15:37 +00:00
|
|
|
* applications Pcbnew, CvPcb, and GervView. The goal of this was to
|
2009-04-05 20:49:15 +00:00
|
|
|
* unobfuscate the original header file design that made it very difficult
|
|
|
|
* to figure out where these variables lived. Ideally, they should be pushed
|
|
|
|
* back into the application layer.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "fctsys.h"
|
|
|
|
#include "pcbcommon.h"
|
|
|
|
#include "plot_common.h"
|
2011-09-23 13:57:12 +00:00
|
|
|
|
|
|
|
#include "class_pad.h"
|
2009-04-05 20:49:15 +00:00
|
|
|
#include "class_zone_setting.h"
|
2009-10-28 11:48:47 +00:00
|
|
|
#include "class_board_design_settings.h"
|
2009-04-05 20:49:15 +00:00
|
|
|
|
2011-09-23 13:57:12 +00:00
|
|
|
|
|
|
|
class MODULE;
|
|
|
|
|
|
|
|
|
2011-12-06 08:35:13 +00:00
|
|
|
/* return a one bit layer mask from a layer number
|
|
|
|
* aLayerNumber = the layer number to convert (0 .. LAYER_COUNT-1)
|
|
|
|
*/
|
|
|
|
int GetLayerMask( int aLayerNumber )
|
|
|
|
{
|
|
|
|
// Look up Table for conversion one layer number -> one bit layer mask:
|
|
|
|
static int tabOneLayerMask[LAYER_COUNT] =
|
|
|
|
{
|
|
|
|
0x00000001, 0x00000002, 0x00000004, 0x00000008,
|
|
|
|
0x00000010, 0x00000020, 0x00000040, 0x00000080,
|
|
|
|
0x00000100, 0x00000200, 0x00000400, 0x00000800,
|
|
|
|
0x00001000, 0x00002000, 0x00004000, 0x00008000,
|
|
|
|
0x00010000, 0x00020000, 0x00040000, 0x00080000,
|
|
|
|
0x00100000, 0x00200000, 0x00400000, 0x00800000,
|
|
|
|
0x01000000, 0x02000000, 0x04000000, 0x08000000,
|
|
|
|
0x10000000, 0x20000000, 0x40000000, 0x80000000
|
|
|
|
};
|
|
|
|
|
|
|
|
wxASSERT( aLayerNumber < LAYER_COUNT && aLayerNumber >= 0 );
|
|
|
|
return( tabOneLayerMask[aLayerNumber] );
|
|
|
|
}
|
2009-04-05 20:49:15 +00:00
|
|
|
|
|
|
|
/* Look up Table for conversion copper layer count -> general copper layer
|
|
|
|
* mask: */
|
|
|
|
int g_TabAllCopperLayerMask[NB_COPPER_LAYERS] = {
|
|
|
|
0x0001, 0x8001, 0x8003, 0x8007,
|
|
|
|
0x800F, 0x801F, 0x803F, 0x807F,
|
|
|
|
0x80FF, 0x81FF, 0x83FF, 0x87FF,
|
|
|
|
0x8FFF, 0x9FFF, 0xCFFF, 0xFFFF
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
DISPLAY_OPTIONS DisplayOpt; /* Display options for board items */
|
|
|
|
|
|
|
|
/* PCB file name extension definitions. */
|
|
|
|
wxString NetExtBuffer( wxT( "net" ) );
|
|
|
|
wxString NetCmpExtBuffer( wxT( "cmp" ) );
|
|
|
|
wxString g_Shapes3DExtBuffer( wxT( "wrl" ) );
|
|
|
|
const wxString ModuleFileExtension( wxT( "mod" ) );
|
|
|
|
|
|
|
|
/* PCB file name wild card definitions. */
|
2011-09-30 18:15:37 +00:00
|
|
|
const wxString ModuleFileWildcard( _( "KiCad footprint library files (*.mod)|*.mod" ) );
|
2009-04-05 20:49:15 +00:00
|
|
|
|
2011-09-07 09:27:02 +00:00
|
|
|
int g_RotationAngle;
|
2009-04-05 20:49:15 +00:00
|
|
|
|
|
|
|
int g_AnchorColor = BLUE;
|
|
|
|
int g_ModuleTextCMPColor = LIGHTGRAY;
|
|
|
|
int g_ModuleTextCUColor = MAGENTA;
|
|
|
|
int g_ModuleTextNOVColor = DARKGRAY;
|
|
|
|
int g_PadCUColor = GREEN;
|
|
|
|
int g_PadCMPColor = RED;
|
|
|
|
|
2009-11-23 15:16:50 +00:00
|
|
|
|
|
|
|
// Current design settings:
|
2010-01-31 20:01:46 +00:00
|
|
|
class BOARD_DESIGN_SETTINGS g_DesignSettings;
|
2009-04-05 20:49:15 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Used in track creation, a list of track segments currently being created,
|
|
|
|
* with the newest track at the end of the list, sorted by new-ness. e.g. use
|
|
|
|
* TRACK->Back() to get the next older track, TRACK->Next() to get the next
|
|
|
|
* newer track.
|
|
|
|
*/
|
|
|
|
DLIST<TRACK> g_CurrentTrackList;
|
|
|
|
|
|
|
|
BOARD* g_ModuleEditor_Pcb = NULL;
|
|
|
|
|
2011-11-08 16:37:25 +00:00
|
|
|
bool g_Zone_45_Only = false;
|
2009-04-05 20:49:15 +00:00
|
|
|
|
|
|
|
// Default setting used when creating a new zone
|
|
|
|
ZONE_SETTING g_Zone_Default_Setting;
|
|
|
|
|
|
|
|
D_PAD g_Pad_Master( (MODULE*) NULL );
|