30#include <boost/ptr_container/ptr_vector.hpp>
33#include <boost/ptr_container/ptr_set.hpp>
35#include <specctra_import_export/specctra_lexer.h>
121 return x==other.
x &&
y==other.
y;
126 return !( *
this == other );
167 out->
Print( nestLevel,
" %.6g %.6g",
x,
y );
189 out->
Print( nestLevel,
"(%s%s%s %s%s%s)\n",
190 quoteName,
name.c_str(), quoteName,
191 quoteValue,
value.c_str(), quoteValue );
215 const char*
Name()
const;
272 return sf.GetString();
296 ELEM( aType, aParent )
327 kids.push_back( aElem );
332 ELEM_ARRAY::auto_type ret =
kids.replace( aIndex, aElem );
333 return ret.release();
338 ELEM_ARRAY::auto_type ret =
kids.release(
kids.begin() + aIndex );
339 return ret.release();
416 ELEM( aType, aParent )
446 ELEM( T_rect, aParent )
469 const char* newline = nestLevel ?
"\n" :
"";
473 out->
Print( nestLevel,
"(%s %s%s%s %.6g %.6g %.6g %.6g)%s",
499 ELEM( aType, aParent )
517 out->
Print( 0,
"\n" );
520 for(
const std::string& rule :
m_rules )
521 out->
Print( nestLevel+1,
"%s\n", rule.c_str() );
523 out->
Print( nestLevel,
")" );
526 if( nestLevel || !singleLine )
527 out->
Print( 0,
"\n" );
542 ELEM( T_layer_rule, aParent )
559 out->
Print( 0,
" %s%s%s", quote, layer.c_str(), quote );
562 out->
Print( 0 ,
"\n" );
565 m_rule->Format( out, nestLevel+1 );
567 out->
Print( nestLevel,
")\n" );
587 ELEM( aType, aParent )
595 points.push_back( aPoint );
612 const char* newline = nestLevel ?
"\n" :
"";
616 const int RIGHTMARGIN = 70;
617 int perLine = out->
Print( nestLevel,
"(%s %s%s%s %.6g",
622 int wrapNest = std::max( nestLevel+1, 6 );
626 if( perLine > RIGHTMARGIN )
628 out->
Print( 0,
"\n" );
629 perLine = out->
Print( wrapNest,
"%s",
"" );
633 perLine += out->
Print( 0,
" " );
636 perLine += out->
Print( 0,
"%.6g %.6g", pt.x, pt.y );
641 out->
Print( 0,
"(aperture_type square)" );
644 out->
Print( 0,
")%s", newline );
657typedef boost::ptr_vector<PATH>
PATHS;
665 ELEM( aType, aParent )
682 aBuffer.push_back(
rectangle->GetOrigin().x );
683 aBuffer.push_back(
rectangle->GetOrigin().y );
685 aBuffer.push_back(
rectangle->GetOrigin().x );
686 aBuffer.push_back(
rectangle->GetEnd().y );
688 aBuffer.push_back(
rectangle->GetEnd().x );
689 aBuffer.push_back(
rectangle->GetEnd().y );
691 aBuffer.push_back(
rectangle->GetEnd().x );
692 aBuffer.push_back(
rectangle->GetOrigin().y );
698 for(
const POINT& pt :
path.GetPoints() )
700 aBuffer.push_back( pt.x );
701 aBuffer.push_back( pt.y );
710 out->
Print( nestLevel,
"(%s\n",
Name() );
717 path.Format( out, nestLevel+1 );
720 out->
Print( nestLevel,
")\n" );
736 ELEM( T_circle, aParent )
743 const char* newline = nestLevel ?
"\n" :
"";
751 out->
Print( 0,
")%s", newline );
783 ELEM( T_qarc, aParent )
790 const char* newline = nestLevel ?
"\n" :
"";
793 out->
Print( nestLevel,
"(%s %s%s%s %.6g",
Name(), quote,
layer_id.c_str(), quote,
797 out->
Print( 0,
" %.6g %.6g", pt.x, pt.y );
799 out->
Print( 0,
")%s", newline );
812 vertex[0].FixNegativeZero();
820 vertex[1].FixNegativeZero();
828 vertex[2].FixNegativeZero();
845 ELEM( aType, aParent )
862 wxASSERT( aShape->
Type()==T_rect
863 || aShape->
Type()==T_circle
864 || aShape->
Type()==T_qarc
865 || aShape->
Type()==T_path
866 || aShape->
Type()==T_polygon);
877 shape->Format( out, 0 );
879 out->
Print( 0,
")\n" );
909 ELEM( aType, aParent )
932 wxASSERT( aShape->
Type()==T_rect
933 || aShape->
Type()==T_circle
934 || aShape->
Type()==T_qarc
935 || aShape->
Type()==T_path
936 || aShape->
Type()==T_polygon);
950 const char* newline =
"\n";
957 out->
Print( 0,
" %s%s%s", quote,
m_name.c_str(), quote );
963 out->
Print( 0,
" \"\"" );
972 out->
Print( 0,
" " );
978 out->
Print( 0,
"%s", newline );
980 m_rules->Format( out, nestLevel+1 );
985 out->
Print( 0,
"%s", newline );
992 out->
Print( 0,
"%s", newline );
996 window.Format( out, nestLevel+1 );
998 out->
Print( nestLevel,
")\n" );
1002 out->
Print( 0,
")\n" );
1036 ELEM( T_via, aParent )
1047 const int RIGHTMARGIN = 80;
1048 int perLine = out->
Print( nestLevel,
"(%s",
Name() );
1052 if( perLine > RIGHTMARGIN )
1054 out->
Print( 0,
"\n" );
1055 perLine = out->
Print( nestLevel+1,
"%s",
"");
1058 const char* quote = out->
GetQuoteChar( padstack.c_str() );
1059 perLine += out->
Print( 0,
" %s%s%s", quote, padstack.c_str(), quote );
1064 out->
Print( 0,
"\n" );
1066 perLine = out->
Print( nestLevel+1,
"(spare" );
1068 for(
const std::string& spare :
m_spares )
1070 if( perLine > RIGHTMARGIN )
1072 out->
Print( 0,
"\n" );
1073 perLine = out->
Print( nestLevel+2,
"%s",
"");
1076 const char* quote = out->
GetQuoteChar( spare.c_str() );
1077 perLine += out->
Print( 0,
" %s%s%s", quote, spare.c_str(), quote );
1080 out->
Print( 0,
")" );
1083 out->
Print( 0,
")\n" );
1098 ELEM( T_classes, aParent )
1104 for(
const std::string& class_id :
class_ids )
1106 const char* quote = out->
GetQuoteChar( class_id.c_str() );
1107 out->
Print( nestLevel,
"%s%s%s\n", quote, class_id.c_str(), quote );
1140 classes->Format( out, nestLevel );
1171 out->
Print( nestLevel,
"(%s\n",
Name() );
1173 out->
Print( nestLevel+1,
"(via_at_smd %s",
via_at_smd ?
"on" :
"off" );
1178 out->
Print( 0,
")\n" );
1180 for(
int i = 0; i <
Length(); ++i )
1183 out->
Print( nestLevel,
")\n" );
1198 ELEM( T_layer, aParent )
1217 out->
Print( nestLevel,
"(%s %s%s%s\n",
Name(), quote,
name.c_str(), quote );
1223 out->
Print( nestLevel+1,
"(property\n" );
1226 property.Format( out, nestLevel+2 );
1228 out->
Print( nestLevel+1,
")\n" );
1235 rules->Format( out, nestLevel+1 );
1241 out->
Print( nestLevel+1,
"(cost %d", -
cost );
1248 out->
Print( 0,
")\n" );
1253 out->
Print( nestLevel+1,
"(use_net" );
1255 for(
const std::string& net :
use_net )
1258 out->
Print( 0,
" %s%s%s", quote, net.c_str(), quote );
1261 out->
Print( 0,
")\n" );
1264 out->
Print( nestLevel,
")\n" );
1288 ELEM( T_layer_pair, aParent )
1298 out->
Print( nestLevel,
"(%s %s%s%s %s%s%s %.6g)\n",
1326 ELEM( T_layer_noise_weight, aParent )
1332 out->
Print( nestLevel,
"(%s\n",
Name() );
1335 pair.Format( out, nestLevel+1 );
1337 out->
Print( nestLevel,
")\n" );
1368 ELEM( aType, aParent )
1395 ELEM( aType, aParent )
1403 out->
Print( nestLevel,
"(%s %s%s%s)\n",
1405 quote,
value.c_str(), quote );
1450 m_rules->Format( out, nestLevel );
1475 ELEM( T_grid, aParent )
1502 out->
Print( 0,
")\n");
1520 ELEM( T_structure_out, aParent )
1533 layer.Format( out, nestLevel );
1536 m_rules->Format( out, nestLevel );
1596 m_unit->Format( out, nestLevel );
1599 layer.Format( out, nestLevel );
1611 plane.Format( out, nestLevel );
1614 region.Format( out, nestLevel );
1617 keepout.Format( out, nestLevel );
1620 m_via->Format( out, nestLevel );
1625 for(
int i=0; i<
Length(); ++i )
1631 m_rules->Format( out, nestLevel );
1637 grid.Format( out, nestLevel );
1680 ELEM( T_place, aParent )
1758 ELEM( T_component, aParent )
1781 out->
Print( nestLevel,
")\n" );
1787 place.Format( out, nestLevel );
1804 ELEM( T_placement, aParent )
1827 if( component.GetImageId().compare( imageName ) == 0 )
1840 m_unit->Format( out, nestLevel );
1848 m_component.Format( out, nestLevel );
1894 out->
Print( nestLevel,
"(%s ",
Name() );
1897 shape->Format( out, 0 );
1904 out->
Print( 0,
"\n" );
1907 window.Format( out, nestLevel+1 );
1909 out->
Print( nestLevel,
")\n" );
1913 out->
Print( 0,
")\n" );
1939 ELEM( T_pin, aParent )
2024 const char* quote = out->
GetQuoteChar( imageId.c_str() );
2026 out->
Print( nestLevel,
"(%s %s%s%s",
Name(), quote, imageId.c_str(), quote );
2030 out->
Print( nestLevel,
")\n" );
2039 out->
Print( 0,
"\n");
2042 m_unit->Format( out, nestLevel );
2048 pin.Format( out, nestLevel );
2051 m_rules->Format( out, nestLevel );
2057 keepout.Format( out, nestLevel );
2144 out->
Print( nestLevel,
")\n" );
2151 m_unit->Format( out, nestLevel );
2156 out->
Print( nestLevel,
"%s",
"" );
2162 out->
Print( 0,
"(attach off)" );
2168 out->
Print( 0,
"(attach on (use_via %s%s%s))", quote,
m_via_id.c_str(), quote );
2177 out->
Print( 0,
"\n" );
2180 m_rules->Format( out, nestLevel );
2230 ELEM( aType, aParent )
2267 for( i = 0; i <
m_images.size(); ++i )
2322 for(
unsigned i = 0; i <
m_vias.size(); ++i )
2337 m_vias.push_back( aVia );
2378 if( padstack.GetPadstackId().compare( aPadstackId ) == 0 )
2388 m_unit->Format( out, nestLevel );
2391 image.Format( out, nestLevel );
2394 padstack.Format( out, nestLevel );
2397 via.Format( out, nestLevel );
2425 ELEM( T_pin, aParent )
2439 const char* newline = nestLevel ?
"\n" :
"";
2444 return out->
Print( nestLevel,
"%s%s%s-%s%s%s%s", cquote,
component_id.c_str(), cquote,
2445 pquote,
pin_id.c_str(), pquote, newline );
2457 ELEM( T_fromto, aParent )
2479 out->
Print( 0,
"(net %s%s%s)", quote,
m_net_id.c_str(), quote );
2482 bool singleLine =
true;
2486 out->
Print( 0,
"\n" );
2491 m_rules->Format( out, nestLevel+1 );
2499 layer_rule.Format( out, nestLevel+1 );
2501 out->
Print( singleLine ? 0 : nestLevel,
")" );
2503 if( nestLevel || !singleLine )
2504 out->
Print( 0,
"\n" );
2528 ELEM( T_comp_order, aParent )
2538 const char* quote = out->
GetQuoteChar( placement_id.c_str() );
2539 out->
Print( 0,
" %s%s%s", quote, placement_id.c_str(), quote );
2542 out->
Print( 0,
")" );
2545 out->
Print( 0,
"\n" );
2563 ELEM( T_net, aParent )
2584 for(
unsigned i = 0; i <
m_pins.size(); ++i )
2586 if( aComponent ==
m_pins[i].component_id )
2596 const char* space =
" ";
2602 out->
Print( 0,
"%s(unassigned)", space );
2612 out->
Print( 0,
"\n" );
2616 const int RIGHTMARGIN = 80;
2621 if( perLine > RIGHTMARGIN )
2623 out->
Print( 0,
"\n");
2624 perLine = out->
Print( nestLevel+2,
"%s",
"" );
2628 perLine += out->
Print( 0,
" " );
2631 perLine +=
pin.FormatIt( out, 0 );
2634 out->
Print( 0,
")\n" );
2644 m_rules->Format( out, nestLevel+1 );
2647 layer_rule.Format( out, nestLevel+1 );
2650 from_to.Format( out, nestLevel+1 );
2652 out->
Print( nestLevel,
")\n" );
2685 ELEM( T_topology, aParent )
2692 from_to.Format( out, nestLevel );
2695 comp_order.Format( out, nestLevel );
2713 ELEM( T_class, aParent )
2729 int perLine = out->
Print( nestLevel,
"(%s %s%s%s",
Name(), quote,
m_class_id.c_str(), quote );
2731 const int RIGHTMARGIN = 72;
2733 for(
const std::string& net_id :
m_net_ids )
2735 const char* space =
" ";
2737 if( perLine > RIGHTMARGIN )
2739 out->
Print( 0,
"\n" );
2740 perLine = out->
Print( nestLevel+1,
"%s",
"" );
2745 if( net_id.empty() )
2749 perLine += out->
Print( 0,
"%s%s%s%s", space, quote, net_id.c_str(), quote );
2752 bool newLine =
false;
2756 out->
Print( 0,
"\n" );
2762 out->
Print( nestLevel+1,
"(circuit\n" );
2764 for(
const std::string& circuit :
m_circuit )
2765 out->
Print( nestLevel + 2,
"%s\n", circuit.c_str() );
2767 out->
Print( nestLevel+1,
")\n" );
2771 m_rules->Format( out, nestLevel+1 );
2774 layer_rule.Format( out, nestLevel + 1 );
2779 out->
Print( newLine ? nestLevel : 0,
")\n" );
2803 ELEM( T_network, aParent )
2810 net.Format( out, nestLevel );
2813 c.Format( out, nestLevel );
2830 ELEM( T_connect, aParent ) {}
2841 ELEM( T_wire, aParent )
2865 wxASSERT(aShape->
Type()==T_rect || aShape->
Type()==T_circle
2866 || aShape->
Type()==T_qarc || aShape->
Type()==T_path
2867 || aShape->
Type()==T_polygon);
2875 out->
Print( nestLevel,
"(%s ",
Name() );
2883 out->
Print( 0,
"(net %s%s%s)", quote,
m_net_id.c_str(), quote );
2898 out->
Print( 0,
"(shield %s%s%s)", quote,
m_shield.c_str(), quote );
2903 out->
Print( 0,
"\n" );
2906 window.Format( out, nestLevel + 1 );
2913 out->
Print( 0,
"(supply)" );
2915 out->
Print( 0,
")\n" );
2948 ELEM( T_via, aParent )
2965 const int RIGHTMARGIN = 80;
2970 if( perLine > RIGHTMARGIN )
2972 out->
Print( 0,
"\n" );
2973 perLine = out->
Print( nestLevel+1,
"%s",
"" );
2977 perLine += out->
Print( 0,
" " );
2980 perLine += out->
Print( 0,
"%.6g %.6g", pt.x, pt.y );
2984 out->
Print( 0,
" " );
2988 if( perLine > RIGHTMARGIN )
2990 out->
Print( 0,
"\n" );
2991 perLine = out->
Print( nestLevel+1,
"%s",
"" );
2995 perLine += out->
Print( 0,
"(net %s%s%s)", quote,
m_net_id.c_str(), quote );
3000 if( perLine > RIGHTMARGIN )
3002 out->
Print( 0,
"\n" );
3003 perLine = out->
Print( nestLevel+1,
"%s",
"" );
3011 if( perLine > RIGHTMARGIN )
3013 out->
Print( 0,
"\n" );
3014 perLine = out->
Print( nestLevel+1,
"%s",
"" );
3022 if( perLine > RIGHTMARGIN )
3024 out->
Print( 0,
"\n" );
3025 perLine = out->
Print( nestLevel+1,
"%s",
"" );
3028 if(
m_attr == T_virtual_pin )
3041 if( perLine > RIGHTMARGIN )
3043 out->
Print( 0,
"\n" );
3044 perLine = out->
Print( nestLevel+1,
"%s",
"" );
3047 perLine += out->
Print( 0,
"(supply)" );
3052 out->
Print( 0,
"\n" );
3053 out->
Print( nestLevel+1,
"(contact\n" );
3058 out->
Print( nestLevel+2,
"%s%s%s\n", quote, contact_layer.c_str(), quote );
3061 out->
Print( nestLevel+1,
"))\n" );
3065 out->
Print( 0,
")\n" );
3091 ELEM( T_wiring, aParent )
3104 unit->Format( out, nestLevel );
3107 wire.Format( out, nestLevel );
3110 wire_via.Format( out, nestLevel );
3134 ELEM( T_pcb, aParent )
3165 m_parser->Format( out, nestLevel+1 );
3171 m_unit->Format( out, nestLevel+1 );
3186 m_wiring->Format( out, nestLevel+1 );
3188 out->
Print( nestLevel,
")\n" );
3221 ELEM( T_ancestor, aParent )
3232 strftime( temp,
sizeof(temp),
"%b %d %H : %M : %S %Y", tmp );
3236 out->
Print( nestLevel,
"(%s \"%s\" (created_time %s)\n",
Name(),
filename.c_str(), temp );
3241 out->
Print( nestLevel+1,
"(comment %s%s%s)\n", quote,
comment.c_str(), quote );
3244 out->
Print( nestLevel,
")\n" );
3262 ELEM( T_history, aParent )
3270 ancestor.Format( out, nestLevel );
3276 strftime( temp,
sizeof( temp ),
"%b %d %H : %M : %S %Y", tmp );
3279 out->
Print( nestLevel,
"(self (created_time %s)\n", temp );
3281 for(
const std::string& comment :
comments )
3283 const char* quote = out->
GetQuoteChar( comment.c_str() );
3284 out->
Print( nestLevel+1,
"(comment %s%s%s)\n", quote, comment.c_str(), quote );
3287 out->
Print( nestLevel,
")\n" );
3306 ELEM( T_supply_pin, aParent )
3312 bool singleLine =
pin_refs.size() <= 1;
3317 out->
Print( 0,
"%s",
" " );
3318 pin_refs.begin()->Format( out, 0 );
3323 pin_ref.FormatIt( out, nestLevel + 1 );
3328 const char* newline = singleLine ?
"" :
"\n";
3331 out->
Print( singleLine ? 0 : nestLevel+1,
" (net %s%s%s)%s",
3332 quote,
net_id.c_str(), quote, newline );
3335 out->
Print( singleLine ? 0 : nestLevel,
")\n");
3353 ELEM( T_net_out, aParent )
3369 out->
Print( nestLevel,
"(net %s%s%s\n", quote,
net_id.c_str(), quote );
3375 rules->Format( out, nestLevel+1 );
3378 wire.Format( out, nestLevel + 1 );
3381 wire_via.Format( out, nestLevel + 1 );
3384 supply_pin.Format( out, nestLevel + 1 );
3386 out->
Print( nestLevel,
")\n" );
3405 ELEM( T_route, aParent )
3436 parser->Format( out, nestLevel );
3442 library->Format( out, nestLevel );
3446 out->
Print( nestLevel,
"(network_out\n" );
3449 net_out.Format( out, nestLevel + 1 );
3451 out->
Print( nestLevel,
")\n" );
3494 ELEM( T_was_is, aParent )
3502 out->
Print( nestLevel,
"(pins " );
3503 pin_pair.was.Format( out, 0 );
3504 out->
Print( 0,
" " );
3505 pin_pair.is.Format( out, 0 );
3506 out->
Print( 0,
")\n" );
3524 ELEM( T_session, aParent )
3550 history->Format( out, nestLevel+1 );
3559 was_is->Format( out, nestLevel+1 );
3562 route->Format( out, nestLevel+1 );
3564 out->
Print( nestLevel,
")\n" );
3601 wxASSERT( !iOwnReaders );
3608 SetSpecctraMode(
true );
3661 void LoadPCB(
const wxString& aFilename );
3683 void ExportPCB(
const wxString& aFilename,
bool aNameChange=
false );
3766 void readCOMPnPIN( std::string* component_id, std::string* pid_id );
3779 void readTIME( time_t* time_stamp );
3876 PADSTACK*
makeVia(
int aCopperDiameter,
int aDrillDiameter,
int aTopLayer,
int aBotLayer );
3921 int aViaDrillDefault );
Information pertinent to a Pcbnew printed circuit board.
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
BOUNDARY(ELEM *aParent, DSN_T aType=T_boundary)
void GetCorners(std::vector< double > &aBuffer)
GetCorners fills aBuffer with a list of coordinates (x,y) of corners.
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void SetLayerId(const std::string &aLayerId)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void SetVertex(const POINT &aVertex)
void SetDiameter(double aDiameter)
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
std::vector< std::string > class_ids
CLASS_CLASS(ELEM *aParent, DSN_T aType)
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
The <class_descriptor> in the specctra spec.
std::vector< std::string > m_circuit
circuit descriptor list
boost::ptr_vector< LAYER_RULE > m_layer_rules
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
std::vector< std::string > m_net_ids
Implement a <component_descriptor> in the specctra dsn spec.
boost::ptr_vector< PLACE > m_places
const std::string & GetImageId() const
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void SetImageId(const std::string &aImageId)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Compare two objects of this type and returns <0, 0, or >0.
The <component_order_descriptor>.
COMP_ORDER(ELEM *aParent)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
std::vector< std::string > m_placement_ids
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
A <plane_descriptor> in the specctra dsn spec.
COPPER_PLANE(ELEM *aParent)
int FindElem(DSN_T aType, int instanceNum=0)
Find a particular instance number of a given type of ELEM.
ELEM_HOLDER(DSN_T aType, ELEM *aParent=nullptr)
ELEM * operator[](int aIndex) const
virtual void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
ELEM * Replace(int aIndex, ELEM *aElem)
void Insert(int aIndex, ELEM *aElem)
ELEM_ARRAY kids
ELEM pointers.
ELEM * Remove(int aIndex)
ELEM * At(int aIndex) const
boost::ptr_vector< ELEM > ELEM_ARRAY
int Length() const
Return the number of ELEMs in this holder.
A base class for any DSN element class.
std::string makeHash()
Return a string which uniquely represents this ELEM among other ELEMs of the same derived class as "t...
const char * Name() const
virtual void Format(OUTPUTFORMATTER *out, int nestLevel)
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
ELEM(DSN_T aType, ELEM *aParent=nullptr)
void SetParent(ELEM *aParent)
virtual UNIT_RES * GetUnits() const
Return the units for this section.
virtual void FormatContents(OUTPUTFORMATTER *out, int nestLevel)
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
static STRING_FORMATTER sf
boost::ptr_vector< LAYER_RULE > m_layer_rules
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
DSN_T m_grid_type
T_via | T_wire | T_via_keepout | T_place | T_snap.
DSN_T m_direction
T_x | T_y | -1 for both.
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
std::vector< std::string > comments
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
std::string m_hash
a hash string used by Compare(), not Format()ed/exported.
static int Compare(IMAGE *lhs, IMAGE *rhs)
Compare two objects of this type and returns <0, 0, or >0.
UNIT_RES * GetUnits() const override
Return the units for this section.
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
boost::ptr_vector< KEEPOUT > m_keepouts
int m_duplicated
no. times this image_id is duplicated
boost::ptr_vector< PIN > m_pins
Used for <keepout_descriptor> and <plane_descriptor>.
void AddWindow(WINDOW *aWindow)
KEEPOUT(ELEM *aParent, DSN_T aType)
Require a DSN_T because this class is used for T_place_keepout, T_via_keepout, T_wire_keepout,...
boost::ptr_vector< WINDOW > m_windows
void SetShape(ELEM *aShape)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
LAYER_NOISE_WEIGHT(ELEM *aParent)
SPECCTRA_LAYER_PAIRS layer_pairs
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
LAYER_RULE(ELEM *aParent)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
std::vector< std::string > m_layer_ids
DSN_T layer_type
one of: T_signal, T_power, T_mixed, T_jumper
std::vector< std::string > use_net
int cost_type
T_length | T_way.
int direction
[forbidden | high | medium | low | free | <positive_integer> | -1]
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
A <library_descriptor> in the specctra dsn specification.
boost::ptr_vector< PADSTACK > m_padstacks
all except vias, which are in 'vias'
PADSTACK * LookupVia(PADSTACK *aVia)
Add the via only if one exactly like it does not already exist in the padstack container.
PADSTACK * FindPADSTACK(const std::string &aPadstackId)
Search the padstack container by name.
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void AppendVia(PADSTACK *aVia)
Add aVia to the internal via container.
int FindIMAGE(IMAGE *aImage)
Search this LIBRARY for an image which matches the argument.
UNIT_RES * GetUnits() const override
Return the units for this section.
boost::ptr_vector< IMAGE > m_images
IMAGE * LookupIMAGE(IMAGE *aImage)
Add the image only if one exactly like it does not already exist in the image container.
void AppendPADSTACK(PADSTACK *aPadstack)
Add the padstack to the padstack container.
boost::ptr_vector< PADSTACK > m_vias
LIBRARY(ELEM *aParent, DSN_T aType=T_library)
void AddPadstack(PADSTACK *aPadstack)
void AppendIMAGE(IMAGE *aImage)
Add the image to the image list.
int FindVia(PADSTACK *aVia)
Search this LIBRARY for a via which matches the argument.
boost::ptr_vector< NET > m_nets
boost::ptr_vector< CLASS > m_classes
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
A <net_out_descriptor> of the specctra dsn spec.
boost::ptr_vector< WIRE > wires
boost::ptr_vector< WIRE_VIA > wire_vias
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
boost::ptr_vector< SUPPLY_PIN > supply_pins
A <net_descriptor> in the DSN spec.
std::vector< PIN_REF > m_load
boost::ptr_vector< FROMTO > m_fromtos
std::vector< PIN_REF > m_pins
std::vector< PIN_REF > m_noexpose
std::vector< PIN_REF > m_source
std::vector< PIN_REF > m_expose
int FindPIN_REF(const std::string &aComponent)
std::vector< PIN_REF > m_terminator
DSN_T m_type
T_fix | T_normal.
DSN_T m_supply
T_power | T_ground.
boost::ptr_vector< LAYER_RULE > m_layer_rules
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
COMP_ORDER * m_comp_order
DSN_T m_pins_type
T_pins | T_order, type of field 'pins' below.
Hold either a via or a pad definition.
const std::string & GetPadstackId()
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
std::string m_hash
a hash string used by Compare(), not Format()ed/exported.
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
PADSTACK()
Cannot take ELEM* aParent because PADSTACKSET confuses this with a copy constructor and causes havoc.
std::string m_padstack_id
void SetPadstackId(const char *aPadstackId)
static int Compare(PADSTACK *lhs, PADSTACK *rhs)
Compare two objects of this type and returns <0, 0, or >0.
UNIT_RES * GetUnits() const override
Return the units for this section.
A configuration record per the SPECCTRA DSN file spec.
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
std::vector< std::string > constants
This holds pairs of strings, one pair for each constant definition.
bool routes_include_image_conductor
bool routes_include_guides
bool wires_include_testpoint
bool routes_include_testpoint
bool generated_by_freeroute
bool space_in_quoted_tokens
Support both the <path_descriptor> and the <polygon_descriptor> per the specctra dsn spec.
std::vector< POINT > & GetPoints()
std::vector< POINT > points
PATH(ELEM *aParent, DSN_T aType=T_path)
void SetLayerId(const std::string &aLayerId)
void SetAperture(double aWidth)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void AppendPoint(const POINT &aPoint)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
PCB(ELEM *aParent=nullptr)
UNIT_RES * GetUnits() const override
Return the units for this section.
void SetVertex(const POINT &aPoint)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
int m_kiNetCode
KiCad netcode.
void SetRotation(double aRotation)
std::string m_padstack_id
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
UNIT_RES * GetUnits() const override
Return the units for this section.
COMPONENT * LookupCOMPONENT(const std::string &imageName)
Look up a COMPONENT by name.
boost::ptr_vector< COMPONENT > m_components
Implement a <placement_reference> in the specctra dsn spec.
void SetVertex(const POINT &aVertex)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void SetRotation(double aRotation)
std::string m_logical_part
std::string m_part_number
std::string m_component_id
reference designator
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void SetStart(const POINT &aStart)
void SetLayerId(std::string &aLayerId)
void SetCenter(const POINT &aCenter)
void SetEnd(const POINT &aEnd)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void SetLayerId(std::string &aLayerId)
void SetCorners(const POINT &aPoint0, const POINT &aPoint1)
POINT point0
one of two opposite corners
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
STRUCTURE_OUT * structure_out
UNIT_RES * GetUnits() const override
Return the units for this section.
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
boost::ptr_vector< NET_OUT > net_outs
A <rule_descriptor> in the specctra dsn spec.
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
RULE(ELEM *aParent, DSN_T aType)
std::vector< std::string > m_rules
rules are saved in std::string form.
A <session_file_descriptor> in the specctra dsn spec.
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
SESSION(ELEM *aParent=nullptr)
A "(shape ..)" element in the specctra dsn spec.
SHAPE(ELEM *aParent, DSN_T aType=T_shape)
Takes a DSN_T aType of T_outline.
void SetConnect(DSN_T aConnect)
boost::ptr_vector< WINDOW > m_windows
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
PADSTACK * makeVia(const ::PCB_VIA *aVia)
Make any kind of PADSTACK using the given KiCad VIA.
void doUNIT(UNIT_RES *growth)
int m_top_via_layer
specctra cu layers, 0 based index:
void doCOMPONENT(COMPONENT *growth)
IMAGE * makeIMAGE(BOARD *aBoard, FOOTPRINT *aFootprint)
Allocates an I#MAGE on the heap and creates all the PINs according to the PADs in the FOOTPRINT.
void doWAS_IS(WAS_IS *growth)
void doPLACEMENT(PLACEMENT *growth)
void doNET_OUT(NET_OUT *growth)
void buildLayerMaps(BOARD *aBoard)
Create a few data translation structures for layer name and number mapping between the DSN::PCB struc...
PCB_TRACK * makeTRACK(WIRE *wire, PATH *aPath, int aPointIndex, int aNetcode)
Create a TRACK form the PATH and BOARD info.
void doCLASS(CLASS *growth)
void SetSESSION(SESSION *aSession)
Delete any existing SESSION and replaces it with the given one.
void doSTRUCTURE_OUT(STRUCTURE_OUT *growth)
std::map< int, PCB_LAYER_ID > m_pcbLayer2kicad
maps PCB layer number to BOARD layer numbers
void doCIRCLE(CIRCLE *growth)
void doANCESTOR(ANCESTOR *growth)
void doLAYER_NOISE_WEIGHT(LAYER_NOISE_WEIGHT *growth)
void ExportPCB(const wxString &aFilename, bool aNameChange=false)
Write the internal PCB instance out as a SPECTRA DSN format file.
void doCLASS_CLASS(CLASS_CLASS *growth)
void doSESSION(SESSION *growth)
void doWINDOW(WINDOW *growth)
UNIT_RES * m_routeResolution
used during FromSESSION() only, memory for it is not owned here.
SHAPE_POLY_SET m_brd_outlines
void doSHAPE(SHAPE *growth)
BOARD * m_sessionBoard
a copy to avoid passing as an argument, memory for it is not owned here.
void FlipFOOTPRINTs(BOARD *aBoard)
Flip the footprints which are on the back side of the board to the front.
void doQARC(QARC *growth)
void doRESOLUTION(UNIT_RES *growth)
void LoadPCB(const wxString &aFilename)
A recursive descent parser for a SPECCTRA DSN "design" file.
void doSTRINGPROP(STRINGPROP *growth)
void doBOUNDARY(BOUNDARY *growth)
void doSPECCTRA_LAYER_PAIR(SPECCTRA_LAYER_PAIR *growth)
bool m_footprintsAreFlipped
void doRECTANGLE(RECTANGLE *growth)
void deleteNETs()
Delete all the NETs that may be in here.
void doREGION(REGION *growth)
void fillBOUNDARY(BOARD *aBoard, BOUNDARY *aBoundary)
Make the board perimeter for the DSN file by filling the BOUNDARY element in the specctra element tre...
void ExportSESSION(const wxString &aFilename)
Write the internal SESSION instance out as a #SPECTRA DSN format file.
void doWIRE(WIRE *growth)
static const KICAD_T scanPADs[]
PADSTACK * makePADSTACK(BOARD *aBoard, PAD *aPad)
Create a PADSTACK which matches the given pad.
void SetPCB(PCB *aPcb)
Delete any existing PCB and replaces it with the given one.
void doTOKPROP(TOKPROP *growth)
std::vector< std::string > m_layerIds
indexed by PCB layer number
void doIMAGE(IMAGE *growth)
void doCONNECT(CONNECT *growth)
void doCOMP_ORDER(COMP_ORDER *growth)
static PCB * MakePCB()
Make a PCB with all the default ELEMs and parts on the heap.
void doTOPOLOGY(TOPOLOGY *growth)
void doKEEPOUT(KEEPOUT *growth)
void doRULE(RULE *growth)
void doPATH(PATH *growth)
void doSUPPLY_PIN(SUPPLY_PIN *growth)
void doLAYER(LAYER *growth)
bool BuiltBoardOutlines(BOARD *aBoard)
Build the board outlines and store it in m_brd_outlines.
void LoadSESSION(const wxString &aFilename)
A recursive descent parser for a SPECCTRA DSN "session" file.
void doLIBRARY(LIBRARY *growth)
void exportNETCLASS(const NETCLASS *aNetClass, const BOARD *aBoard)
Export aNetClass to the DSN file.
PADSTACK * makeVia(int aCopperDiameter, int aDrillDiameter, int aTopLayer, int aBotLayer)
Make a round through hole PADSTACK using the given KiCad diameter in deci-mils.
boost::ptr_set< PADSTACK > m_padstackset
std::map< PCB_LAYER_ID, int > m_kicadLayer2pcb
maps BOARD layer number to PCB layer numbers
std::vector< NET * > m_nets
we don't want ownership here permanently, so we don't use boost::ptr_vector
void doFROMTO(FROMTO *growth)
void doPLACE(PLACE *growth)
void doGRID(GRID *growth)
void doLAYER_RULE(LAYER_RULE *growth)
void FromSESSION(BOARD *aBoard)
Add the entire SESSION info to a BOARD but does not write it out.
void doWIRE_VIA(WIRE_VIA *growth)
void doCLASSES(CLASSES *growth)
void readCOMPnPIN(std::string *component_id, std::string *pid_id)
Read a <pin_reference> and splits it into the two parts which are on either side of the hyphen.
PCB_VIA * makeVIA(WIRE_VIA *aVia, PADSTACK *aPadstack, const POINT &aPoint, int aNetCode, int aViaDrillDefault)
Instantiate a KiCad VIA on the heap and initializes it with internal values consistent with the given...
PCB_ARC * makeARC(WIRE *wire, QARC *aQarc, int aNetcode)
Create an ARC form the PATH and BOARD info.
void FromBOARD(BOARD *aBoard)
Add the entire BOARD to the PCB but does not write it out.
void doPARSER(PARSER *growth)
void doNETWORK(NETWORK *growth)
void RevertFOOTPRINTs(BOARD *aBoard)
Flip the footprints which were on the back side of the board back to the back.
void doSTRUCTURE(STRUCTURE *growth)
int findLayerName(const std::string &aLayerName) const
Return the PCB layer index for a given layer name, within the specctra sessionfile.
void doROUTE(ROUTE *growth)
void readTIME(time_t *time_stamp)
Read a <time_stamp> which consists of 8 lexer tokens: "month date hour : minute : second year".
void doPADSTACK(PADSTACK *growth)
void doWIRING(WIRING *growth)
static const KEYWORD keywords[]
specctra DSN keywords
void doHISTORY(HISTORY *growth)
void doCONTROL(CONTROL *growth)
void doPROPERTIES(PROPERTIES *growth)
SPECCTRA_LAYER_PAIR(ELEM *aParent)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
A container for a single property whose value is a string.
STRINGPROP(ELEM *aParent, DSN_T aType)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
STRUCTURE_OUT(ELEM *aParent)
boost::ptr_vector< LAYER > m_layers
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
boost::ptr_vector< REGION > m_regions
boost::ptr_vector< GRID > m_grids
boost::ptr_vector< KEEPOUT > m_keepouts
UNIT_RES * GetUnits() const override
Return the units for this section.
LAYER_NOISE_WEIGHT * m_layer_noise_weight
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void SetBOUNDARY(BOUNDARY *aBoundary)
BOUNDARY * m_place_boundary
boost::ptr_vector< COPPER_PLANE > m_planes
void SetPlaceBOUNDARY(BOUNDARY *aBoundary)
boost::ptr_vector< LAYER > m_layers
A <supply_pin_descriptor> in the specctra dsn spec.
std::vector< PIN_REF > pin_refs
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
SUPPLY_PIN(ELEM *aParent)
A container for a single property whose value is another DSN_T token.
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
TOKPROP(ELEM *aParent, DSN_T aType)
boost::ptr_vector< COMP_ORDER > m_comp_orders
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
boost::ptr_vector< FROMTO > m_fromtos
A holder for either a T_unit or T_resolution object which are usually mutually exclusive in the dsn g...
UNIT_RES(ELEM *aParent, DSN_T aType)
static UNIT_RES Default
A static instance which holds the default units of T_inch and 2540000.
DSN_T GetEngUnits() const
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
A <via_descriptor> in the specctra dsn spec.
std::vector< std::string > m_spares
std::vector< std::string > m_padstacks
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
void AppendVia(const char *aViaName)
A <was_is_descriptor> in the specctra dsn spec.
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
std::vector< PIN_PAIR > pin_pairs
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
WINDOW(ELEM *aParent, DSN_T aType=T_window)
void SetShape(ELEM *aShape)
A <wire_via_descriptor> in the specctra dsn spec.
std::string m_padstack_id
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
std::string m_virtual_pin_name
std::vector< std::string > m_contact_layers
const std::string & GetPadstackId()
std::vector< POINT > m_vertexes
A <wire_shape_descriptor> in the specctra dsn spec.
boost::ptr_vector< WINDOW > m_windows
void SetShape(ELEM *aShape)
void Format(OUTPUTFORMATTER *out, int nestLevel) override
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
A <wiring_descriptor> in the specctra dsn spec.
boost::ptr_vector< WIRE > wires
boost::ptr_vector< WIRE_VIA > wire_vias
void FormatContents(OUTPUTFORMATTER *out, int nestLevel) override
Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
UNIT_RES * GetUnits() const override
Return the units for this section.
A collection of nets and the parameters used to route or test these nets.
Represent a set of closed polygons.
This source file implements export and import capabilities to the specctra dsn file format.
boost::ptr_vector< PATH > PATHS
boost::ptr_vector< CLASS > CLASSLIST
boost::ptr_vector< COMP_ORDER > COMP_ORDERS
bool operator<(const PADSTACK &lhs, const PADSTACK &rhs)
Used by the PADSTACKSET boost::ptr_set below.
const char * GetTokenText(T aTok)
The DSN namespace and returns the C string representing a SPECCTRA_DB::keyword.
std::vector< PROPERTY > PROPERTIES
void ExportBoardToSpecctraFile(BOARD *aBoard, const wxString &aFullFilename)
Helper method to export board to DSN file.
boost::ptr_vector< ANCESTOR > ANCESTORS
boost::ptr_vector< COPPER_PLANE > COPPER_PLANES
boost::ptr_vector< SPECCTRA_LAYER_PAIR > SPECCTRA_LAYER_PAIRS
bool ImportSpecctraSession(BOARD *aBoard, const wxString &fullFileName)
Helper method to import SES file to a board.
boost::ptr_set< PADSTACK > PADSTACKSET
Used within the WAS_IS class below to hold a pair of PIN_REFs and corresponds to the (pins was is) co...
PIN_PAIR(ELEM *aParent=nullptr)
A <pin_reference> definition in the specctra dsn spec.
int FormatIt(OUTPUTFORMATTER *out, int nestLevel)
Like Format() but is not virtual.
A point in the SPECCTRA DSN coordinate system.
POINT & operator=(const POINT &other)
void FixNegativeZero()
Change negative zero to positive zero in the IEEE floating point storage format.
bool operator!=(const POINT &other) const
bool operator==(const POINT &other) const
void Format(OUTPUTFORMATTER *out, int nestLevel) const
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
POINT(double aX, double aY)
POINT & operator+=(const POINT &other)
void Format(OUTPUTFORMATTER *out, int nestLevel) const
Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
Hold a keyword string and its unique integer token.
KICAD_T
The set of class identification values stored in EDA_ITEM::m_structType.