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  {
958  MinRouteWidth = GetXmlAttributeIDLong( cNode, 0 );
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 }
long ViaGrid
Grid for Vias (equal X and Y steps)
long MaxPhysicalLayer
Should equal number of copper layers.
XNODE * GetChildren() const
Definition: xnode.h:62
bool ParseSubNode(XNODE *aChildNode, PARSER_CONTEXT *aContext)
long TrackGrid
Grid for Routes (equal X and Y steps)
static long GetXmlAttributeIDLong(XNODE *aNode, unsigned int aID, bool aIsRequired=true)
Hold an XML or S-expression element.
Definition: xnode.h:43
long MinMitre
Manufacturing Design Rule. Corresponds to "Minimum Mitre".
#define THROW_UNKNOWN_NODE_IO_ERROR(nodename, location)
long MinRouteWidth
Manufacturing Design Rule. Corresponds to "Thin Route Width".
long MaxMitre
Manufacturing Design Rule. Corresponds to "Maximum Mitre".

References XNODE::GetChildren(), 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 671 of file cadstar_archive_parser.cpp.

672 {
673  wxString cNodeName = aChildNode->GetName();
674 
675  if( cNodeName == wxT( "UNITS" ) )
676  {
677  Units = ParseUnits( aChildNode );
678  }
679  else if( cNodeName == wxT( "UNITSPRECISION" ) )
680  {
681  UnitDisplPrecision = GetXmlAttributeIDLong( aChildNode, 0 );
682  }
683  else if( cNodeName == wxT( "INTERLINEGAP" ) )
684  {
685  InterlineGap = GetXmlAttributeIDLong( aChildNode, 0 );
686  }
687  else if( cNodeName == wxT( "BARLINEGAP" ) )
688  {
689  BarlineGap = GetXmlAttributeIDLong( aChildNode, 0 );
690  }
691  else if( cNodeName == wxT( "ALLOWBARTEXT" ) )
692  {
693  AllowBarredText = true;
694  }
695  else if( cNodeName == wxT( "ANGULARPRECISION" ) )
696  {
697  AngularPrecision = GetXmlAttributeIDLong( aChildNode, 0 );
698  }
699  else if( cNodeName == wxT( "DESIGNORIGIN" ) )
700  {
701  DesignOrigin.Parse( aChildNode->GetChildren(), aContext );
702  }
703  else if( cNodeName == wxT( "DESIGNAREA" ) )
704  {
705  std::vector<POINT> pts = ParseAllChildPoints( aChildNode, aContext, true, 2 );
706  DesignArea = std::make_pair( pts[0], pts[1] );
707  }
708  else if( cNodeName == wxT( "DESIGNREF" ) )
709  {
710  DesignOrigin.Parse( aChildNode->GetChildren(), aContext );
711  }
712  else if( cNodeName == wxT( "DESIGNLIMIT" ) )
713  {
714  DesignLimit.Parse( aChildNode->GetChildren(), aContext );
715  }
716  else
717  {
718  return false;
719  }
720 
721  return true;
722 }
std::pair< POINT, POINT > DesignArea
long AngularPrecision
Number of decimal points to display for angular dimensions.
UNITS Units
Units to display for linear dimensions.
long UnitDisplPrecision
Number of decimal points to display for linear dimensions.
XNODE * GetChildren() const
Definition: xnode.h:62
bool AllowBarredText
Specifies if barring is allowed in the design.
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 ...
static long GetXmlAttributeIDLong(XNODE *aNode, unsigned int aID, bool aIsRequired=true)
static UNITS ParseUnits(XNODE *aNode)
void Parse(XNODE *aNode, PARSER_CONTEXT *aContext) override
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)

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 545 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 546 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 542 of file cadstar_archive_parser.h.

◆ DesignArea

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

Definition at line 549 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 548 of file cadstar_archive_parser.h.

◆ DesignRef

LONGPOINT CADSTAR_ARCHIVE_PARSER::SETTINGS::DesignRef
inherited

Appears to be 0,0 always.

Definition at line 550 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 539 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 538 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 537 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: