Clang-alike lightweight RTTI for pcbnew + type casting cleanup.

This commit is contained in:
Tomasz Wlostowski 2014-06-06 11:44:21 +02:00 committed by Maciej Suminski
parent 7a110d0ce3
commit 4121c27269
19 changed files with 297 additions and 168 deletions

View File

@ -32,13 +32,13 @@
#ifndef BASE_STRUCT_H_ #ifndef BASE_STRUCT_H_
#define BASE_STRUCT_H_ #define BASE_STRUCT_H_
#include <core/typeinfo.h>
#include <colors.h> #include <colors.h>
#include <bitmaps.h> #include <bitmaps.h>
#include <richio.h> #include <richio.h>
#include <view/view_item.h> #include <view/view_item.h>
#include <boost/ptr_container/ptr_vector.hpp>
#if defined(DEBUG) #if defined(DEBUG)
#include <iostream> // needed for Show() #include <iostream> // needed for Show()
extern std::ostream& operator <<( std::ostream& out, const wxSize& size ); extern std::ostream& operator <<( std::ostream& out, const wxSize& size );
@ -369,8 +369,17 @@ public:
EDA_ITEM( const EDA_ITEM& base ); EDA_ITEM( const EDA_ITEM& base );
virtual ~EDA_ITEM() { }; virtual ~EDA_ITEM() { };
/// @copydoc VIEW_ITEM::Type() /**
KICAD_T Type() const { return m_StructType; } * Function Type()
*
* returns the type of object. This attribute should never be changed
* after a constructor sets it, so there is no public "setter" method.
* @return KICAD_T - the type of object.
*/
inline KICAD_T Type() const
{
return m_StructType;
}
void SetTimeStamp( time_t aNewTimeStamp ) { m_TimeStamp = aNewTimeStamp; } void SetTimeStamp( time_t aNewTimeStamp ) { m_TimeStamp = aNewTimeStamp; }
time_t GetTimeStamp() const { return m_TimeStamp; } time_t GetTimeStamp() const { return m_TimeStamp; }

180
include/core/typeinfo.h Normal file
View File

@ -0,0 +1,180 @@
/*
* This program source code file is part of KiCad, a free EDA CAD application.
*
* Copyright (C) 2014 CERN
* Copyright (C) 2004-2013 KiCad Developers, see change_log.txt for contributors.
* @author Tomasz Wlostowski <tomasz.wlostowski@cern.ch>
*
* 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 __KICAD_TYPEINFO_H
#define __KICAD_TYPEINFO_H
#include <cstdio>
class EDA_ITEM;
/**
* Enum KICAD_T
* is the set of class identification values, stored in EDA_ITEM::m_StructType
*/
enum KICAD_T
{
NOT_USED = -1, ///< the 3d code uses this value
EOT = 0, ///< search types array terminator (End Of Types)
TYPE_NOT_INIT = 0,
PCB_T,
SCREEN_T, ///< not really an item, used to identify a screen
// Items in pcb
PCB_MODULE_T, ///< class MODULE, a footprint
PCB_PAD_T, ///< class D_PAD, a pad in a footprint
PCB_LINE_T, ///< class DRAWSEGMENT, a segment not on copper layers
PCB_TEXT_T, ///< class TEXTE_PCB, text on a layer
PCB_MODULE_TEXT_T, ///< class TEXTE_MODULE, text in a footprint
PCB_MODULE_EDGE_T, ///< class EDGE_MODULE, a footprint edge
PCB_TRACE_T, ///< class TRACK, a track segment (segment on a copper layer)
PCB_VIA_T, ///< class VIA, a via (like a track segment on a copper layer)
PCB_ZONE_T, ///< class SEGZONE, a segment used to fill a zone area (segment on a
///< copper layer)
PCB_MARKER_T, ///< class MARKER_PCB, a marker used to show something
PCB_DIMENSION_T, ///< class DIMENSION, a dimension (graphic item)
PCB_TARGET_T, ///< class PCB_TARGET, a target (graphic item)
PCB_ZONE_AREA_T, ///< class ZONE_CONTAINER, a zone area
PCB_ITEM_LIST_T, ///< class BOARD_ITEM_LIST, a list of board items
// Schematic draw Items. The order of these items effects the sort order.
// It is currently ordered to mimic the old Eeschema locate behavior where
// the smallest item is the selected item.
SCH_MARKER_T,
SCH_JUNCTION_T,
SCH_NO_CONNECT_T,
SCH_BUS_WIRE_ENTRY_T,
SCH_BUS_BUS_ENTRY_T,
SCH_LINE_T,
SCH_BITMAP_T,
SCH_TEXT_T,
SCH_LABEL_T,
SCH_GLOBAL_LABEL_T,
SCH_HIERARCHICAL_LABEL_T,
SCH_FIELD_T,
SCH_COMPONENT_T,
SCH_SHEET_PIN_T,
SCH_SHEET_T,
// Be prudent with these 3 types:
// they should be used only to locate a specific field type
// among SCH_FIELD_T items types
SCH_FIELD_LOCATE_REFERENCE_T,
SCH_FIELD_LOCATE_VALUE_T,
SCH_FIELD_LOCATE_FOOTPRINT_T,
// General
SCH_SCREEN_T,
/*
* Draw items in library component.
*
* The order of these items effects the sort order for items inside the
* "DRAW/ENDDRAW" section of the component definition in a library file.
* If you add a new draw item, type, please make sure you add it so the
* sort order is logical.
*/
LIB_COMPONENT_T,
LIB_ALIAS_T,
LIB_ARC_T,
LIB_CIRCLE_T,
LIB_TEXT_T,
LIB_RECTANGLE_T,
LIB_POLYLINE_T,
LIB_BEZIER_T,
LIB_PIN_T,
/*
* Fields are not saved inside the "DRAW/ENDDRAW". Add new draw item
* types before this line.
*/
LIB_FIELD_T,
/*
* For GerbView: items type:
*/
TYPE_GERBER_DRAW_ITEM,
/*
* for Pl_Editor, in undo/redo commands
*/
TYPE_PL_EDITOR_LAYOUT,
// End value
MAX_STRUCT_TYPE_ID
};
template<typename T>
struct remove_pointer
{
typedef T type;
};
template<typename T>
struct remove_pointer<T*>
{
typedef typename remove_pointer<T>::type type;
};
/**
* Function IsA()
*
* Checks if the type of aObject is T.
* @param aObject object for type check
* @return true, if aObject type equals T.
*/
template <class T, class I>
bool IsA(const I *aObject)
{
return remove_pointer<T>::type::ClassOf(aObject);
}
template <class T, class I>
bool IsA(const I& aObject)
{
return remove_pointer<T>::type::ClassOf(&aObject);
}
/**
* Function dyn_cast()
*
* A lightweight dynamic downcast. Casts aObject to type Casted*.
* Uses EDA_ITEM::Type() and EDA_ITEM::ClassOf() to check if type matches.
* @param aObject object to be casted
* @return down-casted object or NULL if type doesn't match Casted.
*/
template<class Casted, class From>
Casted dyn_cast(From aObject)
{
if( remove_pointer<Casted>::type::ClassOf ( aObject ) )
return static_cast<Casted>( aObject );
return NULL;
}
#endif // __KICAD_TYPEINFO_H

View File

@ -34,6 +34,8 @@
#include <class_base_screen.h> #include <class_base_screen.h>
#include <general.h> #include <general.h>
#include <boost/ptr_container/ptr_vector.hpp>
class SCH_ITEM; class SCH_ITEM;
class SCH_SHEET_PATH; class SCH_SHEET_PATH;
class LINE_READER; class LINE_READER;

View File

@ -36,104 +36,6 @@
#include <view/view.h> #include <view/view.h>
#include <gal/definitions.h> #include <gal/definitions.h>
/**
* Enum KICAD_T
* is the set of class identification values, stored in EDA_ITEM::m_StructType
*/
enum KICAD_T
{
NOT_USED = -1, ///< the 3d code uses this value
EOT = 0, ///< search types array terminator (End Of Types)
TYPE_NOT_INIT = 0,
PCB_T,
SCREEN_T, ///< not really an item, used to identify a screen
// Items in pcb
PCB_MODULE_T, ///< class MODULE, a footprint
PCB_PAD_T, ///< class D_PAD, a pad in a footprint
PCB_LINE_T, ///< class DRAWSEGMENT, a segment not on copper layers
PCB_TEXT_T, ///< class TEXTE_PCB, text on a layer
PCB_MODULE_TEXT_T, ///< class TEXTE_MODULE, text in a footprint
PCB_MODULE_EDGE_T, ///< class EDGE_MODULE, a footprint edge
PCB_TRACE_T, ///< class TRACK, a track segment (segment on a copper layer)
PCB_VIA_T, ///< class VIA, a via (like a track segment on a copper layer)
PCB_ZONE_T, ///< class SEGZONE, a segment used to fill a zone area (segment on a
///< copper layer)
PCB_MARKER_T, ///< class MARKER_PCB, a marker used to show something
PCB_DIMENSION_T, ///< class DIMENSION, a dimension (graphic item)
PCB_TARGET_T, ///< class PCB_TARGET, a target (graphic item)
PCB_ZONE_AREA_T, ///< class ZONE_CONTAINER, a zone area
PCB_ITEM_LIST_T, ///< class BOARD_ITEM_LIST, a list of board items
// Schematic draw Items. The order of these items effects the sort order.
// It is currently ordered to mimic the old Eeschema locate behavior where
// the smallest item is the selected item.
SCH_MARKER_T,
SCH_JUNCTION_T,
SCH_NO_CONNECT_T,
SCH_BUS_WIRE_ENTRY_T,
SCH_BUS_BUS_ENTRY_T,
SCH_LINE_T,
SCH_BITMAP_T,
SCH_TEXT_T,
SCH_LABEL_T,
SCH_GLOBAL_LABEL_T,
SCH_HIERARCHICAL_LABEL_T,
SCH_FIELD_T,
SCH_COMPONENT_T,
SCH_SHEET_PIN_T,
SCH_SHEET_T,
// Be prudent with these 3 types:
// they should be used only to locate a specific field type
// among SCH_FIELD_T items types
SCH_FIELD_LOCATE_REFERENCE_T,
SCH_FIELD_LOCATE_VALUE_T,
SCH_FIELD_LOCATE_FOOTPRINT_T,
// General
SCH_SCREEN_T,
/*
* Draw items in library component.
*
* The order of these items effects the sort order for items inside the
* "DRAW/ENDDRAW" section of the component definition in a library file.
* If you add a new draw item, type, please make sure you add it so the
* sort order is logical.
*/
LIB_COMPONENT_T,
LIB_ALIAS_T,
LIB_ARC_T,
LIB_CIRCLE_T,
LIB_TEXT_T,
LIB_RECTANGLE_T,
LIB_POLYLINE_T,
LIB_BEZIER_T,
LIB_PIN_T,
/*
* Fields are not saved inside the "DRAW/ENDDRAW". Add new draw item
* types before this line.
*/
LIB_FIELD_T,
/*
* For GerbView: items type:
*/
TYPE_GERBER_DRAW_ITEM,
/*
* for Pl_Editor, in undo/redo commands
*/
TYPE_PL_EDITOR_LAYOUT,
// End value
MAX_STRUCT_TYPE_ID
};
namespace KIGFX namespace KIGFX
{ {
@ -186,17 +88,6 @@ public:
delete[] m_groups; delete[] m_groups;
} }
/**
* Function Type
* returns the type of object. This attribute should never be changed
* after a constructor sets it, so there is no public "setter" method.
* @return KICAD_T - the type of object.
*/
virtual KICAD_T Type() const
{
return NOT_USED;
}
/** /**
* Function ViewBBox() * Function ViewBBox()
* returns the bounding box of the item covering all its layers. * returns the bounding box of the item covering all its layers.

View File

@ -220,6 +220,10 @@ private:
void chainMarkedSegments( wxPoint aPosition, LAYER_MSK aLayerMask, TRACK_PTRS* aList ); void chainMarkedSegments( wxPoint aPosition, LAYER_MSK aLayerMask, TRACK_PTRS* aList );
public: public:
static inline bool ClassOf( const EDA_ITEM* aItem )
{
return PCB_T == aItem->Type();
}
void SetFileName( const wxString& aFileName ) { m_fileName = aFileName; } void SetFileName( const wxString& aFileName ) { m_fileName = aFileName; }

View File

@ -58,6 +58,21 @@ public:
BOARD_CONNECTED_ITEM( const BOARD_CONNECTED_ITEM& aItem ); BOARD_CONNECTED_ITEM( const BOARD_CONNECTED_ITEM& aItem );
static inline bool ClassOf( const EDA_ITEM* aItem )
{
switch( aItem->Type() )
{
case PCB_PAD_T:
case PCB_TRACE_T:
case PCB_VIA_T:
case PCB_ZONE_AREA_T:
return true;
default:
return false;
}
}
///> @copydoc BOARD_ITEM::IsConnected() ///> @copydoc BOARD_ITEM::IsConnected()
bool IsConnected() const bool IsConnected() const
{ {

View File

@ -54,6 +54,11 @@ public:
/// skip the linked list stuff, and parent /// skip the linked list stuff, and parent
const EDGE_MODULE& operator = ( const EDGE_MODULE& rhs ); const EDGE_MODULE& operator = ( const EDGE_MODULE& rhs );
static inline bool ClassOf( const EDA_ITEM* aItem )
{
return PCB_MODULE_EDGE_T == aItem->Type();
}
void Copy( EDGE_MODULE* source ); // copy structure void Copy( EDGE_MODULE* source ); // copy structure
void SetStart0( const wxPoint& aPoint ) { m_Start0 = aPoint; } void SetStart0( const wxPoint& aPoint ) { m_Start0 = aPoint; }

View File

@ -424,7 +424,8 @@ EDA_RECT MODULE::GetFootprintRect() const
for( const BOARD_ITEM* item = m_Drawings.GetFirst(); item; item = item->Next() ) for( const BOARD_ITEM* item = m_Drawings.GetFirst(); item; item = item->Next() )
{ {
const EDGE_MODULE *edge = dynamic_cast<const EDGE_MODULE*>( item ); const EDGE_MODULE* edge = dyn_cast<const EDGE_MODULE*>( item );
if( edge ) if( edge )
area.Merge( edge->GetBoundingBox() ); area.Merge( edge->GetBoundingBox() );
} }

View File

@ -77,6 +77,11 @@ public:
~MODULE(); ~MODULE();
static inline bool ClassOf( const EDA_ITEM* aItem )
{
return PCB_MODULE_T == aItem->Type();
}
MODULE* Next() const { return static_cast<MODULE*>( Pnext ); } MODULE* Next() const { return static_cast<MODULE*>( Pnext ); }
MODULE* Back() const { return static_cast<MODULE*>( Pback ); } MODULE* Back() const { return static_cast<MODULE*>( Pback ); }

View File

@ -60,25 +60,18 @@ public:
TEXT_is_DIVERS = 2 TEXT_is_DIVERS = 2
}; };
private:
/* Note: orientation in 1/10 deg relative to the footprint
* Physical orient is m_Orient + m_Parent->m_Orient
*/
TEXT_TYPE m_Type; ///< 0=ref, 1=val, etc.
bool m_NoShow; ///< true = invisible
wxPoint m_Pos0; ///< text coordinates relatives to the footprint anchor, orient 0.
///< text coordinate ref point is the text centre
public:
TEXTE_MODULE( MODULE* parent, TEXT_TYPE text_type = TEXT_is_DIVERS ); TEXTE_MODULE( MODULE* parent, TEXT_TYPE text_type = TEXT_is_DIVERS );
// Do not create a copy constructor. The one generated by the compiler is adequate. // Do not create a copy constructor. The one generated by the compiler is adequate.
~TEXTE_MODULE(); ~TEXTE_MODULE();
static inline bool ClassOf( const EDA_ITEM* aItem )
{
return PCB_MODULE_TEXT_T == aItem->Type();
}
virtual const wxPoint& GetPosition() const virtual const wxPoint& GetPosition() const
{ {
return m_Pos; return m_Pos;
@ -172,6 +165,17 @@ public:
#if defined(DEBUG) #if defined(DEBUG)
virtual void Show( int nestLevel, std::ostream& os ) const { ShowDummy( os ); } // override virtual void Show( int nestLevel, std::ostream& os ) const { ShowDummy( os ); } // override
#endif #endif
private:
/* Note: orientation in 1/10 deg relative to the footprint
* Physical orient is m_Orient + m_Parent->m_Orient
*/
TEXT_TYPE m_Type; ///< 0=ref, 1=val, etc.
bool m_NoShow; ///< true = invisible
wxPoint m_Pos0; ///< text coordinates relatives to the footprint anchor, orient 0.
///< text coordinate ref point is the text centre
}; };
#endif // TEXT_MODULE_H_ #endif // TEXT_MODULE_H_

