2011-03-21 18:08:15 +00:00
|
|
|
/*
|
|
|
|
* This program source code file is part of KICAD, a free EDA CAD application.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2011 SoftPLC Corporation, Dick Hollenbeck <dick@softplc.com>
|
|
|
|
* Copyright (C) 2010 Kicad Developers, see change_log.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
|
|
|
|
*/
|
|
|
|
|
2010-12-27 16:49:39 +00:00
|
|
|
|
|
|
|
#ifndef SCH_PART_H_
|
|
|
|
#define SCH_PART_H_
|
|
|
|
|
|
|
|
#include <sch_lib.h>
|
2011-04-11 03:36:37 +00:00
|
|
|
#include <sch_lib_table.h>
|
|
|
|
#include <sch_lpid.h>
|
|
|
|
//#include <boost/ptr_container/ptr_vector.hpp>
|
|
|
|
#include <boost/ptr_container/ptr_map.hpp>
|
2010-12-27 16:49:39 +00:00
|
|
|
|
2011-01-01 22:56:43 +00:00
|
|
|
|
2011-04-03 00:36:10 +00:00
|
|
|
#define INTERNAL_PER_LOGICAL 10000 ///< no. internal units per logical unit
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function InternalToLogical
|
|
|
|
* converts an internal coordinate to a logical coordinate. Logical coordinates
|
|
|
|
* are defined as the standard distance between pins being equal to one.
|
|
|
|
* Internal coordinates are currently INTERNAL_PER_LOGICAL times that.
|
|
|
|
*/
|
|
|
|
static inline double InternalToLogical( int aCoord )
|
|
|
|
{
|
|
|
|
return double( aCoord ) / INTERNAL_PER_LOGICAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function LogicalToInternal
|
|
|
|
* converts a logical coordinate to an internal coordinate. Logical coordinates
|
|
|
|
* are defined as the standard distance between pins being equal to one.
|
|
|
|
* Internal coordinates are currently INTERNAL_PER_LOGICAL times that.
|
|
|
|
*/
|
|
|
|
static inline int LogicalToInternal( double aCoord )
|
|
|
|
{
|
|
|
|
return int( aCoord * INTERNAL_PER_LOGICAL );
|
|
|
|
}
|
|
|
|
|
2011-04-03 18:24:45 +00:00
|
|
|
static inline int WidthToInternal( double aWidth )
|
|
|
|
{
|
|
|
|
// sweet line widths are a "percent of a logical unit"
|
|
|
|
return LogicalToInternal( aWidth ) / 100;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline double InternalToWidth( int aWidth )
|
|
|
|
{
|
|
|
|
// sweet line widths are a "percent of a logical unit"
|
|
|
|
return InternalToLogical( aWidth ) * 100;
|
|
|
|
}
|
|
|
|
|
2011-04-18 06:26:00 +00:00
|
|
|
static inline int FontzToInternal( double aFontSize )
|
|
|
|
{
|
|
|
|
// sweet font sizes are deci-pins
|
|
|
|
return LogicalToInternal( aFontSize ) / 10;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline double InternalToFontz( int aFontSize )
|
|
|
|
{
|
|
|
|
// sweet font sizes are deci-pins
|
|
|
|
return InternalToLogical( aFontSize ) * 10;
|
|
|
|
}
|
|
|
|
|
2011-04-03 18:24:45 +00:00
|
|
|
|
2011-02-14 06:39:51 +00:00
|
|
|
//-----<temporary home for PART sub objects, move after stable>------------------
|
|
|
|
|
|
|
|
#include <wx/gdicmn.h>
|
2011-02-28 05:45:58 +00:00
|
|
|
#include <deque>
|
2011-03-20 01:59:17 +00:00
|
|
|
#include <vector>
|
2011-03-28 05:02:59 +00:00
|
|
|
#include <set>
|
2011-03-20 01:59:17 +00:00
|
|
|
#include <sweet_lexer.h>
|
|
|
|
|
2011-03-28 05:02:59 +00:00
|
|
|
class OUTPUTFORMATTER;
|
2011-03-20 01:59:17 +00:00
|
|
|
|
2011-04-03 00:36:10 +00:00
|
|
|
/// Control Bits for Format() functions
|
|
|
|
#define CTL_OMIT_NL (1<<0) ///< omit new line in Format()s.
|
|
|
|
|
2011-03-20 16:37:35 +00:00
|
|
|
namespace SCH {
|
|
|
|
|
|
|
|
class PART;
|
|
|
|
class SWEET_PARSER;
|
2011-03-27 06:07:25 +00:00
|
|
|
class PROPERTY;
|
2011-03-20 16:37:35 +00:00
|
|
|
|
2011-03-20 01:59:17 +00:00
|
|
|
class POINT : public wxPoint
|
|
|
|
{
|
|
|
|
public:
|
2011-03-20 16:37:35 +00:00
|
|
|
POINT( int x, int y ) :
|
|
|
|
wxPoint( x, y )
|
|
|
|
{}
|
|
|
|
|
|
|
|
POINT() :
|
|
|
|
wxPoint()
|
|
|
|
{}
|
2011-03-20 01:59:17 +00:00
|
|
|
};
|
|
|
|
|
2011-05-02 13:37:16 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/// a set of pin padnames that are electrically equivalent for a PART.
|
|
|
|
typedef std::set< wxString > MERGE_SET;
|
|
|
|
|
|
|
|
/// The key is the VISIBLE_PIN from
|
|
|
|
/// (pin_merge VISIBLE_PIN (hide HIDDEN_PIN1 HIDDEN_PIN2...))
|
|
|
|
typedef boost::ptr_map< wxString, MERGE_SET > MERGE_SETS;
|
|
|
|
|
2011-04-18 06:26:00 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class FONTZ
|
|
|
|
* is the size of a font, and comes with a constructor which initializes
|
|
|
|
* height and width to special values which defer font size decision to
|
|
|
|
* a higher control.
|
|
|
|
*/
|
|
|
|
class FONTZ
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
#define FONTZ_DEFAULT -1 ///< when size defers to higher control
|
|
|
|
|
|
|
|
FONTZ() :
|
|
|
|
height( FONTZ_DEFAULT ),
|
|
|
|
width( FONTZ_DEFAULT )
|
|
|
|
{}
|
|
|
|
|
|
|
|
int height;
|
|
|
|
int width;
|
|
|
|
};
|
|
|
|
|
2011-03-27 06:07:25 +00:00
|
|
|
typedef float ANGLE;
|
2011-04-18 06:26:00 +00:00
|
|
|
typedef int STROKE; ///< will be a class someday, currently only line width
|
2011-03-27 06:07:25 +00:00
|
|
|
|
2010-12-27 16:49:39 +00:00
|
|
|
|
|
|
|
namespace SCH {
|
|
|
|
|
2011-03-27 06:07:25 +00:00
|
|
|
class FONT
|
2011-03-20 16:37:35 +00:00
|
|
|
{
|
|
|
|
friend class PART;
|
|
|
|
friend class SWEET_PARSER;
|
2011-01-01 22:56:43 +00:00
|
|
|
|
2011-03-20 16:37:35 +00:00
|
|
|
protected:
|
|
|
|
wxString name; ///< name or other id such as number, TBD
|
2011-04-18 06:26:00 +00:00
|
|
|
FONTZ size;
|
|
|
|
|
2011-03-20 16:37:35 +00:00
|
|
|
bool italic;
|
|
|
|
bool bold;
|
|
|
|
|
|
|
|
public:
|
2011-03-27 06:07:25 +00:00
|
|
|
FONT() :
|
2011-03-20 16:37:35 +00:00
|
|
|
italic( false ),
|
|
|
|
bold( false )
|
|
|
|
{}
|
2011-04-03 00:36:10 +00:00
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
2011-03-20 16:37:35 +00:00
|
|
|
};
|
2011-02-14 06:39:51 +00:00
|
|
|
|
2011-03-27 06:07:25 +00:00
|
|
|
|
|
|
|
struct TEXT_EFFECTS
|
|
|
|
{
|
|
|
|
POINT pos;
|
|
|
|
ANGLE angle;
|
|
|
|
FONT font;
|
|
|
|
bool isVisible;
|
|
|
|
|
|
|
|
PROPERTY* property; ///< only used from a COMPONENT, specifies PROPERTY in PART
|
|
|
|
wxString propName; ///< only used from a COMPONENT, specifies PROPERTY in PART
|
|
|
|
|
|
|
|
TEXT_EFFECTS() :
|
|
|
|
angle( 0 ),
|
|
|
|
isVisible( false ),
|
|
|
|
property( 0 )
|
|
|
|
{}
|
2011-04-03 00:36:10 +00:00
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
2011-03-27 06:07:25 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-04-18 06:26:00 +00:00
|
|
|
#define STROKE_DEFAULT -1 ///< defer line width decision to higher control
|
|
|
|
|
|
|
|
#define FILL_TYPE_DEFAULT PR::T_none ///< fillType defaut
|
|
|
|
|
|
|
|
|
2011-03-27 06:07:25 +00:00
|
|
|
class BASE_GRAPHIC
|
2010-12-30 01:47:14 +00:00
|
|
|
{
|
2011-02-14 06:39:51 +00:00
|
|
|
friend class PART;
|
|
|
|
friend class SWEET_PARSER;
|
|
|
|
|
|
|
|
protected:
|
2011-04-11 03:36:37 +00:00
|
|
|
PART* owner;
|
|
|
|
PART* birthplace; ///< at which PART in inheritance chain was 'this' added
|
2011-02-14 06:39:51 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
BASE_GRAPHIC( PART* aOwner ) :
|
2011-04-11 03:36:37 +00:00
|
|
|
owner( aOwner ),
|
|
|
|
birthplace( aOwner )
|
2011-02-14 06:39:51 +00:00
|
|
|
{}
|
|
|
|
|
|
|
|
virtual ~BASE_GRAPHIC() {}
|
2011-03-28 05:02:59 +00:00
|
|
|
|
2011-04-03 00:36:10 +00:00
|
|
|
static const char* ShowFill( int aFillType )
|
|
|
|
{
|
|
|
|
return SWEET_LEXER::TokenName( PR::T( aFillType ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function Format
|
|
|
|
* outputs this object to @a aFormatter in s-expression form.
|
|
|
|
*/
|
|
|
|
virtual void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
2011-03-28 05:02:59 +00:00
|
|
|
throw( IO_ERROR )
|
|
|
|
{}
|
2010-12-30 01:47:14 +00:00
|
|
|
};
|
|
|
|
|
2011-02-28 05:45:58 +00:00
|
|
|
typedef std::deque<POINT> POINTS;
|
2011-01-03 17:47:08 +00:00
|
|
|
|
2011-03-20 01:59:17 +00:00
|
|
|
class POLY_LINE : public BASE_GRAPHIC
|
2010-12-30 01:47:14 +00:00
|
|
|
{
|
2011-02-14 06:39:51 +00:00
|
|
|
friend class PART;
|
|
|
|
friend class SWEET_PARSER;
|
|
|
|
|
|
|
|
protected:
|
2011-04-18 06:26:00 +00:00
|
|
|
STROKE stroke;
|
2011-02-28 05:45:58 +00:00
|
|
|
int fillType; // T_none, T_filled, or T_transparent
|
2011-02-27 08:16:05 +00:00
|
|
|
POINTS pts;
|
2011-02-14 06:39:51 +00:00
|
|
|
|
2011-04-03 00:36:10 +00:00
|
|
|
void formatContents( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
|
|
|
|
2011-02-14 06:39:51 +00:00
|
|
|
public:
|
|
|
|
POLY_LINE( PART* aOwner ) :
|
2011-04-03 00:36:10 +00:00
|
|
|
BASE_GRAPHIC( aOwner ),
|
2011-04-18 06:26:00 +00:00
|
|
|
stroke( STROKE_DEFAULT ),
|
2011-04-03 00:36:10 +00:00
|
|
|
fillType( PR::T_none )
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
2011-02-14 06:39:51 +00:00
|
|
|
};
|
|
|
|
|
2011-03-20 01:59:17 +00:00
|
|
|
class BEZIER : public POLY_LINE
|
2011-02-28 05:45:58 +00:00
|
|
|
{
|
|
|
|
friend class PART;
|
|
|
|
friend class SWEET_PARSER;
|
|
|
|
|
|
|
|
public:
|
|
|
|
BEZIER( PART* aOwner ) :
|
|
|
|
POLY_LINE( aOwner )
|
2011-04-03 00:36:10 +00:00
|
|
|
{
|
2011-04-18 06:26:00 +00:00
|
|
|
stroke = STROKE_DEFAULT;
|
2011-04-03 00:36:10 +00:00
|
|
|
fillType = PR::T_none;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
2011-02-28 05:45:58 +00:00
|
|
|
};
|
2011-02-14 06:39:51 +00:00
|
|
|
|
2011-03-20 01:59:17 +00:00
|
|
|
class RECTANGLE : public BASE_GRAPHIC
|
2011-02-27 08:16:05 +00:00
|
|
|
{
|
|
|
|
friend class PART;
|
|
|
|
friend class SWEET_PARSER;
|
|
|
|
|
|
|
|
protected:
|
2011-04-18 06:26:00 +00:00
|
|
|
STROKE stroke;
|
2011-02-27 08:16:05 +00:00
|
|
|
int fillType; // T_none, T_filled, or T_transparent
|
|
|
|
POINT start;
|
|
|
|
POINT end;
|
|
|
|
|
|
|
|
public:
|
|
|
|
RECTANGLE( PART* aOwner ) :
|
2011-04-03 00:36:10 +00:00
|
|
|
BASE_GRAPHIC( aOwner ),
|
2011-04-18 06:26:00 +00:00
|
|
|
stroke( STROKE_DEFAULT ),
|
|
|
|
fillType( FILL_TYPE_DEFAULT )
|
2011-04-03 00:36:10 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
2011-02-27 08:16:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-03-20 01:59:17 +00:00
|
|
|
class CIRCLE : public BASE_GRAPHIC
|
2011-02-27 08:16:05 +00:00
|
|
|
{
|
|
|
|
friend class PART;
|
|
|
|
friend class SWEET_PARSER;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
POINT center;
|
|
|
|
int radius;
|
2011-04-18 06:26:00 +00:00
|
|
|
STROKE stroke;
|
2011-03-20 01:59:17 +00:00
|
|
|
int fillType; // T_none, T_filled, or T_transparent
|
2011-02-27 08:16:05 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
CIRCLE( PART* aOwner ) :
|
2011-04-03 00:36:10 +00:00
|
|
|
BASE_GRAPHIC( aOwner ),
|
|
|
|
radius( LogicalToInternal( 0.5 ) ),
|
2011-04-18 06:26:00 +00:00
|
|
|
stroke( STROKE_DEFAULT ),
|
|
|
|
fillType( FILL_TYPE_DEFAULT )
|
2011-04-03 00:36:10 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
2011-02-27 08:16:05 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-03-20 01:59:17 +00:00
|
|
|
class ARC : public BASE_GRAPHIC
|
2011-02-27 08:16:05 +00:00
|
|
|
{
|
|
|
|
friend class PART;
|
|
|
|
friend class SWEET_PARSER;
|
|
|
|
|
|
|
|
protected:
|
2011-03-20 01:59:17 +00:00
|
|
|
POINT pos;
|
2011-04-18 06:26:00 +00:00
|
|
|
STROKE stroke;
|
2011-02-27 08:16:05 +00:00
|
|
|
int fillType; // T_none, T_filled, or T_transparent
|
|
|
|
int radius;
|
|
|
|
POINT start;
|
|
|
|
POINT end;
|
|
|
|
|
|
|
|
public:
|
|
|
|
ARC( PART* aOwner ) :
|
2011-04-03 00:36:10 +00:00
|
|
|
BASE_GRAPHIC( aOwner ),
|
2011-04-18 06:26:00 +00:00
|
|
|
stroke( STROKE_DEFAULT ),
|
|
|
|
fillType( FILL_TYPE_DEFAULT ),
|
2011-04-03 00:36:10 +00:00
|
|
|
radius( LogicalToInternal( 0.5 ) )
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
2011-02-14 06:39:51 +00:00
|
|
|
};
|
|
|
|
|
2011-02-28 05:45:58 +00:00
|
|
|
|
2011-03-20 01:59:17 +00:00
|
|
|
class GR_TEXT : public BASE_GRAPHIC
|
2011-02-28 05:45:58 +00:00
|
|
|
{
|
|
|
|
friend class PART;
|
|
|
|
friend class SWEET_PARSER;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
POINT pos;
|
2011-03-27 06:07:25 +00:00
|
|
|
ANGLE angle;
|
|
|
|
|
2011-03-20 01:59:17 +00:00
|
|
|
int fillType; ///< T_none, T_filled, or T_transparent
|
2011-04-18 06:26:00 +00:00
|
|
|
|
2011-03-20 01:59:17 +00:00
|
|
|
int hjustify; ///< T_center, T_right, or T_left
|
|
|
|
int vjustify; ///< T_center, T_top, or T_bottom
|
2011-03-27 06:07:25 +00:00
|
|
|
|
2011-02-28 05:45:58 +00:00
|
|
|
bool isVisible;
|
|
|
|
wxString text;
|
2011-03-27 06:07:25 +00:00
|
|
|
FONT font;
|
2011-02-28 05:45:58 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
GR_TEXT( PART* aOwner ) :
|
2011-03-20 01:59:17 +00:00
|
|
|
BASE_GRAPHIC( aOwner ),
|
2011-02-28 05:45:58 +00:00
|
|
|
angle( 0 ),
|
2011-03-20 01:59:17 +00:00
|
|
|
fillType( PR::T_filled ),
|
|
|
|
hjustify( PR::T_left ),
|
|
|
|
vjustify( PR::T_bottom ),
|
|
|
|
isVisible( true )
|
|
|
|
{}
|
2011-04-03 00:36:10 +00:00
|
|
|
|
|
|
|
static const char* ShowJustify( int aJustify )
|
|
|
|
{
|
|
|
|
return SWEET_LEXER::TokenName( PR::T( aJustify ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
2011-03-20 01:59:17 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-03-27 06:07:25 +00:00
|
|
|
class PROPERTY : public BASE_GRAPHIC
|
2011-03-20 01:59:17 +00:00
|
|
|
{
|
|
|
|
friend class PART;
|
|
|
|
friend class SWEET_PARSER;
|
|
|
|
|
|
|
|
protected:
|
2011-03-27 06:07:25 +00:00
|
|
|
wxString name;
|
|
|
|
wxString text;
|
2011-04-03 00:36:10 +00:00
|
|
|
TEXT_EFFECTS* effects;
|
|
|
|
|
|
|
|
void clear()
|
|
|
|
{
|
|
|
|
delete effects;
|
|
|
|
effects = 0;
|
|
|
|
|
|
|
|
name = wxEmptyString;
|
|
|
|
text = wxEmptyString;
|
|
|
|
}
|
2011-03-27 06:07:25 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
PROPERTY( PART* aOwner, const wxChar* aName = wxT( "" ) ) :
|
|
|
|
BASE_GRAPHIC( aOwner ),
|
2011-04-03 00:36:10 +00:00
|
|
|
name( aName ),
|
|
|
|
effects( 0 )
|
2011-03-27 06:07:25 +00:00
|
|
|
{}
|
2011-04-03 00:36:10 +00:00
|
|
|
|
|
|
|
~PROPERTY()
|
|
|
|
{
|
|
|
|
clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function Effects
|
|
|
|
* returns a pointer to the TEXT_EFFECTS object for this PROPERTY, and optionally
|
|
|
|
* will lazily allocate one if it did not exist previously.
|
|
|
|
* @param doAlloc if true, means do an allocation of a new TEXT_EFFECTS if one
|
|
|
|
* currently does not exist, otherwise return NULL if non-existent.
|
|
|
|
*/
|
|
|
|
TEXT_EFFECTS* EffectsLookup();
|
|
|
|
TEXT_EFFECTS* Effects() const
|
|
|
|
{
|
|
|
|
return effects;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
2011-03-27 06:07:25 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
struct PINTEXT
|
|
|
|
{
|
|
|
|
wxString text;
|
|
|
|
FONT font;
|
|
|
|
bool isVisible;
|
|
|
|
|
|
|
|
PINTEXT() :
|
|
|
|
isVisible( true )
|
|
|
|
{}
|
2011-04-03 00:36:10 +00:00
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, const char* aElement, int aNestLevel, int aControlBits ) const
|
|
|
|
throw( IO_ERROR );
|
2011-03-27 06:07:25 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-04-18 06:26:00 +00:00
|
|
|
#define PIN_LEN_DEFAULT -1 ///< use standard pin length for given type
|
|
|
|
#define PIN_SHAPE_DEFAULT PR::T_line ///< use standard pin shape
|
|
|
|
#define PIN_CONN_DEFAULT PR::T_in ///< use standard pin connection type
|
|
|
|
|
2011-03-27 06:07:25 +00:00
|
|
|
class PIN : public BASE_GRAPHIC
|
|
|
|
{
|
|
|
|
friend class PART;
|
|
|
|
friend class SWEET_PARSER;
|
2011-03-20 01:59:17 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
PIN( PART* aOwner ) :
|
|
|
|
BASE_GRAPHIC( aOwner ),
|
|
|
|
angle( 0 ),
|
2011-04-18 06:26:00 +00:00
|
|
|
connectionType( PIN_CONN_DEFAULT ),
|
|
|
|
shape( PIN_SHAPE_DEFAULT ),
|
|
|
|
length( PIN_LEN_DEFAULT ),
|
2011-02-28 05:45:58 +00:00
|
|
|
isVisible( true )
|
|
|
|
{}
|
2011-03-27 06:07:25 +00:00
|
|
|
|
2011-04-11 03:36:37 +00:00
|
|
|
~PIN();
|
|
|
|
|
2011-04-03 00:36:10 +00:00
|
|
|
const char* ShowType() const
|
|
|
|
{
|
|
|
|
return SWEET_LEXER::TokenName( PR::T( connectionType ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
const char* ShowShape() const
|
|
|
|
{
|
|
|
|
return SWEET_LEXER::TokenName( PR::T( shape ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits ) const
|
2011-03-28 05:02:59 +00:00
|
|
|
throw( IO_ERROR );
|
|
|
|
|
2011-03-27 06:07:25 +00:00
|
|
|
protected:
|
|
|
|
POINT pos;
|
|
|
|
ANGLE angle;
|
|
|
|
|
2011-04-18 06:26:00 +00:00
|
|
|
PINTEXT pad;
|
2011-03-27 06:07:25 +00:00
|
|
|
PINTEXT signal;
|
|
|
|
|
2011-04-18 06:26:00 +00:00
|
|
|
int connectionType; ///< T_in, T_out, T_inout, T_tristate, T_passive, T_unspecified,
|
2011-03-27 06:07:25 +00:00
|
|
|
///< T_power_in, T_power_out, T_open_collector, T_open_emitter, or T_unconnected.
|
|
|
|
|
|
|
|
int shape; ///< T_none, T_line, T_inverted, T_clock, T_inverted_clk, T_input_low, T_clock_low,
|
|
|
|
///< T_falling_edge, T_non_logic.
|
|
|
|
|
|
|
|
int length; ///< length of pin in internal units
|
|
|
|
bool isVisible; ///< pin is visible
|
|
|
|
|
2011-04-18 06:26:00 +00:00
|
|
|
wxString pin_merge; ///< pad of (pin_merge ...) that I am a member of, else empty if none
|
2011-04-11 03:36:37 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class PART_REF
|
|
|
|
* is an LPID with a pointer to the "looked up" PART, which is looked up lazily.
|
|
|
|
*/
|
|
|
|
class PART_REF : public LPID
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
PART_REF() :
|
|
|
|
LPID(),
|
|
|
|
part(0)
|
|
|
|
{}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Constructor LPID
|
|
|
|
* takes aLPID string and parses it. A typical LPID string uses a logical
|
|
|
|
* library name followed by a part name.
|
|
|
|
* e.g.: "kicad:passives/R/rev2", or
|
|
|
|
* e.g.: "mylib:R33"
|
|
|
|
*/
|
|
|
|
PART_REF( const STRING& aLPID ) throw( PARSE_ERROR ) :
|
|
|
|
LPID( aLPID ),
|
|
|
|
part(0)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function Lookup
|
|
|
|
* returns the PART that this LPID refers to. Never returns NULL, because
|
|
|
|
* instead an exception would be thrown.
|
|
|
|
* @throw IO_ERROR if any problem occurs or if the part cannot be found.
|
|
|
|
*/
|
|
|
|
PART* Lookup( LIB_TABLE* aLibTable, LIB* aFallBackLib ) throw( IO_ERROR )
|
|
|
|
{
|
|
|
|
if( !part )
|
|
|
|
{
|
|
|
|
part = aLibTable->LookupPart( *this, aFallBackLib );
|
|
|
|
}
|
|
|
|
return part;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected:
|
|
|
|
PART* part; ///< The looked-up PART,
|
|
|
|
///< no ownership (duh, PARTs are always owned by a LIB)
|
2011-02-28 05:45:58 +00:00
|
|
|
};
|
|
|
|
|
2011-04-11 03:36:37 +00:00
|
|
|
typedef std::vector<PART_REF> PART_REFS;
|
|
|
|
|
2011-03-20 16:37:35 +00:00
|
|
|
|
2011-02-27 08:16:05 +00:00
|
|
|
} // namespace SCH
|
|
|
|
|
2011-02-14 06:39:51 +00:00
|
|
|
|
|
|
|
//-----</temporary home for PART sub objects, move after stable>-----------------
|
|
|
|
|
|
|
|
|
2011-04-11 03:36:37 +00:00
|
|
|
typedef std::set< wxString > KEYWORDS;
|
|
|
|
|
2011-02-14 06:39:51 +00:00
|
|
|
namespace SCH {
|
|
|
|
|
2011-03-20 01:59:17 +00:00
|
|
|
typedef std::vector< BASE_GRAPHIC* > GRAPHICS;
|
2011-03-27 06:07:25 +00:00
|
|
|
typedef std::vector< PROPERTY* > PROPERTIES;
|
2011-04-11 03:36:37 +00:00
|
|
|
|
|
|
|
typedef std::vector< PIN* > PINS;
|
2011-04-18 06:26:00 +00:00
|
|
|
typedef std::vector< PIN* > PIN_LIST; ///< no ownership, used for searches
|
2011-04-11 03:36:37 +00:00
|
|
|
|
2011-02-14 06:39:51 +00:00
|
|
|
|
|
|
|
class LPID;
|
|
|
|
class SWEET_PARSER;
|
2010-12-30 01:47:14 +00:00
|
|
|
|
|
|
|
|
2010-12-27 16:49:39 +00:00
|
|
|
/**
|
|
|
|
* Class PART
|
|
|
|
* will have to be unified with what Wayne is doing. I want a separate copy
|
|
|
|
|
|
|
|
* here until I can get the state management correct. Since a PART only lives
|
|
|
|
* within a cache called a LIB, its constructor is private (only a LIB
|
|
|
|
* can instantiate one), and it exists in various states of freshness and
|
|
|
|
* completeness relative to the LIB_SOURCE within the LIB.
|
|
|
|
*/
|
|
|
|
class PART
|
|
|
|
{
|
2011-01-01 22:56:43 +00:00
|
|
|
friend class LIB; // is the owner of all PARTS, afterall
|
2011-02-14 06:39:51 +00:00
|
|
|
friend class SWEET_PARSER;
|
2010-12-27 16:49:39 +00:00
|
|
|
|
2011-04-03 00:36:10 +00:00
|
|
|
public:
|
2010-12-27 16:49:39 +00:00
|
|
|
|
2011-02-28 05:45:58 +00:00
|
|
|
/**
|
2011-04-03 00:36:10 +00:00
|
|
|
* Enum PROP_ID
|
|
|
|
* is the set of "mandatory" properties within a PART. These are used by
|
|
|
|
* class PART as array indices into PART::mandatory[].
|
2011-02-28 05:45:58 +00:00
|
|
|
*/
|
2011-04-03 00:36:10 +00:00
|
|
|
enum PROP_ID
|
|
|
|
{
|
|
|
|
REFERENCE, ///< reference prefix, a template for instantiation at COMPONENT level
|
|
|
|
VALUE, ///< value, e.g. "3.3K"
|
|
|
|
FOOTPRINT, ///< name of PCB module, e.g. "16DIP300"
|
|
|
|
DATASHEET, ///< URI of datasheet
|
|
|
|
MODEL, ///< spice model name
|
|
|
|
END ///< array sentinel, not a valid index
|
|
|
|
};
|
2010-12-27 16:49:39 +00:00
|
|
|
|
2011-02-14 06:39:51 +00:00
|
|
|
virtual ~PART();
|
2011-01-01 22:56:43 +00:00
|
|
|
|
2011-03-28 05:02:59 +00:00
|
|
|
PART& operator = ( const PART& other );
|
2010-12-27 16:49:39 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function Owner
|
|
|
|
* returns the LIB* owner of this part.
|
|
|
|
*/
|
|
|
|
LIB* Owner() { return owner; }
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function Parse
|
2010-12-30 01:47:14 +00:00
|
|
|
* translates a Sweet string into a binary form that is represented
|
2010-12-27 16:49:39 +00:00
|
|
|
* by the normal fields of this class. Parse is expected to call Inherit()
|
|
|
|
* if this part extends any other.
|
2010-12-30 01:47:14 +00:00
|
|
|
*
|
2011-02-14 06:39:51 +00:00
|
|
|
* @param aParser is an instance of SWEET_PARSER, rewound at the first line.
|
2010-12-30 01:47:14 +00:00
|
|
|
*
|
2011-01-04 18:53:11 +00:00
|
|
|
* @param aLibTable is the LIB_TABLE "view" that is in effect for inheritance,
|
2010-12-30 01:47:14 +00:00
|
|
|
* and comes from the big containing SCHEMATIC object.
|
2010-12-27 16:49:39 +00:00
|
|
|
*/
|
2011-02-14 06:39:51 +00:00
|
|
|
void Parse( SWEET_PARSER* aParser, LIB_TABLE* aLibTable ) throw( IO_ERROR, PARSE_ERROR );
|
2010-12-27 16:49:39 +00:00
|
|
|
|
2011-03-28 05:02:59 +00:00
|
|
|
/**
|
|
|
|
* Function Format
|
|
|
|
* outputs this PART in UTF8 encoded s-expression format to @a aFormatter.
|
|
|
|
* @param aFormatter is the output sink to write to.
|
|
|
|
* @param aNestLevel is the initial indent level
|
|
|
|
* @param aControlBits are bit flags ORed together which control how the output
|
|
|
|
* is done.
|
|
|
|
*/
|
|
|
|
void Format( OUTPUTFORMATTER* aFormatter, int aNestLevel, int aControlBits = 0 ) const
|
|
|
|
throw( IO_ERROR );
|
|
|
|
|
2011-04-11 03:36:37 +00:00
|
|
|
/**
|
|
|
|
* Function PropertyDelete
|
|
|
|
* deletes the property with aPropertyName if found and returns true, else false
|
|
|
|
* if not found.
|
|
|
|
*/
|
|
|
|
bool PropertyDelete( const wxString& aPropertyName );
|
2011-03-28 05:02:59 +00:00
|
|
|
|
2011-04-03 00:36:10 +00:00
|
|
|
/**
|
|
|
|
* Function Field
|
|
|
|
* returns a pointer to one of the mandatory properties, or NULL
|
|
|
|
* if non-existent. Use FieldLookup() to potentially allocate it.
|
|
|
|
*/
|
|
|
|
PROPERTY* Field( PROP_ID aPropertyId ) const
|
|
|
|
{
|
|
|
|
wxASSERT( unsigned(aPropertyId) < unsigned(END) );
|
|
|
|
return mandatory[aPropertyId];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function FieldLookup
|
|
|
|
* returns a pointer to one of the mandatory properties, which is lazily
|
|
|
|
* constructed by this function if need be.
|
|
|
|
* @param aPropertyId tells which field.
|
|
|
|
*/
|
|
|
|
PROPERTY* FieldLookup( PROP_ID aPropertyId );
|
2011-03-28 05:02:59 +00:00
|
|
|
|
2011-04-11 03:36:37 +00:00
|
|
|
/**
|
2011-04-18 06:26:00 +00:00
|
|
|
* Function PinFindByPad
|
|
|
|
* finds a PIN based on aPad or returns NULL if not found.
|
|
|
|
* @param aPad is the pin to find
|
2011-04-11 03:36:37 +00:00
|
|
|
* @return PIN* - the found PIN or NULL if not found.
|
|
|
|
*/
|
2011-04-18 06:26:00 +00:00
|
|
|
PIN* PinFindByPad( const wxString& aPad )
|
2011-04-11 03:36:37 +00:00
|
|
|
{
|
2011-04-18 06:26:00 +00:00
|
|
|
PINS::iterator it = pinFindByPad( aPad );
|
2011-04-11 03:36:37 +00:00
|
|
|
return it != pins.end() ? *it : NULL;
|
|
|
|
}
|
|
|
|
|
2011-04-18 06:26:00 +00:00
|
|
|
/**
|
|
|
|
* Function PinsFindBySignal
|
|
|
|
* fetches all the pins matching aSignal into aResults.
|
|
|
|
*/
|
|
|
|
void PinsFindBySignal( PIN_LIST* aResults, const wxString& aSignal );
|
2011-04-11 03:36:37 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function PinDelete
|
2011-04-18 06:26:00 +00:00
|
|
|
* deletes the pin with aPad if found and returns true, else false
|
2011-04-11 03:36:37 +00:00
|
|
|
* if not found.
|
|
|
|
*/
|
2011-04-18 06:26:00 +00:00
|
|
|
bool PinDelete( const wxString& aPad );
|
2011-04-11 03:36:37 +00:00
|
|
|
|
2011-03-28 05:02:59 +00:00
|
|
|
|
2011-03-27 06:07:25 +00:00
|
|
|
/*
|
2011-02-27 08:16:05 +00:00
|
|
|
void SetValue( const wxString& aValue )
|
|
|
|
{
|
|
|
|
value = aValue;
|
|
|
|
}
|
|
|
|
const wxString& GetValue()
|
|
|
|
{
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetFootprint( const wxString& aFootprint )
|
|
|
|
{
|
|
|
|
footprint = aFootprint;
|
|
|
|
}
|
|
|
|
const wxString& GetFootprint()
|
|
|
|
{
|
|
|
|
return footprint;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetModel( const wxString& aModel )
|
|
|
|
{
|
|
|
|
model = aModel;
|
|
|
|
}
|
|
|
|
const wxString& GetModel()
|
|
|
|
{
|
|
|
|
return model;
|
|
|
|
}
|
2011-03-27 06:07:25 +00:00
|
|
|
*/
|
2011-02-27 08:16:05 +00:00
|
|
|
|
2010-12-30 01:47:14 +00:00
|
|
|
/*
|
|
|
|
void SetBody( const STR_UTF& aSExpression )
|
|
|
|
{
|
|
|
|
body = aSExpression;
|
|
|
|
}
|
|
|
|
*/
|
2011-04-03 00:36:10 +00:00
|
|
|
|
|
|
|
|
|
|
|
protected: // not likely to have C++ descendants, but protected none-the-less.
|
|
|
|
|
|
|
|
/// a protected constructor, only a LIB can instantiate a PART.
|
|
|
|
PART( LIB* aOwner, const STRING& aPartNameAndRev );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function destroy
|
|
|
|
* clears out this object, deleting everything that this PART owns and
|
|
|
|
* initializing values back to a state as if the object was just constructed
|
|
|
|
* empty.
|
|
|
|
*/
|
|
|
|
void clear();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function inherit
|
|
|
|
* is a specialized assignment function that copies a specific subset, enough
|
|
|
|
* to fulfill the requirements of the Sweet s-expression language.
|
|
|
|
*/
|
|
|
|
void inherit( const PART& aBasePart );
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function propertyFind
|
|
|
|
* searches for aPropertyName and returns a PROPERTIES::iterator which
|
|
|
|
* is the found item or properties.end() if not found.
|
|
|
|
*/
|
|
|
|
PROPERTIES::iterator propertyFind( const wxString& aPropertyName );
|
|
|
|
|
2011-04-11 03:36:37 +00:00
|
|
|
/**
|
2011-04-18 06:26:00 +00:00
|
|
|
* Function pinFindByPad
|
|
|
|
* searches for a PIN with aPad and returns a PROPERTIES::iterator which
|
2011-04-11 03:36:37 +00:00
|
|
|
* is the found item or pins.end() if not found.
|
|
|
|
*/
|
2011-04-18 06:26:00 +00:00
|
|
|
PINS::iterator pinFindByPad( const wxString& aPad );
|
2011-04-11 03:36:37 +00:00
|
|
|
|
2011-04-03 00:36:10 +00:00
|
|
|
POINT anchor;
|
|
|
|
|
|
|
|
//PART( LIB* aOwner );
|
|
|
|
|
|
|
|
LIB* owner; ///< which LIB am I a part of (pun if you want)
|
|
|
|
int contains; ///< has bits from Enum PartParts
|
|
|
|
|
|
|
|
STRING partNameAndRev; ///< example "passives/R[/revN..]", immutable.
|
|
|
|
|
|
|
|
LPID* extends; ///< of base part, NULL if none, otherwise I own it.
|
|
|
|
PART* base; ///< which PART am I extending, if any. no ownership.
|
|
|
|
|
|
|
|
/// encapsulate the old version deletion, take ownership of @a aLPID
|
|
|
|
void setExtends( LPID* aLPID );
|
|
|
|
|
|
|
|
/// s-expression text for the part, initially empty, and read in as this part
|
|
|
|
/// actually becomes cached in RAM.
|
|
|
|
STRING body;
|
|
|
|
|
2011-04-11 03:36:37 +00:00
|
|
|
/// mandatory properties, aka fields. Index into mandatory[] is PROP_ID.
|
2011-04-03 00:36:10 +00:00
|
|
|
PROPERTY* mandatory[END];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Member properties
|
|
|
|
* holds the non-mandatory properties.
|
|
|
|
*/
|
|
|
|
PROPERTIES properties;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Member graphics
|
|
|
|
* owns : POLY_LINE, RECTANGLE, CIRCLE, ARC, BEZIER, and GR_TEXT objects.
|
|
|
|
*/
|
|
|
|
GRAPHICS graphics;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Member pins
|
|
|
|
* owns all the PINs in pins.
|
|
|
|
*/
|
|
|
|
PINS pins;
|
|
|
|
|
|
|
|
/// Alternate body forms.
|
2011-04-11 03:36:37 +00:00
|
|
|
PART_REFS alternates;
|
2011-04-03 00:36:10 +00:00
|
|
|
|
2011-04-11 03:36:37 +00:00
|
|
|
/// searching aids
|
2011-04-03 00:36:10 +00:00
|
|
|
KEYWORDS keywords;
|
|
|
|
|
2011-04-11 03:36:37 +00:00
|
|
|
/**
|
|
|
|
* A pin_merge set is a set of pins that are all electrically equivalent
|
|
|
|
* and whose anchor pin is the only one visible. The visible pin is the
|
|
|
|
* key in the MERGE_SETS boost::ptr_map::map
|
|
|
|
*/
|
|
|
|
MERGE_SETS pin_merges;
|
2010-12-27 16:49:39 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace PART
|
|
|
|
|
|
|
|
#endif // SCH_PART_
|