KiCad PCB EDA Suite
CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION Struct Reference

#include <cadstar_pcb_archive_parser.h>

Inheritance diagram for CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION:
CADSTAR_ARCHIVE_PARSER::SETTINGS CADSTAR_ARCHIVE_PARSER::PARSER

Public Member Functions

void Parse (XNODE *aNode, PARSER_CONTEXT *aContext) override
 
bool ParseSubNode (XNODE *aChildNode, PARSER_CONTEXT *aContext)
 

Public Attributes

long MinRouteWidth
 Manufacturing Design Rule. Corresponds to "Thin Route Width". More...
 
long MinNeckedLength
 Manufacturing Design Rule. More...
 
long MinUnneckedLength
 Manufacturing Design Rule. More...
 
long MinMitre
 Manufacturing Design Rule. Corresponds to "Minimum Mitre". More...
 
long MaxMitre
 Manufacturing Design Rule. Corresponds to "Maximum Mitre". More...
 
long MaxPhysicalLayer
 Should equal number of copper layers. More...
 
long TrackGrid
 Grid for Routes (equal X and Y steps) More...
 
long ViaGrid
 Grid for Vias (equal X and Y steps) More...
 
bool BackOffJunctions = false
 
bool BackOffWidthChange = false
 
UNITS Units
 Units to display for linear dimensions. More...
 
long UnitDisplPrecision
 Number of decimal points to display for linear dimensions. More...
 
long InterlineGap
 For CADSTAR font only, distance between lines of text, expressed as a percentage of the text height (accepted values are 0-100) More...
 
long BarlineGap
 For CADSTAR font only, distance between top bar and character, expressed as a percentage of the text height (accepted values are 0-100) More...
 
bool AllowBarredText = false
 Specifies if barring is allowed in the design. More...
 
long AngularPrecision
 Number of decimal points to display for angular dimensions. More...
 
LONGPOINT DesignOrigin
 
std::pair< POINT, POINTDesignArea
 
LONGPOINT DesignRef
 Appears to be 0,0 always. More...
 
LONGPOINT DesignLimit
 

Detailed Description

Definition at line 399 of file cadstar_pcb_archive_parser.h.

Member Function Documentation

◆ Parse()

void CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::Parse ( XNODE aNode,
PARSER_CONTEXT aContext 
)
overridevirtual

Reimplemented from CADSTAR_ARCHIVE_PARSER::SETTINGS.

Definition at line 943 of file cadstar_pcb_archive_parser.cpp.

944{
945 wxASSERT( aNode->GetName() == wxT( "TECHNOLOGY" ) );
946
947 XNODE* cNode = aNode->GetChildren();
948
949 for( ; cNode; cNode = cNode->GetNext() )
950 {
951 wxString cNodeName = cNode->GetName();
952
953 if( ParseSubNode( cNode, aContext ) ) //CADSTAR_ARCHIVE_PARSER::SETTINGS
954 {
955 }
956 else if( cNodeName == wxT( "MINROUTEWIDTH" ) )
957 {
959 }
960 else if( cNodeName == wxT( "MINNECKED" ) )
961 {
963 }
964 else if( cNodeName == wxT( "MINUNNECKED" ) )
965 {
967 }
968 else if( cNodeName == wxT( "MINMITER" ) )
969 {
970 MinMitre = GetXmlAttributeIDLong( cNode, 0 );
971 }
972 else if( cNodeName == wxT( "MAXMITER" ) )
973 {
974 MaxMitre = GetXmlAttributeIDLong( cNode, 0 );
975 }
976 else if( cNodeName == wxT( "MAXPHYSLAYER" ) )
977 {
979 }
980 else if( cNodeName == wxT( "TRACKGRID" ) )
981 {
982 TrackGrid = GetXmlAttributeIDLong( cNode, 0 );
983 }
984 else if( cNodeName == wxT( "VIAGRID" ) )
985 {
986 ViaGrid = GetXmlAttributeIDLong( cNode, 0 );
987 }
988 else if( cNodeName == wxT( "BACKOFFJCTS" ) )
989 {
990 BackOffJunctions = true;
991 }
992 else if( cNodeName == wxT( "BCKOFFWIDCHANGE" ) )
993 {
994 BackOffWidthChange = true;
995 }
996 else
997 {
998 THROW_UNKNOWN_NODE_IO_ERROR( cNodeName, wxT( "TECHNOLOGY" ) );
999 }
1000 }
1001}
#define THROW_UNKNOWN_NODE_IO_ERROR(nodename, location)
static long GetXmlAttributeIDLong(XNODE *aNode, unsigned int aID, bool aIsRequired=true)
Hold an XML or S-expression element.
Definition: xnode.h:44
XNODE * GetChildren() const
Definition: xnode.h:62
XNODE * GetNext() const
Definition: xnode.h:67
bool ParseSubNode(XNODE *aChildNode, PARSER_CONTEXT *aContext)
long MinRouteWidth
Manufacturing Design Rule. Corresponds to "Thin Route Width".
long TrackGrid
Grid for Routes (equal X and Y steps)
long MaxPhysicalLayer
Should equal number of copper layers.
long MaxMitre
Manufacturing Design Rule. Corresponds to "Maximum Mitre".
long ViaGrid
Grid for Vias (equal X and Y steps)
long MinMitre
Manufacturing Design Rule. Corresponds to "Minimum Mitre".

