KiCad PCB EDA Suite
Loading...
Searching...
No Matches
DSN::STRUCTURE Class Reference

#include <specctra.h>

Inheritance diagram for DSN::STRUCTURE:
DSN::ELEM_HOLDER DSN::ELEM

Public Member Functions

 STRUCTURE (ELEM *aParent)
 
 ~STRUCTURE ()
 
void SetBOUNDARY (BOUNDARY *aBoundary)
 
void SetPlaceBOUNDARY (BOUNDARY *aBoundary)
 
void FormatContents (OUTPUTFORMATTER *out, int nestLevel) override
 Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.
 
UNIT_RESGetUnits () const override
 Return the units for this section.
 
int FindElem (DSN_T aType, int instanceNum=0)
 Find a particular instance number of a given type of ELEM.
 
int Length () const
 Return the number of ELEMs in this holder.
 
void Append (ELEM *aElem)
 
ELEMReplace (int aIndex, ELEM *aElem)
 
ELEMRemove (int aIndex)
 
void Insert (int aIndex, ELEM *aElem)
 
ELEMAt (int aIndex) const
 
ELEMoperator[] (int aIndex) const
 
void Delete (int aIndex)
 
DSN_T Type () const
 
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.
 
void SetParent (ELEM *aParent)
 

Protected Member Functions

std::string makeHash ()
 Return a string which uniquely represents this ELEM among other ELEMs of the same derived class as "this" one.
 

Protected Attributes

DSN_T type
 
ELEMparent
 

Static Protected Attributes

static STRING_FORMATTER sf
 

Private Types

typedef boost::ptr_vector< REGIONREGIONS
 
typedef boost::ptr_vector< GRIDGRIDS
 
typedef boost::ptr_vector< ELEMELEM_ARRAY
 

Private Attributes

UNIT_RESm_unit
 
LAYERS m_layers
 
LAYER_NOISE_WEIGHTm_layer_noise_weight
 
BOUNDARYm_boundary
 
BOUNDARYm_place_boundary
 
VIAm_via
 
CONTROLm_control
 
RULEm_rules
 
KEEPOUTS m_keepouts
 
COPPER_PLANES m_planes
 
REGIONS m_regions
 
RULEm_place_rules
 
GRIDS m_grids
 
ELEM_ARRAY kids
 ELEM pointers.
 

Friends

class SPECCTRA_DB
 

Detailed Description

Definition at line 1559 of file specctra.h.

Member Typedef Documentation

◆ ELEM_ARRAY

typedef boost::ptr_vector<ELEM> DSN::ELEM_HOLDER::ELEM_ARRAY
privateinherited

Definition at line 363 of file specctra.h.

◆ GRIDS

typedef boost::ptr_vector<GRID> DSN::STRUCTURE::GRIDS
private

Definition at line 1684 of file specctra.h.

◆ REGIONS

typedef boost::ptr_vector<REGION> DSN::STRUCTURE::REGIONS
private

Definition at line 1679 of file specctra.h.

Constructor & Destructor Documentation

◆ STRUCTURE()

DSN::STRUCTURE::STRUCTURE ( ELEM * aParent)
inline

◆ ~STRUCTURE()

DSN::STRUCTURE::~STRUCTURE ( )
inline

Member Function Documentation

◆ Append()

◆ At()

ELEM * DSN::ELEM_HOLDER::At ( int aIndex) const
inlineinherited

◆ Delete()

void DSN::ELEM_HOLDER::Delete ( int aIndex)
inlineinherited

Definition at line 358 of file specctra.h.

References kids.

◆ FindElem()

int DSN::ELEM_HOLDER::FindElem ( DSN_T aType,
int instanceNum = 0 )
inherited

Find a particular instance number of a given type of ELEM.

Parameters
aTypeThe type of ELEM to find
instanceNumThe instance number of to find: 0 for first, 1 for second, etc.
Returns
int - The index into the kids array or -1 if not found.

Definition at line 3799 of file specctra.cpp.

References kids, T, and DSN::ELEM::Type().

◆ Format()

void DSN::ELEM::Format ( OUTPUTFORMATTER * out,
int nestLevel )
virtualinherited

Write this object as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.

Parameters
outThe formatter to write to.
nestLevelA multiple of the number of spaces to precede the output with.
Exceptions
IO_ERRORif a system error writing the output, such as a full disk.

Reimplemented in DSN::ANCESTOR, DSN::BOUNDARY, DSN::CIRCLE, DSN::CLASS, DSN::COMP_ORDER, DSN::COMPONENT, DSN::CONTROL, DSN::FROMTO, DSN::GRID, DSN::IMAGE, DSN::KEEPOUT, DSN::LAYER, DSN::LAYER_NOISE_WEIGHT, DSN::LAYER_RULE, DSN::NET, DSN::NET_OUT, DSN::PADSTACK, DSN::PATH, DSN::PCB, DSN::PIN, DSN::PLACE, DSN::QARC, DSN::RECTANGLE, DSN::RULE, DSN::SESSION, DSN::SHAPE, DSN::SPECCTRA_LAYER_PAIR, DSN::STRINGPROP, DSN::SUPPLY_PIN, DSN::TOKPROP, DSN::UNIT_RES, DSN::VIA, DSN::WINDOW, DSN::WIRE, and DSN::WIRE_VIA.

Definition at line 3782 of file specctra.cpp.

References FormatContents(), Name(), and OUTPUTFORMATTER::Print().

Referenced by DSN::CONTROL::Format(), DSN::ELEM_HOLDER::FormatContents(), and DSN::STRUCTURE::FormatContents().

◆ FormatContents()

void DSN::STRUCTURE::FormatContents ( OUTPUTFORMATTER * out,
int nestLevel )
inlineoverridevirtual

Write the contents as ASCII out to an OUTPUTFORMATTER according to the SPECCTRA DSN format.

This is the same as Format() except that the outer wrapper is not included.

Parameters
outThe formatter to write to.
nestLevelA multiple of the number of spaces to precede the output with.
Exceptions
IO_ERRORif a system error writing the output, such as a full disk.

Reimplemented from DSN::ELEM_HOLDER.

Definition at line 1605 of file specctra.h.

References DSN::ELEM_HOLDER::At(), DSN::ELEM::Format(), DSN::ELEM_HOLDER::Length(), m_boundary, m_control, m_grids, m_keepouts, m_layer_noise_weight, m_layers, m_place_boundary, m_place_rules, m_planes, m_regions, m_rules, m_unit, and m_via.

◆ GetUnits()

UNIT_RES * DSN::STRUCTURE::GetUnits ( ) const
inlineoverridevirtual

Return the units for this section.

Derived classes may override this to check for section specific overrides.

Returns
an element from a local or parent scope.

Reimplemented from DSN::ELEM.

Definition at line 1652 of file specctra.h.

References DSN::ELEM::GetUnits(), and m_unit.

◆ Insert()

void DSN::ELEM_HOLDER::Insert ( int aIndex,
ELEM * aElem )
inlineinherited

Definition at line 344 of file specctra.h.

References DSN::ELEM::ELEM(), and kids.

◆ Length()

int DSN::ELEM_HOLDER::Length ( ) const
inlineinherited

Return the number of ELEMs in this holder.

Returns
the count of children elements.

Definition at line 322 of file specctra.h.

References kids.

Referenced by DSN::CONTROL::Format(), FormatContents(), DSN::STRUCTURE::FormatContents(), and DSN::SPECCTRA_DB::makeVIA().

◆ makeHash()

std::string DSN::ELEM::makeHash ( )
inlineprotectedinherited

Return a string which uniquely represents this ELEM among other ELEMs of the same derived class as "this" one.

It is not usable for all derived classes, only those which plan for it by implementing a FormatContents() function that captures all info which will be used in the subsequent string compare. THIS SHOULD NORMALLY EXCLUDE THE TYPENAME, AND INSTANCE NAME OR ID AS WELL.

Definition at line 268 of file specctra.h.

References FormatContents(), and sf.

Referenced by DSN::IMAGE::Compare(), and DSN::PADSTACK::Compare().

◆ Name()

◆ operator[]()

ELEM * DSN::ELEM_HOLDER::operator[] ( int aIndex) const
inlineinherited

Definition at line 353 of file specctra.h.

References At(), and DSN::ELEM::ELEM().

◆ Remove()

ELEM * DSN::ELEM_HOLDER::Remove ( int aIndex)
inlineinherited

Definition at line 338 of file specctra.h.

References DSN::ELEM::ELEM(), and kids.

◆ Replace()

