KiCad PCB EDA Suite
Loading...
Searching...
No Matches
sch_field.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) 2015 Jean-Pierre Charras, jp.charras at wanadoo.fr
5 * Copyright (C) 2022 CERN
6 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License
10 * as published by the Free Software Foundation; either version 2
11 * of the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, you may find one here:
20 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
21 * or you may search the http://www.gnu.org website for the version 2 license,
22 * or you may write to the Free Software Foundation, Inc.,
23 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
24 */
25
26#ifndef CLASS_SCH_FIELD_H
27#define CLASS_SCH_FIELD_H
28
29
30#include <eda_text.h>
31#include <sch_item.h>
32#include <template_fieldnames.h>
33#include <general.h>
34#include <string_utils.h>
35#include "scintilla_tricks.h"
36#include <algorithm>
37
38class SCH_EDIT_FRAME;
39class SCH_TEXT;
40
41
42class SCH_FIELD : public SCH_ITEM, public EDA_TEXT
43{
44public:
45 SCH_FIELD(); // For std::map::operator[]
46
47 SCH_FIELD( SCH_ITEM* aParent, FIELD_T aFieldId = FIELD_T::USER,
48 const wxString& aName = wxEmptyString );
49
50 SCH_FIELD( SCH_ITEM* aParent, SCH_TEXT* aText );
51
52 SCH_FIELD( const SCH_FIELD& aText );
53
54 ~SCH_FIELD() override
55 { }
56
57 SCH_FIELD& operator=( const SCH_FIELD& aField );
58
59 static bool ClassOf( const EDA_ITEM* aItem )
60 {
61 return aItem && SCH_FIELD_T == aItem->Type();
62 }
63
64 wxString GetClass() const override
65 {
66 return wxT( "SCH_FIELD" );
67 }
68
69 bool IsType( const std::vector<KICAD_T>& aScanTypes ) const override
70 {
71 if( SCH_ITEM::IsType( aScanTypes ) )
72 return true;
73
74 for( KICAD_T scanType : aScanTypes )
75 {
77 return true;
78 else if ( scanType == SCH_FIELD_LOCATE_VALUE_T && m_id == FIELD_T::VALUE )
79 return true;
80 else if ( scanType == SCH_FIELD_LOCATE_FOOTPRINT_T && m_id == FIELD_T::FOOTPRINT )
81 return true;
82 else if ( scanType == SCH_FIELD_LOCATE_DATASHEET_T && m_id == FIELD_T::DATASHEET )
83 return true;
84 }
85
86 return false;
87 }
88
89 wxString GetFriendlyName() const override
90 {
91 return _( "Field" );
92 }
93
94 bool IsHypertext() const override;
95
96 void DoHypertextAction( EDA_DRAW_FRAME* aFrame ) const override;
97
104 wxString GetName( bool aUseDefaultName = true ) const;
105
110 wxString GetCanonicalName() const;
111
112 void SetName( const wxString& aName );
113
114 void SetText( const wxString& aText ) override;
115
116 FIELD_T GetId() const { return m_id; }
117
118 int GetOrdinal() const
119 {
120 return IsMandatory() ? (int) m_id : m_ordinal;
121 }
122 void SetOrdinal( int aOrdinal )
123 {
125 m_ordinal = aOrdinal;
126 }
127
133 wxString GetShownName() const;
134 wxString GetShownText( const SCH_SHEET_PATH* aPath, bool aAllowExtraText, int aDepth = 0 ) const;
135
136 wxString GetShownText( bool aAllowExtraText, int aDepth = 0 ) const override;
137
147 wxString GetFullText( int unit = 1 ) const;
148
154 bool IsEmpty()
155 {
156 wxString name( m_name );
157 wxString value( GetText() );
158
159 return name.Trim().empty() && value.Trim().empty();
160 }
161
162 int GetSchTextSize() const { return GetTextWidth(); }
163 void SetSchTextSize( int aSize ) { SetTextSize( VECTOR2I( aSize, aSize ) ); }
164
165 COLOR4D GetFieldColor() const;
166
167 void SetLastResolvedState( const SCH_ITEM* aItem ) override
168 {
169 const SCH_FIELD* aField = dynamic_cast<const SCH_FIELD*>( aItem );
170
171 if( aField )
173 }
174
175 std::vector<int> ViewGetLayers() const override;
176
178
182 EDA_ANGLE GetDrawRotation() const override;
183
184 KIFONT::FONT* GetDrawFont( const RENDER_SETTINGS* aSettings ) const override;
185
186 const BOX2I GetBoundingBox() const override;
187
192 bool IsHorizJustifyFlipped() const;
193 bool IsVertJustifyFlipped() const;
194
197
200
201 bool IsNameShown() const { return m_showName; }
202 void SetNameShown( bool aShown = true ) { m_showName = aShown; }
203
210 bool IsGeneratedField() const { return m_isGeneratedField; }
211
212 bool CanAutoplace() const { return m_allowAutoPlace; }
213 void SetCanAutoplace( bool aCanPlace ) { m_allowAutoPlace = aCanPlace; }
214
215 void swapData( SCH_ITEM* aItem ) override;
216
217 int GetPenWidth() const override;
218
219 bool IsAutoAdded() const { return m_autoAdded; }
220 void SetAutoAdded( bool aAutoAdded ) { m_autoAdded = aAutoAdded; }
221
222 bool ShowInChooser() const { return m_showInChooser; }
223 void SetShowInChooser( bool aShow = true ) { m_showInChooser = aShow; }
224
225 void ClearCaches() override;
226 void ClearRenderCache() override;
227
228 std::vector<std::unique_ptr<KIFONT::GLYPH>>*
229 GetRenderCache( const wxString& forResolvedText, const VECTOR2I& forPosition,
230 TEXT_ATTRIBUTES& aAttrs ) const;
231
232 void Move( const VECTOR2I& aMoveVector ) override
233 {
234 Offset( aMoveVector );
235 }
236
237 void Rotate( const VECTOR2I& aCenter, bool aRotateCCW ) override;
238
239 void MirrorVertically( int aCenter ) override;
240 void MirrorHorizontally( int aCenter ) override;
241
242 void BeginEdit( const VECTOR2I& aStartPoint ) override;
243 void CalcEdit( const VECTOR2I& aPosition ) override;
244
245 void OnScintillaCharAdded( SCINTILLA_TRICKS* aScintillaTricks,
246 wxStyledTextEvent &aEvent ) const;
247
248 bool Matches( const EDA_SEARCH_DATA& aSearchData, void* aAuxData ) const override;
249
250 bool Replace( const EDA_SEARCH_DATA& aSearchData, void* aAuxData = nullptr ) override;
251
252 wxString GetItemDescription( UNITS_PROVIDER* aUnitsProvider, bool aFull ) const override;
253 void GetMsgPanelInfo( EDA_DRAW_FRAME* aFrame, std::vector<MSG_PANEL_ITEM>& aList ) override;
254
255 BITMAPS GetMenuImage() const override;
256
257 bool IsReplaceable() const override;
258
260
261 VECTOR2I GetPosition() const override;
262 void SetPosition( const VECTOR2I& aPosition ) override;
263
265
266 bool HitTest( const VECTOR2I& aPosition, int aAccuracy = 0 ) const override;
267 bool HitTest( const BOX2I& aRect, bool aContained, int aAccuracy = 0 ) const override;
268 bool HitTest( const SHAPE_LINE_CHAIN& aPoly, bool aContained ) const override;
269
270 void Plot( PLOTTER* aPlotter, bool aBackground, const SCH_PLOT_OPTS& aPlotOpts,
271 int aUnit, int aBodyStyle, const VECTOR2I& aOffset, bool aDimmed ) override;
272
273 EDA_ITEM* Clone() const override;
274
282 void ImportValues( const SCH_FIELD& aSource );
283
291 void Copy( SCH_FIELD* aTarget ) const;
292
293 bool IsMandatory() const;
294
295 bool operator <( const SCH_ITEM& aItem ) const override;
296
297 double Similarity( const SCH_ITEM& aItem ) const override;
298
299 bool operator==( const SCH_ITEM& aItem ) const override;
300 bool operator==( const SCH_FIELD& aItem ) const;
301
302#if defined(DEBUG)
303 void Show( int nestLevel, std::ostream& os ) const override { ShowDummy( os ); }
304#endif
305
306protected:
308
309 const KIFONT::METRICS& getFontMetrics() const override { return GetFontMetrics(); }
310
323 int compare( const SCH_ITEM& aOther, int aCompareFlags = 0 ) const override;
324
325 void setId( FIELD_T aId );
326
327 wxString getUnescapedText( const SCH_SHEET_PATH* aPath = nullptr,
328 const wxString& aVariantName = wxEmptyString ) const;
329
330private:
333 wxString m_name;
334
339
342
343 mutable bool m_renderCacheValid;
345 mutable std::vector<std::unique_ptr<KIFONT::GLYPH>> m_renderCache;
346
348};
349
350
351inline int NextFieldOrdinal( const std::vector<SCH_FIELD>& aFields )
352{
353 int ordinal = 42; // Arbitrarily larger than any mandatory FIELD_T id
354
355 for( const SCH_FIELD& field : aFields )
356 ordinal = std::max( ordinal, field.GetOrdinal() + 1 );
357
358 return ordinal;
359}
360
361
362inline const SCH_FIELD* FindField( const std::vector<SCH_FIELD>& aFields, FIELD_T aFieldId )
363{
364 for( const SCH_FIELD& field : aFields )
365 {
366 if( field.GetId() == aFieldId )
367 return &field;
368 }
369
370 return nullptr;
371}
372
373
374inline SCH_FIELD* FindField( std::vector<SCH_FIELD>& aFields, FIELD_T aFieldId )
375{
376 auto& constFields = const_cast<const std::vector<SCH_FIELD>&>( aFields );
377 return const_cast<SCH_FIELD*>( FindField( constFields, aFieldId ) );
378}
379
380
381inline const SCH_FIELD* FindField( const std::vector<SCH_FIELD>& aFields,
382 const wxString& aFieldName )
383{
384 for( const SCH_FIELD& field : aFields )
385 {
386 if( field.GetName() == aFieldName )
387 return &field;
388 }
389
390 return nullptr;
391}
392
393
394inline SCH_FIELD* FindField( std::vector<SCH_FIELD>& aFields, const wxString& aFieldName )
395{
396 auto& constFields = const_cast<const std::vector<SCH_FIELD>&>( aFields );
397 return const_cast<SCH_FIELD*>( FindField( constFields, aFieldName ) );
398}
399
400
401inline wxString GetFieldValue( const std::vector<SCH_FIELD>* aFields, FIELD_T aFieldType )
402{
403 if( !aFields )
404 return wxEmptyString;
405
406 if( const SCH_FIELD* field = FindField( *aFields, aFieldType ) )
407 return field->GetText();
408
409 return wxEmptyString;
410}
411
412
413inline std::string GetFieldValue( const std::vector<SCH_FIELD>* aFields,
414 const wxString& aFieldName, bool aResolve, int aDepth )
415{
416 if( !aFields )
417 return "";
418
419 if( const SCH_FIELD* field = FindField( *aFields, aFieldName ) )
420 return ( aResolve ? field->GetShownText( false, aDepth ) : field->GetText() ).ToStdString();
421
422 return "";
423}
424
425
426inline void SetFieldValue( std::vector<SCH_FIELD>& aFields, const wxString& aFieldName,
427 const std::string& aValue, bool aIsVisible = true )
428{
429 if( aValue == "" )
430 {
431 std::erase_if( aFields, [&]( const SCH_FIELD& field )
432 {
433 return field.GetName() == aFieldName;
434 } );
435 return;
436 }
437
438 if( SCH_FIELD* field = FindField( aFields, aFieldName ) )
439 {
440 field->SetText( aValue );
441 return;
442 }
443
444 SCH_ITEM* parent = static_cast<SCH_ITEM*>( aFields.at( 0 ).GetParent() );
445 aFields.emplace_back( parent, FIELD_T::USER, aFieldName );
446 aFields.back().SetText( aValue );
447 aFields.back().SetVisible( aIsVisible );
448}
449
450
451
452#endif /* CLASS_SCH_FIELD_H */
const char * name
BITMAPS
A list of all bitmap identifiers.
BOX2< VECTOR2I > BOX2I
Definition box2.h:922
The base class for create windows for drawing purpose.
A base class for most all the KiCad significant classes used in schematics and boards.
Definition eda_item.h:98
KICAD_T Type() const
Returns the type of object.
Definition eda_item.h:110
EDA_ITEM(EDA_ITEM *parent, KICAD_T idType, bool isSCH_ITEM=false, bool isBOARD_ITEM=false)
Definition eda_item.cpp:39
const VECTOR2I & GetTextPos() const
Definition eda_text.h:273
void SetTextSize(VECTOR2I aNewSize, bool aEnforceMinTextSize=true)
Definition eda_text.cpp:544
virtual const wxString & GetText() const
Return the string associated with the text object.
Definition eda_text.h:98
int GetTextWidth() const
Definition eda_text.h:264
void Offset(const VECTOR2I &aOffset)
Definition eda_text.cpp:607
EDA_TEXT(const EDA_IU_SCALE &aIuScale, const wxString &aText=wxEmptyString)
Definition eda_text.cpp:97
FONT is an abstract base class for both outline and stroke fonts.
Definition font.h:131
A color representation with 4 components: red, green, blue, alpha.
Definition color4d.h:104
Container for all the knowledge about how graphical objects are drawn on any output surface/device.
Base plotter engine class.
Definition plotter.h:121
Schematic editor (Eeschema) main window.
friend class SCH_IO_KICAD_SEXPR_PARSER
Definition sch_field.h:307
void ClearRenderCache() override
int compare(const SCH_ITEM &aOther, int aCompareFlags=0) const override
Provide the draw object specific comparison called by the == and < operators.
wxString GetClass() const override
Return the class name.
Definition sch_field.h:64
void SetOrdinal(int aOrdinal)
Definition sch_field.h:122
COLOR4D m_lastResolvedColor
Definition sch_field.h:347
bool IsAutoAdded() const
Definition sch_field.h:219
GR_TEXT_V_ALIGN_T GetEffectiveVertJustify() const
bool IsMandatory() const
wxString GetItemDescription(UNITS_PROVIDER *aUnitsProvider, bool aFull) const override
Return a user-visible description string of this item.
void Rotate(const VECTOR2I &aCenter, bool aRotateCCW) override
Rotate the item around aCenter 90 degrees in the clockwise direction.
wxString GetFullText(int unit=1) const
Return the text of a field.
~SCH_FIELD() override
Definition sch_field.h:54
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
std::vector< std::unique_ptr< KIFONT::GLYPH > > m_renderCache
Definition sch_field.h:345
void swapData(SCH_ITEM *aItem) override
Swap the internal data structures aItem with the schematic item.
VECTOR2I GetPosition() const override
void SetEffectiveHorizJustify(GR_TEXT_H_ALIGN_T)
int GetSchTextSize() const
Definition sch_field.h:162
bool Replace(const EDA_SEARCH_DATA &aSearchData, void *aAuxData=nullptr) override
Perform a text replace using the find and replace criteria in aSearchData on items that support text ...
void SetLastResolvedState(const SCH_ITEM *aItem) override
Definition sch_field.h:167
bool m_showName
Render the field name in addition to its value.
Definition sch_field.h:335
void Plot(PLOTTER *aPlotter, bool aBackground, const SCH_PLOT_OPTS &aPlotOpts, int aUnit, int aBodyStyle, const VECTOR2I &aOffset, bool aDimmed) override
Plot the item to aPlotter.
bool IsType(const std::vector< KICAD_T > &aScanTypes) const override
Check whether the item is one of the listed types.
Definition sch_field.h:69
EDA_ITEM * Clone() const override
Create a duplicate of this item with linked list members set to NULL.
BITMAPS GetMenuImage() const override
Return a pointer to an image to be used in menus.
static bool ClassOf(const EDA_ITEM *aItem)
Definition sch_field.h:59
bool IsNameShown() const
Definition sch_field.h:201
bool IsHypertext() const override
Allow items to support hypertext actions when hovered/clicked.
bool m_autoAdded
Was this field automatically added to a LIB_SYMBOL?
Definition sch_field.h:340
double Similarity(const SCH_ITEM &aItem) const override
Return a measure of how likely the other object is to represent the same object.
bool IsGeneratedField() const
Generated fields are fields whose names are variables like ${VAR}.
Definition sch_field.h:210
bool HitTest(const VECTOR2I &aPosition, int aAccuracy=0) const override
Test if aPosition is inside or on the boundary of this item.
SCH_LAYER_ID GetDefaultLayer() const
bool IsHorizJustifyFlipped() const
Return whether the field will be rendered with the horizontal justification inverted due to rotation ...
bool IsVertJustifyFlipped() const
EDA_ANGLE GetDrawRotation() const override
Adjusters to allow EDA_TEXT to draw/print/etc.
void SetEffectiveVertJustify(GR_TEXT_V_ALIGN_T)
void CalcEdit(const VECTOR2I &aPosition) override
Calculate the attributes of an item at aPosition when it is being edited.
bool Matches(const EDA_SEARCH_DATA &aSearchData, void *aAuxData) const override
Compare the item against the search criteria in aSearchData.
void MirrorVertically(int aCenter) override
Mirror item vertically about aCenter.
FIELD_T GetId() const
Definition sch_field.h:116
void SetCanAutoplace(bool aCanPlace)
Definition sch_field.h:213
void DoHypertextAction(EDA_DRAW_FRAME *aFrame) const override
int GetPenWidth() const override
wxString GetCanonicalName() const
Get a non-language-specific name for a field which can be used for storage, variable look-up,...
bool m_isGeneratedField
If the field name is a variable name (e.g.
Definition sch_field.h:337
int m_ordinal
Sort order for non-mandatory fields.
Definition sch_field.h:332
COLOR4D GetFieldColor() const
wxString getUnescapedText(const SCH_SHEET_PATH *aPath=nullptr, const wxString &aVariantName=wxEmptyString) const
wxString GetFriendlyName() const override
Definition sch_field.h:89
bool operator==(const SCH_ITEM &aItem) const override
SCH_FIELD & operator=(const SCH_FIELD &aField)
void ImportValues(const SCH_FIELD &aSource)
Copy parameters from a SCH_FIELD source.
void SetAutoAdded(bool aAutoAdded)
Definition sch_field.h:220
bool operator<(const SCH_ITEM &aItem) const override
FIELD_T m_id
Field id,.
Definition sch_field.h:331
wxString GetShownName() const
Get the field's name as displayed on the schematic or in the symbol fields table.
VECTOR2I GetLibPosition() const
Definition sch_field.h:259
void setId(FIELD_T aId)
int GetOrdinal() const
Definition sch_field.h:118
bool IsEmpty()
Return true if both the name and value of the field are empty.
Definition sch_field.h:154
bool m_renderCacheValid
Definition sch_field.h:343
KIFONT::FONT * GetDrawFont(const RENDER_SETTINGS *aSettings) const override
void BeginEdit(const VECTOR2I &aStartPoint) override
Begin drawing a symbol library draw item at aPosition.
void SetShowInChooser(bool aShow=true)
Definition sch_field.h:223
bool IsReplaceable() const override
Override this method in any derived object that supports test find and replace.
void SetSchTextSize(int aSize)
Definition sch_field.h:163
GR_TEXT_H_ALIGN_T GetEffectiveHorizJustify() const
std::vector< int > ViewGetLayers() const override
Return the all the layers within the VIEW the object is painted on.
wxString GetName(bool aUseDefaultName=true) const
Return the field name (not translated).
void SetPosition(const VECTOR2I &aPosition) override
void SetName(const wxString &aName)
wxString GetShownText(const SCH_SHEET_PATH *aPath, bool aAllowExtraText, int aDepth=0) const
void Move(const VECTOR2I &aMoveVector) override
Move the item by aMoveVector to a new position.
Definition sch_field.h:232
VECTOR2I m_renderCachePos
Definition sch_field.h:344
bool CanAutoplace() const
Definition sch_field.h:212
std::vector< std::unique_ptr< KIFONT::GLYPH > > * GetRenderCache(const wxString &forResolvedText, const VECTOR2I &forPosition, TEXT_ATTRIBUTES &aAttrs) const
void GetMsgPanelInfo(EDA_DRAW_FRAME *aFrame, std::vector< MSG_PANEL_ITEM > &aList) override
Populate aList of MSG_PANEL_ITEM objects with it's internal state for display purposes.
bool ShowInChooser() const
Definition sch_field.h:222
void ClearCaches() override
void SetText(const wxString &aText) override
VECTOR2I GetParentPosition() const
const KIFONT::METRICS & getFontMetrics() const override
Definition sch_field.h:309
bool m_showInChooser
This field is available as a data column for the chooser.
Definition sch_field.h:341
void OnScintillaCharAdded(SCINTILLA_TRICKS *aScintillaTricks, wxStyledTextEvent &aEvent) const
wxString m_name
Definition sch_field.h:333
void SetNameShown(bool aShown=true)
Definition sch_field.h:202
void MirrorHorizontally(int aCenter) override
Mirror item horizontally about aCenter.
void Copy(SCH_FIELD *aTarget) const
Copy parameters of this field to another field.
bool m_allowAutoPlace
This field can be autoplaced.
Definition sch_field.h:336
Base class for any item which can be embedded within the SCHEMATIC container class,...
Definition sch_item.h:167
SCH_ITEM(EDA_ITEM *aParent, KICAD_T aType, int aUnit=0, int aBodyStyle=0)
Definition sch_item.cpp:51
const KIFONT::METRICS & GetFontMetrics() const
Definition sch_item.cpp:622
bool IsType(const std::vector< KICAD_T > &aScanTypes) const override
Check whether the item is one of the listed types.
Definition sch_item.h:182
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
Add cut/copy/paste, dark theme, autocomplete and brace highlighting to a wxStyleTextCtrl instance.
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
#define _(s)
SCH_LAYER_ID
Eeschema drawing layers.
Definition layer_ids.h:449
wxString GetFieldValue(const std::vector< SCH_FIELD > *aFields, FIELD_T aFieldType)
Definition sch_field.h:401
const SCH_FIELD * FindField(const std::vector< SCH_FIELD > &aFields, FIELD_T aFieldId)
Definition sch_field.h:362
int NextFieldOrdinal(const std::vector< SCH_FIELD > &aFields)
Definition sch_field.h:351
void SetFieldValue(std::vector< SCH_FIELD > &aFields, const wxString &aFieldName, const std::string &aValue, bool aIsVisible=true)
Definition sch_field.h:426
FIELD_T
The set of all field indices assuming an array like sequence that a SCH_COMPONENT or LIB_PART can hol...
@ USER
The field ID hasn't been set yet; field is invalid.
@ 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".
GR_TEXT_H_ALIGN_T
This is API surface mapped to common.types.HorizontalAlignment.
GR_TEXT_V_ALIGN_T
This is API surface mapped to common.types.VertialAlignment.
KICAD_T
The set of class identification values stored in EDA_ITEM::m_structType.
Definition typeinfo.h:78
@ SCH_FIELD_LOCATE_REFERENCE_T
Definition typeinfo.h:184
@ SCH_FIELD_LOCATE_FOOTPRINT_T
Definition typeinfo.h:186
@ SCH_FIELD_T
Definition typeinfo.h:154
@ SCH_FIELD_LOCATE_VALUE_T
Definition typeinfo.h:185
@ SCH_FIELD_LOCATE_DATASHEET_T
Definition typeinfo.h:187
VECTOR2< int32_t > VECTOR2I
Definition vector2d.h:695