26#include <pybind11/pybind11.h> 
   83        return static_cast<const BOARD*
>( this );
 
 
   92        return static_cast<BOARD*
>( this );
 
 
  108        if( 
group->AsEdaItem()->IsLocked() )
 
 
  121    wxFAIL_MSG( wxString( 
"GetStroke() not defined by " ) + 
GetClass() );
 
 
  129    wxFAIL_MSG( wxString( 
"SetStroke() not defined by " ) + 
GetClass() );
 
 
  142        return board->GetDesignSettings().m_MaxError;
 
 
  184        return board->GetLayerName( 
m_layer );
 
 
  221        return _( 
"all copper layers" );
 
  223    for( 
LSET testLayers : { copperLayers, techLayers, layers } )
 
  227            if( testLayers[ bit ] )
 
  231                if( testLayers.count() > 1 )
 
  232                    layerInfo << wxS( 
" " ) + 
_( 
"and others" );
 
  240    return _( 
"no layers" );
 
 
  273    if( aImage == 
nullptr )
 
 
  289    if( addToParentGroup )
 
  291        wxCHECK_MSG( aCommit, dupe, 
"Must supply a commit to update parent group" );
 
  296            group->AddItem( dupe );
 
 
  305                                          int aClearance, 
int aError, 
ERROR_LOC aErrorLoc,
 
  306                                          bool ignoreLineWidth )
 const 
  308    wxFAIL_MSG( wxString::Format( wxT( 
"%s doesn't implement TransformShapeToPolygon()" ), 
GetClass() ) );
 
 
  329    static std::shared_ptr<SHAPE> shape;
 
 
  339    static std::shared_ptr<SHAPE_SEGMENT> slot;
 
 
  353        pos -= parentFP->GetPosition();
 
 
  368        pos += parentFP->GetPosition();
 
 
  377    wxMessageBox( wxT( 
"virtual BOARD_ITEM::Rotate used, should not occur" ), 
GetClass() );
 
 
  383    wxMessageBox( wxT( 
"virtual BOARD_ITEM::Flip used, should not occur" ), 
GetClass() );
 
 
  389    wxMessageBox( wxT( 
"virtual BOARD_ITEM::Mirror used, should not occur" ), 
GetClass() );
 
 
  396        return fp->GetReference();
 
 
  405        return board->GetFontFiles();
 
 
  417        if( layerEnum.
Choices().GetCount() == 0 )
 
  434        auto isNotFootprintHolder =
 
 
 
ERROR_LOC
When approximating an arc or circle, should the error be placed on the outside or inside of the curve...
 
constexpr int ARC_HIGH_DEF
 
constexpr EDA_IU_SCALE pcbIUScale
 
LAYER_T
The allowed types of layers, same as Specctra DSN spec.
 
#define DEFAULT_LINE_WIDTH
 
static struct BOARD_ITEM_DESC _BOARD_ITEM_DESC
 
Abstract interface for BOARD_ITEMs capable of storing other items inside.
 
virtual void Remove(BOARD_ITEM *aItem, REMOVE_MODE aMode=REMOVE_MODE::NORMAL)=0
Removes an item from the container.
 
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
 
BOARD_ITEM(BOARD_ITEM *aParent, KICAD_T idtype, PCB_LAYER_ID aLayer=F_Cu)
 
virtual void Mirror(const VECTOR2I &aCentre, FLIP_DIRECTION aFlipDirection)
Mirror this object relative to a given horizontal axis the layer is not changed.
 
virtual PCB_LAYER_ID GetLayer() const
Return the primary layer this item is on.
 
bool IsGroupableType() const
 
virtual BOARD_ITEM * Duplicate(bool addToParentGroup, BOARD_COMMIT *aCommit=nullptr) const
Create a copy of this BOARD_ITEM.
 
void DeleteStructure()
Delete this object after removing from its parent if it has one.
 
const std::vector< wxString > * GetEmbeddedFonts() override
 
void SwapItemData(BOARD_ITEM *aImage)
Swap data between aItem and aImage.
 
void SetLocked(bool aLocked) override
 
virtual STROKE_PARAMS GetStroke() const
 
virtual int BoardLayerCount() const
Return the total number of layers for the board that this item resides on.
 
virtual void SetStroke(const STROKE_PARAMS &aStroke)
 
wxString GetParentAsString() const
For "parent" property.
 
bool IsLocked() const override
 
virtual void TransformShapeToPolygon(SHAPE_POLY_SET &aBuffer, PCB_LAYER_ID aLayer, int aClearance, int aError, ERROR_LOC aErrorLoc, bool ignoreLineWidth=false) const
Convert the item shape to a closed polygon.
 
virtual void Rotate(const VECTOR2I &aRotCentre, const EDA_ANGLE &aAngle)
Rotate this object.
 
virtual void SetLayer(PCB_LAYER_ID aLayer)
Set the layer this item is on.
 
virtual std::vector< int > ViewGetLayers() const override
Return the all the layers within the VIEW the object is painted on.
 
virtual std::shared_ptr< SHAPE > GetEffectiveShape(PCB_LAYER_ID aLayer=UNDEFINED_LAYER, FLASHING aFlash=FLASHING::DEFAULT) const
Some pad shapes can be complex (rounded/chamfered rectangle), even without considering custom shapes.
 
virtual const BOARD * GetBoard() const
Return the BOARD in which this BOARD_ITEM resides, or NULL if none.
 
FOOTPRINT * GetParentFootprint() const
 
VECTOR2I GetFPRelativePosition() const
 
virtual LSET BoardLayerSet() const
Return the LSET for the board that this item resides on.
 
virtual LSET GetLayerSet() const
Return a std::bitset of all layers on which the item physically resides.
 
virtual void swapData(BOARD_ITEM *aImage)
 
const KIFONT::METRICS & GetFontMetrics() const
 
void SetFPRelativePosition(const VECTOR2I &aPos)
 
virtual wxString LayerMaskDescribe() const
Return a string (to be shown to the user) describing a layer mask.
 
virtual void CopyFrom(const BOARD_ITEM *aOther)
 
BOARD_ITEM_CONTAINER * GetParent() const
 
bool IsSideSpecific() const
 
virtual int BoardCopperLayerCount() const
Return the total number of copper layers for the board that this item resides on.
 
wxString GetLayerName() const
Return the name of the PCB layer on which the item resides.
 
virtual std::shared_ptr< SHAPE_SEGMENT > GetEffectiveHoleShape() const
 
virtual void Flip(const VECTOR2I &aCentre, FLIP_DIRECTION aFlipDirection)
Flip this object, i.e.
 
Information pertinent to a Pcbnew printed circuit board.
 
bool IsFootprintHolder() const
Find out if the board is being used to hold a single footprint for editing/viewing.
 
static wxString GetStandardLayerName(PCB_LAYER_ID aLayerId)
Return an "English Standard" name of a PCB layer when given aLayerNumber.
 
LSET GetLayerSet() const override
Return a std::bitset of all layers on which the item physically resides.
 
int GetCopperLayerCount() const
 
const wxString GetLayerName(PCB_LAYER_ID aLayer) const
Return the name of a aLayer.
 
const LSET & GetEnabledLayers() const
A proxy function that calls the corresponding function in m_BoardSettings.
 
COMMIT & Modify(EDA_ITEM *aItem, BASE_SCREEN *aScreen=nullptr, RECURSE_MODE aRecurse=RECURSE_MODE::NO_RECURSE)
Modify a given item in the model.
 
A set of EDA_ITEMs (i.e., without duplicates).
 
A base class for most all the KiCad significant classes used in schematics and boards.
 
virtual VECTOR2I GetPosition() const
 
virtual void SetPosition(const VECTOR2I &aPos)
 
virtual EDA_GROUP * GetParentGroup() const
 
KICAD_T Type() const
Returns the type of object.
 
virtual void SetParent(EDA_ITEM *aParent)
 
virtual EDA_ITEM * Clone() const
Create a duplicate of this item with linked list members set to NULL.
 
EDA_ITEM * m_parent
Owner.
 
EDA_ITEM(EDA_ITEM *parent, KICAD_T idType, bool isSCH_ITEM=false, bool isBOARD_ITEM=false)
 
EDA_ITEM * findParent(KICAD_T aType) const
 
ENUM_MAP & Map(T aValue, const wxString &aName)
 
static ENUM_MAP< T > & Instance()
 
ENUM_MAP & Undefined(T aValue)
 
Class that other classes need to inherit from, in order to be inspectable.
 
static const METRICS & Default()
 
virtual wxString GetClass() const =0
Return the class name.
 
LSET is a set of PCB_LAYER_IDs.
 
static const LSET & SideSpecificMask()
 
LSEQ Seq(const LSEQ &aSequence) const
Return an LSEQ from the union of this LSET and a desired sequence.
 
static const LSET & AllTechMask()
Return a mask holding all technical layers (no CU layer) on both side.
 
static const LSET & AllLayersMask()
 
static LSET AllCuMask()
return AllCuMask( MAX_CU_LAYERS );
 
static wxString Name(PCB_LAYER_ID aLayerId)
Return the fixed name association with aLayerId.
 
PROPERTY_BASE & SetAvailableFunc(std::function< bool(INSPECTABLE *)> aFunc)
Set a callback function to determine whether an object provides this property.
 
PROPERTY_BASE & SetIsHiddenFromPropertiesManager(bool aHide=true)
 
PROPERTY_BASE & SetIsHiddenFromLibraryEditors(bool aIsHidden=true)
 
Provide class metadata.Helper macro to map type hashes to names.
 
void InheritsAfter(TYPE_ID aDerived, TYPE_ID aBase)
Declare an inheritance relationship between types.
 
static PROPERTY_MANAGER & Instance()
 
PROPERTY_BASE & AddProperty(PROPERTY_BASE *aProperty, const wxString &aGroup=wxEmptyString)
Register a property.
 
Represent a set of closed polygons.
 
Simple container to manage line stroke parameters.
 
A type-safe container of any type.
 
Some functions to handle hotkeys in KiCad.
 
constexpr PCB_LAYER_ID PCBNEW_LAYER_ID_START
 
FLASHING
Enum used during connectivity building to ensure we do not query connectivity while building the data...
 
@ LAYER_LOCKED_ITEM_SHADOW
Shadow layer for locked items.
 
PCB_LAYER_ID
A quick note on layer IDs:
 
This file contains miscellaneous commonly used macros and functions.
 
#define UNIMPLEMENTED_FOR(type)
 
Class to handle a set of BOARD_ITEMs.
 
#define IMPLEMENT_ENUM_TO_WXANY(type)
 
#define NO_SETTER(owner, type)
 
@ PT_COORD
Coordinate expressed in distance units (mm/inch)
 
bool operator()(const BOARD_ITEM *a, const BOARD_ITEM *b) const
 
void RotatePoint(int *pX, int *pY, const EDA_ANGLE &aAngle)
Calculate the new point of coord coord pX, pY, for a rotation center 0, 0.
 
@ PCB_SHAPE_T
class PCB_SHAPE, a segment not on copper layers
 
@ PCB_DIM_ORTHOGONAL_T
class PCB_DIM_ORTHOGONAL, a linear dimension constrained to x/y
 
@ PCB_DIM_LEADER_T
class PCB_DIM_LEADER, a leader dimension (graphic item)
 
@ PCB_GENERATOR_T
class PCB_GENERATOR, generator on a layer
 
@ PCB_VIA_T
class PCB_VIA, a via (like a track segment on a copper layer)
 
@ PCB_DIM_CENTER_T
class PCB_DIM_CENTER, a center point marking (graphic item)
 
@ PCB_GROUP_T
class PCB_GROUP, a set of BOARD_ITEMs
 
@ PCB_TEXTBOX_T
class PCB_TEXTBOX, wrapped text on a layer
 
@ PCB_ZONE_T
class ZONE, a copper pour area
 
@ PCB_TEXT_T
class PCB_TEXT, text on a layer
 
@ PCB_REFERENCE_IMAGE_T
class PCB_REFERENCE_IMAGE, bitmap on a layer
 
@ PCB_FIELD_T
class PCB_FIELD, text associated with a footprint property
 
@ PCB_BARCODE_T
class PCB_BARCODE, a barcode (graphic item)
 
@ PCB_FOOTPRINT_T
class FOOTPRINT, a footprint
 
@ PCB_DIM_ALIGNED_T
class PCB_DIM_ALIGNED, a linear dimension (graphic item)
 
@ PCB_PAD_T
class PAD, a pad in a footprint
 
@ PCB_ARC_T
class PCB_ARC, an arc track segment on a copper layer
 
@ PCB_DIMENSION_T
class PCB_DIMENSION_BASE: abstract dimension meta-type
 
@ PCB_TABLE_T
class PCB_TABLE, table of PCB_TABLECELLs
 
@ PCB_TRACE_T
class PCB_TRACK, a track segment (segment on a copper layer)
 
@ PCB_DIM_RADIAL_T
class PCB_DIM_RADIAL, a radius or diameter dimension
 
VECTOR2< int32_t > VECTOR2I