ELEM * DSN::ELEM_HOLDER::Replace ( int aIndex,
ELEM * aElem )
inlineinherited

Definition at line 332 of file specctra.h.

References DSN::ELEM::ELEM(), and kids.

◆ SetBOUNDARY()

void DSN::STRUCTURE::SetBOUNDARY ( BOUNDARY * aBoundary)
inline

Definition at line 1587 of file specctra.h.

References m_boundary.

◆ SetParent()

◆ SetPlaceBOUNDARY()

void DSN::STRUCTURE::SetPlaceBOUNDARY ( BOUNDARY * aBoundary)
inline

Definition at line 1596 of file specctra.h.

References m_place_boundary.

◆ Type()

Friends And Related Symbol Documentation

◆ SPECCTRA_DB

friend class SPECCTRA_DB
friend

Definition at line 1661 of file specctra.h.

References SPECCTRA_DB.

Referenced by SPECCTRA_DB.

Member Data Documentation

◆ kids

ELEM_ARRAY DSN::ELEM_HOLDER::kids
privateinherited

ELEM pointers.

Definition at line 365 of file specctra.h.

Referenced by Append(), At(), Delete(), FindElem(), Insert(), Length(), Remove(), and Replace().

◆ m_boundary

BOUNDARY* DSN::STRUCTURE::m_boundary
private

◆ m_control

CONTROL* DSN::STRUCTURE::m_control
private

Definition at line 1672 of file specctra.h.

Referenced by DSN::SPECCTRA_DB::doSTRUCTURE(), FormatContents(), STRUCTURE(), and ~STRUCTURE().

◆ m_grids

GRIDS DSN::STRUCTURE::m_grids
private

Definition at line 1685 of file specctra.h.

Referenced by DSN::SPECCTRA_DB::doSTRUCTURE(), and FormatContents().

◆ m_keepouts

KEEPOUTS DSN::STRUCTURE::m_keepouts
private

Definition at line 1675 of file specctra.h.

Referenced by DSN::SPECCTRA_DB::doSTRUCTURE(), and FormatContents().

◆ m_layer_noise_weight

LAYER_NOISE_WEIGHT* DSN::STRUCTURE::m_layer_noise_weight
private

Definition at line 1667 of file specctra.h.

Referenced by DSN::SPECCTRA_DB::doSTRUCTURE(), FormatContents(), STRUCTURE(), and ~STRUCTURE().

◆ m_layers

LAYERS DSN::STRUCTURE::m_layers
private

Definition at line 1665 of file specctra.h.

Referenced by DSN::SPECCTRA_DB::doSTRUCTURE(), and FormatContents().

◆ m_place_boundary

BOUNDARY* DSN::STRUCTURE::m_place_boundary
private

◆ m_place_rules

RULE* DSN::STRUCTURE::m_place_rules
private

Definition at line 1682 of file specctra.h.

Referenced by DSN::SPECCTRA_DB::doSTRUCTURE(), FormatContents(), STRUCTURE(), and ~STRUCTURE().

◆ m_planes

COPPER_PLANES DSN::STRUCTURE::m_planes
private

Definition at line 1677 of file specctra.h.

Referenced by DSN::SPECCTRA_DB::doSTRUCTURE(), and FormatContents().

◆ m_regions

REGIONS DSN::STRUCTURE::m_regions
private

Definition at line 1680 of file specctra.h.

Referenced by DSN::SPECCTRA_DB::doSTRUCTURE(), and FormatContents().

◆ m_rules

RULE* DSN::STRUCTURE::m_rules
private

◆ m_unit

UNIT_RES* DSN::STRUCTURE::m_unit
private

◆ m_via

VIA* DSN::STRUCTURE::m_via
private

◆ parent

ELEM* DSN::ELEM::parent
protectedinherited

Definition at line 281 of file specctra.h.

Referenced by ELEM(), GetUnits(), and SetParent().

◆ sf

STRING_FORMATTER DSN::ELEM::sf
staticprotectedinherited

Definition at line 278 of file specctra.h.

Referenced by makeHash().

◆ type

DSN_T DSN::ELEM::type
protectedinherited

Definition at line 280 of file specctra.h.

Referenced by DSN::SPECCTRA_DB::doNET(), ELEM(), DSN::UNIT_RES::Format(), Name(), and Type().


The documentation for this class was generated from the following file: