2007-08-04 04:42:49 +00:00
|
|
|
/**************************************************************/
|
2009-10-28 11:48:47 +00:00
|
|
|
/* pcbstruct.h : some classes and definitions used in pcbnew */
|
2007-08-04 04:42:49 +00:00
|
|
|
/**************************************************************/
|
2007-05-28 18:09:49 +00:00
|
|
|
|
|
|
|
#ifndef PCBSTRUCT_H
|
|
|
|
#define PCBSTRUCT_H
|
|
|
|
|
|
|
|
#include "base_struct.h"
|
2009-02-04 15:25:03 +00:00
|
|
|
#include "class_base_screen.h"
|
2009-10-21 19:16:25 +00:00
|
|
|
#include "class_board_item.h"
|
2007-05-28 18:09:49 +00:00
|
|
|
|
2009-11-23 20:18:47 +00:00
|
|
|
// Definitions relatives aux libraries
|
2009-12-07 03:46:13 +00:00
|
|
|
#define ENTETE_LIBRAIRIE "PCBNEW-LibModule-V1"
|
|
|
|
#define ENTETE_LIBDOC "PCBNEW-LibDoc----V1"
|
|
|
|
#define L_ENTETE_LIB 18
|
|
|
|
#define EXT_DOC wxT( "mdc" )
|
|
|
|
|
|
|
|
|
|
|
|
#define FLAG1 (1 << 13) // flag for free local computations
|
|
|
|
#define FLAG0 (1 << 12) // flag for free local computations
|
|
|
|
#define BEGIN_ONPAD (1 << 11) // flag indicating a start of segment pad
|
|
|
|
#define END_ONPAD (1 << 10) // flag indicating an end of segment pad
|
|
|
|
#define BUSY (1 << 9) // flag indicating that the structure has
|
|
|
|
// already been edited, in some routines
|
|
|
|
#define DELETED (1 << 8) // structures erased and set string "DELETED"
|
|
|
|
#define NO_TRACE (1 << 7) // The element must not be displayed
|
|
|
|
|
|
|
|
#define SURBRILL (1 << 5) // element highlighted
|
|
|
|
#define DRAG (1 << 4) // segment in drag mode
|
|
|
|
#define EDIT (1 << 3) // element being edited
|
|
|
|
#define SEGM_FIXE (1 << 2) // segment fixed (not erase global)
|
|
|
|
#define SEGM_AR (1 << 1) // segment marked for auto routing
|
|
|
|
#define CHAIN (1 << 0) // mark segment
|
2007-08-04 04:42:49 +00:00
|
|
|
|
|
|
|
|
2007-10-07 18:24:15 +00:00
|
|
|
/* Layer identification (layer number) */
|
2009-12-07 03:46:13 +00:00
|
|
|
#define FIRST_COPPER_LAYER 0
|
|
|
|
#define LAYER_N_BACK 0
|
|
|
|
#define LAYER_N_2 1
|
|
|
|
#define LAYER_N_3 2
|
|
|
|
#define LAYER_N_4 3
|
|
|
|
#define LAYER_N_5 4
|
|
|
|
#define LAYER_N_6 5
|
|
|
|
#define LAYER_N_7 6
|
|
|
|
#define LAYER_N_8 7
|
|
|
|
#define LAYER_N_9 8
|
|
|
|
#define LAYER_N_10 9
|
|
|
|
#define LAYER_N_11 10
|
|
|
|
#define LAYER_N_12 11
|
|
|
|
#define LAYER_N_13 12
|
|
|
|
#define LAYER_N_14 13
|
|
|
|
#define LAYER_N_15 14
|
|
|
|
#define LAYER_N_FRONT 15
|
|
|
|
#define LAST_COPPER_LAYER LAYER_N_FRONT
|
|
|
|
#define NB_COPPER_LAYERS (LAST_COPPER_LAYER + 1)
|
|
|
|
|
|
|
|
#define FIRST_NO_COPPER_LAYER 16
|
2009-12-21 17:56:25 +00:00
|
|
|
#define ADHESIVE_N_BACK 16
|
|
|
|
#define ADHESIVE_N_FRONT 17
|
|
|
|
#define SOLDERPASTE_N_BACK 18
|
|
|
|
#define SOLDERPASTE_N_FRONT 19
|
|
|
|
#define SILKSCREEN_N_BACK 20
|
|
|
|
#define SILKSCREEN_N_FRONT 21
|
|
|
|
#define SOLDERMASK_N_BACK 22
|
|
|
|
#define SOLDERMASK_N_FRONT 23
|
2009-12-07 03:46:13 +00:00
|
|
|
#define DRAW_N 24
|
|
|
|
#define COMMENT_N 25
|
|
|
|
#define ECO1_N 26
|
|
|
|
#define ECO2_N 27
|
|
|
|
#define EDGE_N 28
|
|
|
|
#define LAST_NO_COPPER_LAYER 28
|
2010-01-01 13:30:39 +00:00
|
|
|
#define UNUSED_LAYER_29 29
|
|
|
|
#define UNUSED_LAYER_30 30
|
|
|
|
#define UNUSED_LAYER_31 31
|
2009-12-07 03:46:13 +00:00
|
|
|
#define NB_LAYERS (LAST_NO_COPPER_LAYER + 1)
|
|
|
|
|
|
|
|
#define LAYER_COUNT 32
|
|
|
|
|
|
|
|
|
2009-12-21 12:05:36 +00:00
|
|
|
#define LAYER_BACK (1 << LAYER_N_BACK) ///< bit mask for copper layer
|
2009-12-07 03:46:13 +00:00
|
|
|
#define LAYER_2 (1 << LAYER_N_2) ///< bit mask for layer 2
|
|
|
|
#define LAYER_3 (1 << LAYER_N_3) ///< bit mask for layer 3
|
|
|
|
#define LAYER_4 (1 << LAYER_N_4) ///< bit mask for layer 4
|
|
|
|
#define LAYER_5 (1 << LAYER_N_5) ///< bit mask for layer 5
|
|
|
|
#define LAYER_6 (1 << LAYER_N_6) ///< bit mask for layer 6
|
|
|
|
#define LAYER_7 (1 << LAYER_N_7) ///< bit mask for layer 7
|
|
|
|
#define LAYER_8 (1 << LAYER_N_8) ///< bit mask for layer 8
|
|
|
|
#define LAYER_9 (1 << LAYER_N_9) ///< bit mask for layer 9
|
|
|
|
#define LAYER_10 (1 << LAYER_N_10) ///< bit mask for layer 10
|
|
|
|
#define LAYER_11 (1 << LAYER_N_11) ///< bit mask for layer 11
|
|
|
|
#define LAYER_12 (1 << LAYER_N_12) ///< bit mask for layer 12
|
|
|
|
#define LAYER_13 (1 << LAYER_N_13) ///< bit mask for layer 13
|
|
|
|
#define LAYER_14 (1 << LAYER_N_14) ///< bit mask for layer 14
|
|
|
|
#define LAYER_15 (1 << LAYER_N_15) ///< bit mask for layer 15
|
2009-12-21 12:05:36 +00:00
|
|
|
#define LAYER_FRONT (1 << LAYER_N_FRONT) ///< bit mask for component layer
|
2009-12-21 18:51:37 +00:00
|
|
|
#define ADHESIVE_LAYER_BACK (1 << ADHESIVE_N_BACK)
|
|
|
|
#define ADHESIVE_LAYER_FRONT (1 << ADHESIVE_N_FRONT)
|
|
|
|
#define SOLDERPASTE_LAYER_BACK (1 << SOLDERPASTE_N_BACK)
|
|
|
|
#define SOLDERPASTE_LAYER_FRONT (1 << SOLDERPASTE_N_FRONT)
|
|
|
|
#define SILKSCREEN_LAYER_BACK (1 << SILKSCREEN_N_BACK)
|
|
|
|
#define SILKSCREEN_LAYER_FRONT (1 << SILKSCREEN_N_FRONT)
|
|
|
|
#define SOLDERMASK_LAYER_BACK (1 << SOLDERMASK_N_BACK)
|
|
|
|
#define SOLDERMASK_LAYER_FRONT (1 << SOLDERMASK_N_FRONT)
|
2009-12-07 03:46:13 +00:00
|
|
|
#define DRAW_LAYER (1 << DRAW_N)
|
|
|
|
#define COMMENT_LAYER (1 << COMMENT_N)
|
|
|
|
#define ECO1_LAYER (1 << ECO1_N)
|
|
|
|
#define ECO2_LAYER (1 << ECO2_N)
|
|
|
|
#define EDGE_LAYER (1 << EDGE_N)
|
|
|
|
|
2009-12-21 17:56:25 +00:00
|
|
|
#define FIRST_NON_COPPER_LAYER ADHESIVE_N_BACK
|
2009-12-07 03:46:13 +00:00
|
|
|
#define LAST_NON_COPPER_LAYER EDGE_N
|
2008-01-31 20:53:44 +00:00
|
|
|
|
2007-10-01 13:51:07 +00:00
|
|
|
// extra bits 0xE0000000
|
2009-11-23 20:18:47 +00:00
|
|
|
/* Helpful global layers mask : */
|
2009-12-07 03:46:13 +00:00
|
|
|
#define ALL_LAYERS 0x1FFFFFFF // Pcbnew used 29 layers
|
|
|
|
#define FULL_LAYERS 0xFFFFFFFF // Gerbview used 32 layers
|
|
|
|
#define ALL_NO_CU_LAYERS 0x1FFF0000
|
|
|
|
#define ALL_CU_LAYERS 0x0000FFFF
|
|
|
|
#define INTERNAL_LAYERS 0x00007FFE
|
|
|
|
#define EXTERNAL_LAYERS 0x00008001
|
2007-10-01 13:51:07 +00:00
|
|
|
|
2010-01-01 13:30:39 +00:00
|
|
|
|
|
|
|
// layers order in dialogs (plot, print and toolbars)
|
|
|
|
// in same order than in setup layers dialog
|
|
|
|
// (Front or Top to Back or Bottom)
|
|
|
|
#define DECLARE_LAYERS_ORDER_LIST(list) int list[LAYER_COUNT] =\
|
|
|
|
{ LAYER_N_FRONT,\
|
|
|
|
LAYER_N_15, LAYER_N_14, LAYER_N_13, LAYER_N_12,\
|
|
|
|
LAYER_N_11, LAYER_N_10, LAYER_N_9, LAYER_N_8,\
|
|
|
|
LAYER_N_7, LAYER_N_6, LAYER_N_5, LAYER_N_4,\
|
|
|
|
LAYER_N_3, LAYER_N_2,\
|
|
|
|
LAYER_N_BACK,\
|
|
|
|
ADHESIVE_N_FRONT , ADHESIVE_N_BACK,\
|
|
|
|
SOLDERPASTE_N_FRONT, SOLDERPASTE_N_BACK,\
|
|
|
|
SILKSCREEN_N_FRONT, SILKSCREEN_N_BACK,\
|
|
|
|
SOLDERMASK_N_FRONT, SOLDERMASK_N_BACK,\
|
|
|
|
DRAW_N,\
|
|
|
|
COMMENT_N,\
|
|
|
|
ECO1_N, ECO2_N,\
|
|
|
|
EDGE_N,\
|
|
|
|
UNUSED_LAYER_29, UNUSED_LAYER_30, UNUSED_LAYER_31\
|
|
|
|
};
|
|
|
|
|
2009-05-24 18:28:36 +00:00
|
|
|
class NETINFO_ITEM;
|
2009-08-01 19:26:05 +00:00
|
|
|
class MARKER_PCB;
|
2009-05-24 18:28:36 +00:00
|
|
|
class RATSNEST_ITEM;
|
2008-01-28 18:44:14 +00:00
|
|
|
|
2008-01-01 11:46:47 +00:00
|
|
|
|
|
|
|
/* main window classes : */
|
2009-07-30 11:04:07 +00:00
|
|
|
#include "wxBasePcbFrame.h"
|
2007-05-28 18:09:49 +00:00
|
|
|
|
2007-12-09 12:55:53 +00:00
|
|
|
/* Class to handle a board */
|
|
|
|
#include "class_board.h"
|
|
|
|
|
2009-10-10 01:25:53 +00:00
|
|
|
enum ELEMENTS_NUMBERS
|
|
|
|
{
|
|
|
|
VIAS_VISIBLE = 0,
|
|
|
|
VIA_NOT_DEFINED_VISIBLE = VIAS_VISIBLE,
|
|
|
|
VIA_MICROVIA_VISIBLE,
|
|
|
|
VIA_BLIND_BURIED_VISIBLE,
|
|
|
|
VIA_THROUGH_VISIBLE,
|
|
|
|
MODULE_TEXT_CMP_VISIBLE,
|
|
|
|
MODULE_TEXT_CU_VISIBLE,
|
|
|
|
MODULE_TEXT_NOV_VISIBLE,
|
|
|
|
ANCHOR_VISIBLE,
|
|
|
|
PAD_CU_VISIBLE,
|
|
|
|
PAD_CMP_VISIBLE
|
|
|
|
};
|
2009-10-21 19:16:25 +00:00
|
|
|
|
2009-10-18 23:22:26 +00:00
|
|
|
/**
|
|
|
|
* Function IsValidLayerIndex
|
|
|
|
* tests whether a given integer is a valid layer index
|
|
|
|
* @param aLayerIndex = Layer index to test
|
|
|
|
* @return true if aLayerIndex is a valid layer index
|
2009-11-23 20:18:47 +00:00
|
|
|
*/
|
2009-10-18 23:22:26 +00:00
|
|
|
inline bool IsValidLayerIndex( int aLayerIndex )
|
|
|
|
{
|
|
|
|
return aLayerIndex >= 0 && aLayerIndex < NB_LAYERS;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function IsValidCopperLayerIndex
|
|
|
|
* tests whether an integer is a valid copper layer index
|
|
|
|
* @param aLayerIndex = Layer index to test
|
|
|
|
* @return true if aLayerIndex is a valid copper layer index
|
2009-11-23 20:18:47 +00:00
|
|
|
*/
|
2009-10-18 23:22:26 +00:00
|
|
|
inline bool IsValidCopperLayerIndex( int aLayerIndex )
|
|
|
|
{
|
2009-12-07 03:46:13 +00:00
|
|
|
return aLayerIndex >= FIRST_COPPER_LAYER && aLayerIndex <= LAST_COPPER_LAYER;
|
2009-10-18 23:22:26 +00:00
|
|
|
}
|
2009-10-21 19:16:25 +00:00
|
|
|
|
2009-10-18 23:22:26 +00:00
|
|
|
/**
|
|
|
|
* Function IsValidNonCopperLayerIndex
|
|
|
|
* tests whether an integer is a valid non copper layer index
|
|
|
|
* @param aLayerIndex = Layer index to test
|
|
|
|
* @return true if aLayerIndex is a valid non copper layer index
|
2009-11-23 20:18:47 +00:00
|
|
|
*/
|
2009-10-18 23:22:26 +00:00
|
|
|
inline bool IsValidNonCopperLayerIndex( int aLayerIndex )
|
|
|
|
{
|
2009-11-23 20:18:47 +00:00
|
|
|
return aLayerIndex >= FIRST_NO_COPPER_LAYER
|
|
|
|
&& aLayerIndex <= LAST_NO_COPPER_LAYER;
|
2009-10-18 23:22:26 +00:00
|
|
|
}
|
2009-10-21 19:16:25 +00:00
|
|
|
|
2007-08-06 02:02:39 +00:00
|
|
|
|
2007-05-28 18:09:49 +00:00
|
|
|
// Values for m_DisplayViaMode member:
|
|
|
|
enum DisplayViaMode {
|
2007-08-04 04:42:49 +00:00
|
|
|
VIA_HOLE_NOT_SHOW = 0,
|
|
|
|
VIA_SPECIAL_HOLE_SHOW,
|
|
|
|
ALL_VIA_HOLE_SHOW,
|
|
|
|
OPT_VIA_HOLE_END
|
2007-05-28 18:09:49 +00:00
|
|
|
};
|
|
|
|
|
2007-12-09 12:55:53 +00:00
|
|
|
/* Handle info to display a board */
|
2009-07-29 13:10:36 +00:00
|
|
|
#include "class_pcb_screen.h"
|
2007-05-28 18:09:49 +00:00
|
|
|
|
2007-10-26 06:08:19 +00:00
|
|
|
/**********************************/
|
|
|
|
/* Module (Footprint) description */
|
|
|
|
/**********************************/
|
|
|
|
|
2008-01-28 18:44:14 +00:00
|
|
|
#include "class_pad.h" // class for pads
|
|
|
|
#include "class_edge_mod.h" // Class for footprint graphic elements
|
|
|
|
#include "class_text_mod.h" // Class for footprint fields
|
|
|
|
#include "class_module.h" // Class for the footprint
|
2009-05-25 11:53:55 +00:00
|
|
|
#include "class_netinfo.h" // Class for nets
|
2007-05-28 18:09:49 +00:00
|
|
|
|
2008-01-14 19:24:41 +00:00
|
|
|
#include "class_drawsegment.h"
|
2007-05-28 18:09:49 +00:00
|
|
|
#include "class_pcb_text.h"
|
2010-01-18 12:37:53 +00:00
|
|
|
#include "class_dimension.h"
|
2007-05-28 18:09:49 +00:00
|
|
|
#include "class_mire.h"
|
|
|
|
#include "class_track.h"
|
2009-08-01 19:26:05 +00:00
|
|
|
#include "class_marker_pcb.h"
|
2007-12-09 12:55:53 +00:00
|
|
|
#include "class_zone.h"
|
2007-05-28 18:09:49 +00:00
|
|
|
|
2009-06-18 20:51:01 +00:00
|
|
|
/* Values for DISPLAY_OPTIONS.ShowTrackClearanceMode parameter option
|
2009-11-23 20:18:47 +00:00
|
|
|
* This parameter controls how to show tracks and vias clearance area
|
2009-06-18 20:51:01 +00:00
|
|
|
*/
|
|
|
|
enum ShowTrackClearanceModeList {
|
2009-11-23 20:18:47 +00:00
|
|
|
DO_NOT_SHOW_CLEARANCE = 0, // Do not show clearance areas
|
|
|
|
SHOW_CLEARANCE_NEW_TRACKS, /* Show clearance areas only
|
|
|
|
* for new track during track
|
|
|
|
* creation */
|
|
|
|
SHOW_CLEARANCE_NEW_TRACKS_AND_VIA_AREAS, /* Show clearance areas only
|
|
|
|
* for new track during track
|
|
|
|
* creation, and shows a via
|
|
|
|
* clearance area at end of
|
|
|
|
* current new segment (guide
|
|
|
|
* to place a new via
|
|
|
|
*/
|
|
|
|
SHOW_CLEARANCE_ALWAYS /* Show Always clearance areas
|
|
|
|
* for track and vias
|
|
|
|
*/
|
2009-06-18 20:51:01 +00:00
|
|
|
};
|
2007-05-28 18:09:49 +00:00
|
|
|
|
2008-03-01 13:15:41 +00:00
|
|
|
class DISPLAY_OPTIONS
|
2007-05-28 18:09:49 +00:00
|
|
|
{
|
|
|
|
public:
|
2007-08-04 04:42:49 +00:00
|
|
|
bool DisplayPadFill;
|
2009-09-29 04:44:35 +00:00
|
|
|
bool DisplayViaFill;
|
2007-08-04 04:42:49 +00:00
|
|
|
bool DisplayPadNum;
|
|
|
|
bool DisplayPadNoConn;
|
|
|
|
bool DisplayPadIsol;
|
|
|
|
|
|
|
|
int DisplayModEdge;
|
|
|
|
int DisplayModText;
|
2009-11-23 20:18:47 +00:00
|
|
|
bool DisplayPcbTrackFill; /* FALSE = sketch , TRUE = filled */
|
|
|
|
int ShowTrackClearanceMode; /* = 0 , 1 or 2
|
|
|
|
* 0 = do not show clearance
|
|
|
|
* 1 = show track clearance
|
|
|
|
* 2 = show clearance + via area
|
|
|
|
* (useful to know what clearance area is
|
|
|
|
* needed if we want to put a via on
|
|
|
|
* terminal track point)
|
|
|
|
*/
|
2009-06-18 20:51:01 +00:00
|
|
|
|
|
|
|
int m_DisplayViaMode; /* 0 do not show via hole,
|
2007-08-08 03:50:44 +00:00
|
|
|
* 1 show via hole for non default value
|
|
|
|
* 2 show all via hole */
|
2007-08-04 04:42:49 +00:00
|
|
|
|
|
|
|
bool DisplayPolarCood;
|
2008-12-12 21:30:07 +00:00
|
|
|
int DisplayZonesMode;
|
2009-03-26 19:27:50 +00:00
|
|
|
int DisplayNetNamesMode; /* 0 do not show netnames,
|
|
|
|
* 1 show netnames on pads
|
|
|
|
* 2 show netnames on tracks
|
|
|
|
* 3 show netnames on tracks and pads
|
2009-05-21 17:42:42 +00:00
|
|
|
*/
|
2009-03-26 19:27:50 +00:00
|
|
|
|
2007-08-04 04:42:49 +00:00
|
|
|
bool Show_Modules_Cmp;
|
|
|
|
bool Show_Modules_Cu;
|
|
|
|
|
|
|
|
int DisplayDrawItems;
|
|
|
|
bool ContrastModeDisplay;
|
2007-05-28 18:09:49 +00:00
|
|
|
|
|
|
|
public:
|
2007-08-30 22:20:52 +00:00
|
|
|
DISPLAY_OPTIONS();
|
2007-05-28 18:09:49 +00:00
|
|
|
};
|
|
|
|
|
2009-12-07 03:46:13 +00:00
|
|
|
#endif // PCBSTRUCT_H
|