KiCad PCB EDA Suite
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages Concepts
template_fieldnames.h
Go to the documentation of this file.
1/*
2 * This program source code file is part of KiCad, a free EDA CAD application.
3 *
4 * Copyright (C) 2010 SoftPLC Corporation, Dick Hollenbeck <dick@softplc.com>
5 * Copyright The KiCad Developers, see AUTHORS.TXT for contributors.
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, you may find one here:
19 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
20 * or you may search the http://www.gnu.org website for the version 2 license,
21 * or you may write to the Free Software Foundation, Inc.,
22 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
23 */
24
25#pragma once
26
27#include <wx/string.h>
28
29class OUTPUTFORMATTER;
30class TEMPLATE_FIELDNAMES_LEXER;
31
32
43enum class FIELD_T : int
44{
45 USER,
46 REFERENCE,
47 VALUE,
48 FOOTPRINT,
49 DATASHEET,
55};
56
57#define MANDATORY_FIELDS { FIELD_T::REFERENCE, \
58 FIELD_T::VALUE, \
59 FIELD_T::FOOTPRINT, \
60 FIELD_T::DATASHEET, \
61 FIELD_T::DESCRIPTION }
62
63#define GLOBALLABEL_MANDATORY_FIELDS { FIELD_T::INTERSHEET_REFS }
64
65#define SHEET_MANDATORY_FIELDS { FIELD_T::SHEET_NAME, \
66 FIELD_T::SHEET_FILENAME }
67
68// A helper to call GetDefaultFieldName with or without translation.
69// Translation should be used only to display field names in dialogs
70#define DO_TRANSLATE true
71
72
81wxString GetDefaultFieldName( FIELD_T aFieldId, bool aTranslateForHI );
82wxString GetUserFieldName( int aFieldNdx, bool aTranslateForHI );
83
84
85inline wxString GetCanonicalFieldName( FIELD_T aFieldType )
86{
87 return GetDefaultFieldName( aFieldType, !DO_TRANSLATE );
88}
89
90
97{
99 m_Visible( false ),
100 m_URL( false )
101 {
102 }
103
104 TEMPLATE_FIELDNAME( const wxString& aName ) :
105 m_Name( aName ),
106 m_Visible( false ),
107 m_URL( false )
108 {
109 }
110
112 {
113 m_Name = ref.m_Name;
114 m_Visible = ref.m_Visible;
115 m_URL = ref.m_URL;
116 }
117
121 void Format( OUTPUTFORMATTER* out ) const ;
122
135 void Parse( TEMPLATE_FIELDNAMES_LEXER* aSpec );
136
137 wxString m_Name; // The field name
138 bool m_Visible; // Field defaults to being visible in schematic.
139 bool m_URL; // If field should have a browse button
140};
141
142
144{
145public:
147 m_resolvedDirty( true )
148 { }
149
153 void Format( OUTPUTFORMATTER* out, bool aGlobal ) const ;
154
165 void AddTemplateFieldName( const TEMPLATE_FIELDNAME& aFieldName, bool aGlobal );
166
170 void AddTemplateFieldNames( const wxString& aSerializedFieldNames );
171
175 void DeleteAllFieldNameTemplates( bool aGlobal );
176
180 const std::vector<TEMPLATE_FIELDNAME>& GetTemplateFieldNames();
181
185 const std::vector<TEMPLATE_FIELDNAME>& GetTemplateFieldNames( bool aGlobal );
186
193 const TEMPLATE_FIELDNAME* GetFieldName( const wxString& aName );
194
195protected:
196 void resolveTemplates();
197
198 void parse( TEMPLATE_FIELDNAMES_LEXER* in, bool aGlobal );
199
200private:
201 std::vector<TEMPLATE_FIELDNAME> m_globals;
202 std::vector<TEMPLATE_FIELDNAME> m_project;
203
204 // Combined list. Project templates override global ones.
205 std::vector<TEMPLATE_FIELDNAME> m_resolved;
207};
An interface used to output 8 bit text in a convenient way.
Definition: richio.h:322
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.
const std::vector< TEMPLATE_FIELDNAME > & GetTemplateFieldNames()
Return a template field name list for read only access.
std::vector< TEMPLATE_FIELDNAME > m_resolved
void resolveTemplates()
Flatten project and global templates into a single list.
std::vector< TEMPLATE_FIELDNAME > m_project
const TEMPLATE_FIELDNAME * GetFieldName(const wxString &aName)
Search for aName in the template field name list.
void DeleteAllFieldNameTemplates(bool aGlobal)
Delete the entire contents.
void parse(TEMPLATE_FIELDNAMES_LEXER *in, bool aGlobal)
std::vector< TEMPLATE_FIELDNAME > m_globals
void Format(OUTPUTFORMATTER *out, bool aGlobal) const
Serialize this object out as text into the given OUTPUTFORMATTER.
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.
TEMPLATE_FIELDNAME(const wxString &aName)
TEMPLATE_FIELDNAME(const TEMPLATE_FIELDNAME &ref)
#define DO_TRANSLATE
FIELD_T
The set of all field indices assuming an array like sequence that a SCH_COMPONENT or LIB_PART can hol...
@ SHEET_FILENAME
@ USER
The field ID hasn't been set yet; field is invalid.
@ INTERSHEET_REFS
Global label cross-reference page numbers.
@ DESCRIPTION
Field Description of part, i.e. "1/4W 1% Metal Film Resistor".
@ FOOTPRINT
Field Name Module PCB, i.e. "16DIP300".
@ DATASHEET
name of datasheet
@ REFERENCE
Field Reference of part, i.e. "IC21".
@ VALUE
Field Value of part, i.e. "3.3K".
wxString GetUserFieldName(int aFieldNdx, bool aTranslateForHI)
wxString GetCanonicalFieldName(FIELD_T aFieldType)
wxString GetDefaultFieldName(FIELD_T aFieldId, bool aTranslateForHI)
Return a default symbol field name for a mandatory field type.