View File

@ -79,18 +79,12 @@ extern TRACK* GetTrack( TRACK* aStartTrace, const TRACK* aEndTrace,
class TRACK : public BOARD_CONNECTED_ITEM class TRACK : public BOARD_CONNECTED_ITEM
{ {
// make SetNext() and SetBack() private so that they may not be called from anywhere.
// list management is done on TRACKs using DLIST<TRACK> only.
private:
void SetNext( EDA_ITEM* aNext ) { Pnext = aNext; }
void SetBack( EDA_ITEM* aBack ) { Pback = aBack; }
protected:
int m_Width; // Thickness of track, or via diameter
wxPoint m_Start; // Line start point
wxPoint m_End; // Line end point
public: public:
static inline bool ClassOf( const EDA_ITEM* aItem )
{
return PCB_TRACE_T == aItem->Type();
}
BOARD_CONNECTED_ITEM* start; // pointers to a connected item (pad or track) BOARD_CONNECTED_ITEM* start; // pointers to a connected item (pad or track)
BOARD_CONNECTED_ITEM* end; BOARD_CONNECTED_ITEM* end;
@ -339,6 +333,16 @@ protected:
* Helper for drawing the short netname in tracks */ * Helper for drawing the short netname in tracks */
void DrawShortNetname( EDA_DRAW_PANEL* panel, wxDC* aDC, GR_DRAWMODE aDrawMode, void DrawShortNetname( EDA_DRAW_PANEL* panel, wxDC* aDC, GR_DRAWMODE aDrawMode,
EDA_COLOR_T aBgColor ); EDA_COLOR_T aBgColor );
int m_Width; ///< Thickness of track, or via diameter
wxPoint m_Start; ///< Line start point
wxPoint m_End; ///< Line end point
private:
// make SetNext() and SetBack() private so that they may not be called from anywhere.
// list management is done on TRACKs using DLIST<TRACK> only.
void SetNext( EDA_ITEM* aNext ) { Pnext = aNext; }
void SetBack( EDA_ITEM* aBack ) { Pback = aBack; }
}; };
@ -376,6 +380,11 @@ class VIA : public TRACK
public: public:
VIA( BOARD_ITEM* aParent ); VIA( BOARD_ITEM* aParent );
static inline bool ClassOf( const EDA_ITEM *aItem )
{
return PCB_VIA_T == aItem->Type();
}
// Do not create a copy constructor. The one generated by the compiler is adequate. // Do not create a copy constructor. The one generated by the compiler is adequate.
void Draw( EDA_DRAW_PANEL* panel, wxDC* DC, void Draw( EDA_DRAW_PANEL* panel, wxDC* DC,
@ -467,7 +476,6 @@ public:
*/ */
bool IsDrillDefault() const { return m_Drill <= 0; } bool IsDrillDefault() const { return m_Drill <= 0; }
protected: protected:
virtual void GetMsgPanelInfoBase( std::vector< MSG_PANEL_ITEM >& aList ); virtual void GetMsgPanelInfoBase( std::vector< MSG_PANEL_ITEM >& aList );

View File

@ -284,7 +284,7 @@ const ZONE_CONTAINER* TRACKS_CLEANER::zoneForTrackEndpoint( const TRACK *aTrack,
{ {
// Vias are special cased, since they get a layer range, not a single one // Vias are special cased, since they get a layer range, not a single one
LAYER_NUM top_layer, bottom_layer; LAYER_NUM top_layer, bottom_layer;
const VIA *via = dynamic_cast<const VIA*>( aTrack ); const VIA* via = dyn_cast<const VIA*>( aTrack );
if( via ) if( via )
via->LayerPair( &top_layer, &bottom_layer ); via->LayerPair( &top_layer, &bottom_layer );
@ -318,7 +318,8 @@ bool TRACKS_CLEANER::testTrackEndpointDangling( TRACK *aTrack, ENDPOINT_T aEndPo
/* If a via is connected to this end, test if this via has a second item connected. /* If a via is connected to this end, test if this via has a second item connected.
* If not, remove the current segment (the via would then become * If not, remove the current segment (the via would then become
* unconnected and remove on the following pass) */ * unconnected and remove on the following pass) */
VIA* via = dynamic_cast<VIA*>( other ); VIA* via = dyn_cast<VIA*>( other );
if( via ) if( via )
{ {
// search for another segment following the via // search for another segment following the via

View File

@ -171,7 +171,8 @@ void FOOTPRINT_EDIT_FRAME::Edit_Edge_Width( EDGE_MODULE* aEdge )
for( BOARD_ITEM *item = module->GraphicalItems(); item; item = item->Next() ) for( BOARD_ITEM *item = module->GraphicalItems(); item; item = item->Next() )
{ {
aEdge = dynamic_cast<EDGE_MODULE*>( item ); aEdge = dyn_cast<EDGE_MODULE*>( item );
if( aEdge ) if( aEdge )
aEdge->SetWidth( GetDesignSettings().m_ModuleSegmentWidth ); aEdge->SetWidth( GetDesignSettings().m_ModuleSegmentWidth );
} }
@ -218,7 +219,7 @@ void FOOTPRINT_EDIT_FRAME::Edit_Edge_Layer( EDGE_MODULE* aEdge )
for( BOARD_ITEM *item = module->GraphicalItems() ; item != NULL; for( BOARD_ITEM *item = module->GraphicalItems() ; item != NULL;
item = item->Next() ) item = item->Next() )
{ {
aEdge = dynamic_cast<EDGE_MODULE*>( item ); aEdge = dyn_cast<EDGE_MODULE*>( item );
if( aEdge && (aEdge->GetLayer() != new_layer) ) if( aEdge && (aEdge->GetLayer() != new_layer) )
{ {

View File

@ -62,7 +62,7 @@ static void Abort_Create_Track( EDA_DRAW_PANEL* Panel, wxDC* DC )
{ {
PCB_EDIT_FRAME* frame = (PCB_EDIT_FRAME*) Panel->GetParent(); PCB_EDIT_FRAME* frame = (PCB_EDIT_FRAME*) Panel->GetParent();
BOARD* pcb = frame->GetBoard(); BOARD* pcb = frame->GetBoard();
TRACK* track = dynamic_cast<TRACK*>( frame->GetCurItem() ); TRACK* track = dyn_cast<TRACK*>( frame->GetCurItem() );
if( track ) if( track )
{ {

View File

@ -1671,7 +1671,7 @@ BOARD* PCB_IO::Load( const wxString& aFileName, BOARD* aAppendToMe, const PROPER
m_parser->SetLineReader( &reader ); m_parser->SetLineReader( &reader );
m_parser->SetBoard( aAppendToMe ); m_parser->SetBoard( aAppendToMe );
BOARD* board = dynamic_cast<BOARD*>( m_parser->Parse() ); BOARD* board = dyn_cast<BOARD*>( m_parser->Parse() );
wxASSERT( board ); wxASSERT( board );
// Give the filename to the board if it's new // Give the filename to the board if it's new

View File

@ -249,7 +249,7 @@ MODULE* FOOTPRINT_EDIT_FRAME::Import_Module()
f.ReadAll( &fcontents ); f.ReadAll( &fcontents );
module = dynamic_cast<MODULE*>( pcb_io.Parse( fcontents ) ); module = dyn_cast<MODULE*>( pcb_io.Parse( fcontents ) );
if( !module ) if( !module )
{ {

View File

@ -146,18 +146,18 @@ void PCB_RENDER_SETTINGS::LoadDisplayOptions( const DISPLAY_OPTIONS& aOptions )
const COLOR4D& PCB_RENDER_SETTINGS::GetColor( const VIEW_ITEM* aItem, int aLayer ) const const COLOR4D& PCB_RENDER_SETTINGS::GetColor( const VIEW_ITEM* aItem, int aLayer ) const
{ {
int netCode = -1; int netCode = -1;
const EDA_ITEM* item = static_cast<const EDA_ITEM*>( aItem );
if( aItem ) if( item )
{ {
if( static_cast<const EDA_ITEM*>( aItem )->IsSelected() ) if( item->IsSelected() )
{ {
return m_layerColorsSel[aLayer]; return m_layerColorsSel[aLayer];
} }
// Try to obtain the netcode for the item // Try to obtain the netcode for the item
const BOARD_CONNECTED_ITEM* item = dynamic_cast<const BOARD_CONNECTED_ITEM*>( aItem ); if( const BOARD_CONNECTED_ITEM* conItem = dyn_cast<const BOARD_CONNECTED_ITEM*> ( item ) )
if( item ) netCode = conItem->GetNetCode();
netCode = item->GetNetCode();
} }
// Return grayish color for non-highlighted layers in the high contrast mode // Return grayish color for non-highlighted layers in the high contrast mode
@ -200,49 +200,51 @@ PCB_PAINTER::PCB_PAINTER( GAL* aGal ) :
bool PCB_PAINTER::Draw( const VIEW_ITEM* aItem, int aLayer ) bool PCB_PAINTER::Draw( const VIEW_ITEM* aItem, int aLayer )
{ {
const EDA_ITEM* item = static_cast<const EDA_ITEM*>( aItem );
// the "cast" applied in here clarifies which overloaded draw() is called // the "cast" applied in here clarifies which overloaded draw() is called
switch( aItem->Type() ) switch( item->Type() )
{ {
case PCB_ZONE_T: case PCB_ZONE_T:
case PCB_TRACE_T: case PCB_TRACE_T:
draw( (const TRACK*) aItem, aLayer ); draw( (const TRACK*) item, aLayer );
break; break;
case PCB_VIA_T: case PCB_VIA_T:
draw( (const VIA*) aItem, aLayer ); draw( (const VIA*) item, aLayer );
break; break;
case PCB_PAD_T: case PCB_PAD_T:
draw( (const D_PAD*) aItem, aLayer ); draw( (const D_PAD*) item, aLayer );
break; break;
case PCB_LINE_T: case PCB_LINE_T:
case PCB_MODULE_EDGE_T: case PCB_MODULE_EDGE_T:
draw( (DRAWSEGMENT*) aItem ); draw( (DRAWSEGMENT*) item );
break; break;
case PCB_TEXT_T: case PCB_TEXT_T:
draw( (TEXTE_PCB*) aItem, aLayer ); draw( (TEXTE_PCB*) item, aLayer );
break; break;
case PCB_MODULE_TEXT_T: case PCB_MODULE_TEXT_T:
draw( (TEXTE_MODULE*) aItem, aLayer ); draw( (TEXTE_MODULE*) item, aLayer );
break; break;
case PCB_ZONE_AREA_T: case PCB_ZONE_AREA_T:
draw( (ZONE_CONTAINER*) aItem ); draw( (ZONE_CONTAINER*) item );
break; break;
case PCB_DIMENSION_T: case PCB_DIMENSION_T:
draw( (DIMENSION*) aItem, aLayer ); draw( (DIMENSION*) item, aLayer );
break; break;
case PCB_TARGET_T: case PCB_TARGET_T:
draw( (PCB_TARGET*) aItem ); draw( (PCB_TARGET*) item );
break; break;
case PCB_MARKER_T: case PCB_MARKER_T:
draw( (MARKER_PCB*) aItem ); draw( (MARKER_PCB*) item );
break; break;
default: default:

View File

@ -377,7 +377,7 @@ void PlotStandardLayer( BOARD *aBoard, PLOTTER* aPlotter,
// plot them on solder mask // plot them on solder mask
for( TRACK* track = aBoard->m_Track; track; track = track->Next() ) for( TRACK* track = aBoard->m_Track; track; track = track->Next() )
{ {
const VIA* Via = dynamic_cast<const VIA*>( track ); const VIA* Via = dyn_cast<const VIA*>( track );
if( !Via ) if( !Via )
continue; continue;
@ -562,7 +562,7 @@ void PlotLayerOutlines( BOARD *aBoard, PLOTTER* aPlotter,
// Plot vias holes // Plot vias holes
for( TRACK* track = aBoard->m_Track; track; track = track->Next() ) for( TRACK* track = aBoard->m_Track; track; track = track->Next() )
{ {
const VIA* via = dynamic_cast<const VIA*>( track ); const VIA* via = dyn_cast<const VIA*>( track );
if( via && via->IsOnLayer( layer ) ) // via holes can be not through holes if( via && via->IsOnLayer( layer ) ) // via holes can be not through holes
{ {
@ -663,7 +663,7 @@ void PlotSolderMaskLayer( BOARD *aBoard, PLOTTER* aPlotter,
int via_margin = via_clearance + inflate; int via_margin = via_clearance + inflate;
for( TRACK* track = aBoard->m_Track; track; track = track->Next() ) for( TRACK* track = aBoard->m_Track; track; track = track->Next() )
{ {
const VIA* via = dynamic_cast<const VIA*>( track ); const VIA* via = dyn_cast<const VIA*>( track );
if( !via ) if( !via )
continue; continue;

View File

@ -151,7 +151,8 @@ bool BRDITEMS_PLOTTER::PlotAllTextsModule( MODULE* aModule )
for( BOARD_ITEM *item = aModule->GraphicalItems().GetFirst(); for( BOARD_ITEM *item = aModule->GraphicalItems().GetFirst();
item != NULL; item = item->Next() ) item != NULL; item = item->Next() )
{ {
textModule = dynamic_cast<TEXTE_MODULE*>( item ); textModule = dyn_cast<TEXTE_MODULE*>( item );
if( !textModule ) if( !textModule )
continue; continue;
@ -350,7 +351,7 @@ void BRDITEMS_PLOTTER::Plot_Edges_Modules()
{ {
for( BOARD_ITEM* item = module->GraphicalItems().GetFirst(); item; item = item->Next() ) for( BOARD_ITEM* item = module->GraphicalItems().GetFirst(); item; item = item->Next() )
{ {
EDGE_MODULE *edge = dynamic_cast<EDGE_MODULE*>( item ); EDGE_MODULE* edge = dyn_cast<EDGE_MODULE*>( item );
if( !edge || (( GetLayerMask( edge->GetLayer() ) & m_layerMask ) == 0) ) if( !edge || (( GetLayerMask( edge->GetLayer() ) & m_layerMask ) == 0) )
continue; continue;
@ -682,7 +683,7 @@ void BRDITEMS_PLOTTER::PlotDrillMarks()
for( TRACK *pts = m_board->m_Track; pts != NULL; pts = pts->Next() ) for( TRACK *pts = m_board->m_Track; pts != NULL; pts = pts->Next() )
{ {
const VIA *via = dynamic_cast<const VIA*>( pts ); const VIA* via = dyn_cast<const VIA*>( pts );
if( via ) if( via )
plotOneDrillMark( PAD_DRILL_CIRCLE, via->GetStart(), plotOneDrillMark( PAD_DRILL_CIRCLE, via->GetStart(),