31using namespace TFIELD_T;
34#define REFERENCE_CANONICAL "Reference"
35#define VALUE_CANONICAL "Value"
36#define FOOTPRINT_CANONICAL "Footprint"
37#define DATASHEET_CANONICAL "Datasheet"
46 if( !aTranslateForHI )
74 out->
Print( 0,
" visible" );
77 out->
Print( 0,
" url" );
79 out->
Print( 0,
")\n" );
89 if( ( tok = in->NextTok() ) != T_name )
90 in->Expecting( T_name );
92 in->NeedSYMBOLorNUMBER();
98 while( (tok = in->NextTok() ) != T_RIGHT && tok != T_EOF )
108 in->NeedSYMBOLorNUMBER();
121 in->Expecting(
"value|url|visible" );
132 out->
Print( nestLevel,
"(templatefields" );
137 temp.Format( out, nestLevel+1 );
139 out->
Print( 0,
")\n" );
147 while( ( tok = in->NextTok() ) != T_RIGHT && tok != T_EOF )
154 case T_templatefields:
175 in->Unexpected( in->CurText() );
197 if( global.m_Name ==
project.m_Name )
222 if( temp.m_Name == aFieldName.
m_Name )
232 target.push_back( aFieldName );
239 TEMPLATE_FIELDNAMES_LEXER field_lexer(
TO_UTF8( aSerializedFieldNames ) );
243 parse( &field_lexer,
true );
293 if( field.m_Name == aName )
Hold an error message and may be used when throwing exceptions containing meaningful error messages.
TEMPLATE_FIELDNAMES m_globals
void AddTemplateFieldName(const TEMPLATE_FIELDNAME &aFieldName, bool aGlobal)
Insert or append a wanted symbol field name into the field names template.
void AddTemplateFieldNames(const wxString &aSerializedFieldNames)
Add a serialized list of template field names.
TEMPLATE_FIELDNAMES m_project
TEMPLATE_FIELDNAMES m_resolved
const TEMPLATE_FIELDNAME * GetFieldName(const wxString &aName)
Search for aName in the template field name list.
void DeleteAllFieldNameTemplates(bool aGlobal)
Delete the entire contents.
const TEMPLATE_FIELDNAMES & GetTemplateFieldNames()
Return a template field name list for read only access.
void parse(TEMPLATE_FIELDNAMES_LEXER *in, bool aGlobal)
void Format(OUTPUTFORMATTER *out, int nestLevel, bool aGlobal) const
Serialize this object out as text into the given OUTPUTFORMATTER.
This file contains miscellaneous commonly used macros and functions.
#define TO_UTF8(wxstring)
Convert a wxString to a UTF8 encoded C string for all wxWidgets build modes.
static wxString FROM_UTF8(const char *cstring)
Convert a UTF8 encoded C string to a wxString for all wxWidgets build modes.
void Format(OUTPUTFORMATTER *out, int aNestLevel, int aCtl, const CPTREE &aTree)
Output a PTREE into s-expression format via an OUTPUTFORMATTER derivative.
Hold a name of a symbol's field, field value, and default visibility.
void Format(OUTPUTFORMATTER *out, int nestLevel) const
Serialize this object out as text into the given OUTPUTFORMATTER.
void Parse(TEMPLATE_FIELDNAMES_LEXER *aSpec)
Fill this object from information in the input stream aSpec, which is a #TEMPLATE_FIELDNAMES_LEXER.
static const wxString GetDefaultFieldName(int aFieldNdx, bool aTranslateForHI=false)
Return a default symbol field name for field aFieldNdx for all components.
#define FOOTPRINT_CANONICAL
static wxString s_CanonicalReference(REFERENCE_CANONICAL)
static wxString s_CanonicalValue(VALUE_CANONICAL)
static wxString s_CanonicalFootprint(FOOTPRINT_CANONICAL)
static wxString s_CanonicalDatasheet(DATASHEET_CANONICAL)
#define DATASHEET_CANONICAL
#define REFERENCE_CANONICAL
@ DATASHEET_FIELD
name of datasheet
@ FOOTPRINT_FIELD
Field Name Module PCB, i.e. "16DIP300".
@ VALUE_FIELD
Field Value of part, i.e. "3.3K".
@ MANDATORY_FIELDS
The first 4 are mandatory, and must be instantiated in SCH_COMPONENT and LIB_PART constructors.
@ REFERENCE_FIELD
Field Reference of part, i.e. "IC21".
std::vector< TEMPLATE_FIELDNAME > TEMPLATE_FIELDNAMES