References XNODE::GetChildren(), XNODE::GetNext(), CADSTAR_ARCHIVE_PARSER::GetXmlAttributeIDLong(), and THROW_UNKNOWN_NODE_IO_ERROR.

Referenced by CADSTAR_PCB_ARCHIVE_PARSER::ASSIGNMENTS::Parse().

◆ ParseSubNode()

bool CADSTAR_ARCHIVE_PARSER::SETTINGS::ParseSubNode ( XNODE aChildNode,
PARSER_CONTEXT aContext 
)
inherited

Definition at line 767 of file cadstar_archive_parser.cpp.

768{
769 wxString cNodeName = aChildNode->GetName();
770
771 if( cNodeName == wxT( "UNITS" ) )
772 {
773 Units = ParseUnits( aChildNode );
774 }
775 else if( cNodeName == wxT( "UNITSPRECISION" ) )
776 {
777 UnitDisplPrecision = GetXmlAttributeIDLong( aChildNode, 0 );
778 }
779 else if( cNodeName == wxT( "INTERLINEGAP" ) )
780 {
781 InterlineGap = GetXmlAttributeIDLong( aChildNode, 0 );
782 }
783 else if( cNodeName == wxT( "BARLINEGAP" ) )
784 {
785 BarlineGap = GetXmlAttributeIDLong( aChildNode, 0 );
786 }
787 else if( cNodeName == wxT( "ALLOWBARTEXT" ) )
788 {
789 AllowBarredText = true;
790 }
791 else if( cNodeName == wxT( "ANGULARPRECISION" ) )
792 {
793 AngularPrecision = GetXmlAttributeIDLong( aChildNode, 0 );
794 }
795 else if( cNodeName == wxT( "DESIGNORIGIN" ) )
796 {
797 DesignOrigin.Parse( aChildNode->GetChildren(), aContext );
798 }
799 else if( cNodeName == wxT( "DESIGNAREA" ) )
800 {
801 std::vector<POINT> pts = ParseAllChildPoints( aChildNode, aContext, true, 2 );
802 DesignArea = std::make_pair( pts[0], pts[1] );
803 }
804 else if( cNodeName == wxT( "DESIGNREF" ) )
805 {
806 DesignOrigin.Parse( aChildNode->GetChildren(), aContext );
807 }
808 else if( cNodeName == wxT( "DESIGNLIMIT" ) )
809 {
810 DesignLimit.Parse( aChildNode->GetChildren(), aContext );
811 }
812 else
813 {
814 return false;
815 }
816
817 return true;
818}
static UNITS ParseUnits(XNODE *aNode)
static std::vector< POINT > ParseAllChildPoints(XNODE *aNode, PARSER_CONTEXT *aContext, bool aTestAllChildNodes=false, int aExpectedNumPoints=UNDEFINED_VALUE)
if no children are present, it just returns an empty vector (without throwing an exception)
void Parse(XNODE *aNode, PARSER_CONTEXT *aContext) override
UNITS Units
Units to display for linear dimensions.
long InterlineGap
For CADSTAR font only, distance between lines of text, expressed as a percentage of the text height (...
long BarlineGap
For CADSTAR font only, distance between top bar and character, expressed as a percentage of the text ...
bool AllowBarredText
Specifies if barring is allowed in the design.
std::pair< POINT, POINT > DesignArea
long AngularPrecision
Number of decimal points to display for angular dimensions.
long UnitDisplPrecision
Number of decimal points to display for linear dimensions.

References XNODE::GetChildren(), CADSTAR_ARCHIVE_PARSER::GetXmlAttributeIDLong(), CADSTAR_ARCHIVE_PARSER::ParseAllChildPoints(), and CADSTAR_ARCHIVE_PARSER::ParseUnits().

Member Data Documentation

◆ AllowBarredText

bool CADSTAR_ARCHIVE_PARSER::SETTINGS::AllowBarredText = false
inherited

Specifies if barring is allowed in the design.

Definition at line 570 of file cadstar_archive_parser.h.

◆ AngularPrecision

long CADSTAR_ARCHIVE_PARSER::SETTINGS::AngularPrecision
inherited

Number of decimal points to display for angular dimensions.

Definition at line 571 of file cadstar_archive_parser.h.

◆ BackOffJunctions

bool CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::BackOffJunctions = false

Definition at line 415 of file cadstar_pcb_archive_parser.h.

◆ BackOffWidthChange

bool CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::BackOffWidthChange = false

Definition at line 416 of file cadstar_pcb_archive_parser.h.

◆ BarlineGap

long CADSTAR_ARCHIVE_PARSER::SETTINGS::BarlineGap
inherited

For CADSTAR font only, distance between top bar and character, expressed as a percentage of the text height (accepted values are 0-100)

Definition at line 567 of file cadstar_archive_parser.h.

◆ DesignArea

std::pair<POINT, POINT> CADSTAR_ARCHIVE_PARSER::SETTINGS::DesignArea
inherited

Definition at line 574 of file cadstar_archive_parser.h.

Referenced by CADSTAR_PCB_ARCHIVE_LOADER::Load().

◆ DesignLimit

LONGPOINT CADSTAR_ARCHIVE_PARSER::SETTINGS::DesignLimit
inherited

◆ DesignOrigin

LONGPOINT CADSTAR_ARCHIVE_PARSER::SETTINGS::DesignOrigin
inherited

Definition at line 573 of file cadstar_archive_parser.h.

◆ DesignRef

LONGPOINT CADSTAR_ARCHIVE_PARSER::SETTINGS::DesignRef
inherited

Appears to be 0,0 always.

Definition at line 575 of file cadstar_archive_parser.h.

◆ InterlineGap

long CADSTAR_ARCHIVE_PARSER::SETTINGS::InterlineGap
inherited

For CADSTAR font only, distance between lines of text, expressed as a percentage of the text height (accepted values are 0-100)

Definition at line 564 of file cadstar_archive_parser.h.

◆ MaxMitre

long CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::MaxMitre

Manufacturing Design Rule. Corresponds to "Maximum Mitre".

Definition at line 407 of file cadstar_pcb_archive_parser.h.

◆ MaxPhysicalLayer

long CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::MaxPhysicalLayer

Should equal number of copper layers.

However, it seems this can be set to any arbitrarily high number as long as it is greater or equal to the number of copper layers. Also the last copper layer (bottom) must have this set as its value.

Definition at line 408 of file cadstar_pcb_archive_parser.h.

Referenced by CADSTAR_PCB_ARCHIVE_LOADER::loadNetVia().

◆ MinMitre

long CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::MinMitre

Manufacturing Design Rule. Corresponds to "Minimum Mitre".

Definition at line 406 of file cadstar_pcb_archive_parser.h.

◆ MinNeckedLength

long CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::MinNeckedLength

Manufacturing Design Rule.

Corresponds to "Minimum Thinner Track Length"

Definition at line 402 of file cadstar_pcb_archive_parser.h.

◆ MinRouteWidth

long CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::MinRouteWidth

Manufacturing Design Rule. Corresponds to "Thin Route Width".

Definition at line 401 of file cadstar_pcb_archive_parser.h.

Referenced by CADSTAR_PCB_ARCHIVE_LOADER::loadDesignRules().

◆ MinUnneckedLength

long CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::MinUnneckedLength

Manufacturing Design Rule.

Corresponds to "Minimum Thicker Track Length"

Definition at line 404 of file cadstar_pcb_archive_parser.h.

◆ TrackGrid

long CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::TrackGrid

Grid for Routes (equal X and Y steps)

Definition at line 412 of file cadstar_pcb_archive_parser.h.

◆ UnitDisplPrecision

long CADSTAR_ARCHIVE_PARSER::SETTINGS::UnitDisplPrecision
inherited

Number of decimal points to display for linear dimensions.

Definition at line 563 of file cadstar_archive_parser.h.

Referenced by CADSTAR_PCB_ARCHIVE_LOADER::applyDimensionSettings().

◆ Units

UNITS CADSTAR_ARCHIVE_PARSER::SETTINGS::Units
inherited

Units to display for linear dimensions.

Definition at line 562 of file cadstar_archive_parser.h.

Referenced by CADSTAR_PCB_ARCHIVE_LOADER::applyDimensionSettings().

◆ ViaGrid

long CADSTAR_PCB_ARCHIVE_PARSER::TECHNOLOGY_SECTION::ViaGrid

Grid for Vias (equal X and Y steps)

Definition at line 413 of file cadstar_pcb_archive_parser.h.


The documentation for this struct was generated from the following files: