29#include <template_fieldnames_lexer.h>
32using namespace TFIELD_T;
35#define REFERENCE_CANONICAL "Reference"
36#define VALUE_CANONICAL "Value"
37#define FOOTPRINT_CANONICAL "Footprint"
38#define DATASHEET_CANONICAL "Datasheet"
39#define DESCRIPTION_CANONICAL "Description"
49 if( !aTranslateForHI )
61 wxString str( wxS(
"Field" ) );
62#if wxUSE_UNICODE_WCHAR
63 str << std::to_wstring( aFieldNdx );
65 str << std::to_string( aFieldNdx );
77 default:
return wxString::Format(
_(
"Field%d" ), aFieldNdx );
87 out->
Print(
" visible" );
102 if( ( tok = in->NextTok() ) != T_name )
103 in->Expecting( T_name );
105 in->NeedSYMBOLorNUMBER();
111 while( (tok = in->NextTok() ) != T_RIGHT && tok != T_EOF )
121 in->NeedSYMBOLorNUMBER();
134 in->Expecting(
"value|url|visible" );
145 out->
Print(
"(templatefields" );
151 if( !temp.m_Name.IsEmpty() )
163 while( ( tok = in->NextTok() ) != T_RIGHT && tok != T_EOF )
170 case T_templatefields:
186 if( !field.
m_Name.IsEmpty() )
192 in->Unexpected( in->CurText() );
212 bool overriddenInProject =
false;
216 if( global.m_Name ==
project.m_Name )
218 overriddenInProject =
true;
223 if( !overriddenInProject )
245 if( temp.m_Name == aFieldName.
m_Name )
255 target.push_back( aFieldName );
262 TEMPLATE_FIELDNAMES_LEXER field_lexer(
TO_UTF8( aSerializedFieldNames ) );
266 parse( &field_lexer,
true );
316 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, bool aGlobal) const
Serialize this object out as text into the given OUTPUTFORMATTER.
wxString From_UTF8(const char *cstring)
#define TO_UTF8(wxstring)
Convert a wxString to a UTF8 encoded C string for all wxWidgets build modes.
Hold a name of a symbol's field, field value, and default visibility.
void Format(OUTPUTFORMATTER *out) 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 DESCRIPTION_CANONICAL
static wxString s_CanonicalDescription(DESCRIPTION_CANONICAL)
#define REFERENCE_CANONICAL
wxString GetCanonicalFieldName(int idx)
@ 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 5 are mandatory, and must be instantiated in SCH_COMPONENT and LIB_PART constructors.
@ REFERENCE_FIELD
Field Reference of part, i.e. "IC21".
@ DESCRIPTION_FIELD
Field Description of part, i.e. "1/4W 1% Metal Film Resistor".
std::vector< TEMPLATE_FIELDNAME > TEMPLATE_FIELDNAMES