KiCad PCB EDA Suite
Loading...
Searching...
No Matches
pcbexpr_evaluator.cpp
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) 2019-2022 KiCad Developers, see AUTHORS.txt for contributors.
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 2
9 * of the License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, you may find one here:
18 * http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
19 * or you may search the http://www.gnu.org website for the version 2 license,
20 * or you may write to the Free Software Foundation, Inc.,
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
22 */
23
24
25#include <cstdio>
26#include <memory>
27#include <mutex>
28#include <board.h>
29#include <footprint.h>
30#include <lset.h>
32#include <pcbexpr_evaluator.h>
33#include <drc/drc_engine.h>
34
35/* --------------------------------------------------------------------------------------------
36 * Specialized Expression References
37 */
38
40{
41 wxASSERT( dynamic_cast<const PCBEXPR_CONTEXT*>( aCtx ) );
42
43 const PCBEXPR_CONTEXT* ctx = static_cast<const PCBEXPR_CONTEXT*>( aCtx );
44 BOARD_ITEM* item = ctx->GetItem( m_itemIndex );
45 return item;
46}
47
48
50{
51public:
53 LIBEVAL::VALUE( LayerName( aLayer ) ),
54 m_layer( aLayer )
55 {};
56
57 virtual bool EqualTo( LIBEVAL::CONTEXT* aCtx, const VALUE* b ) const override
58 {
59 // For boards with user-defined layer names there will be 2 entries for each layer
60 // in the ENUM_MAP: one for the canonical layer name and one for the user layer name.
61 // We need to check against both.
62
63 wxPGChoices& layerMap = ENUM_MAP<PCB_LAYER_ID>::Instance().Choices();
64 const wxString& layerName = b->AsString();
65 BOARD* board = static_cast<PCBEXPR_CONTEXT*>( aCtx )->GetBoard();
66
67 {
68 std::shared_lock<std::shared_mutex> readLock( board->m_CachesMutex );
69
70 auto i = board->m_LayerExpressionCache.find( layerName );
71
72 if( i != board->m_LayerExpressionCache.end() )
73 return i->second.Contains( m_layer );
74 }
75
76 LSET mask;
77
78 for( unsigned ii = 0; ii < layerMap.GetCount(); ++ii )
79 {
80 wxPGChoiceEntry& entry = layerMap[ii];
81
82 if( entry.GetText().Matches( layerName ) )
83 mask.set( ToLAYER_ID( entry.GetValue() ) );
84 }
85
86 {
87 std::unique_lock<std::shared_mutex> writeLock( board->m_CachesMutex );
88 board->m_LayerExpressionCache[ layerName ] = mask;
89 }
90
91 return mask.Contains( m_layer );
92 }
93
94protected:
96};
97
98
100{
101public:
102 PCBEXPR_PINTYPE_VALUE( const wxString& aPinTypeName ) :
103 LIBEVAL::VALUE( aPinTypeName )
104 {};
105
106 bool EqualTo( LIBEVAL::CONTEXT* aCtx, const VALUE* b ) const override
107 {
108 const wxString& thisStr = AsString();
109 const wxString& otherStr = b->AsString();
110
111 if( thisStr.IsSameAs( otherStr, false ) )
112 return true;
113
114 // Handle cases where the netlist token is different from the EEschema token
115 if( thisStr == wxT( "tri_state" ) )
116 return otherStr.IsSameAs( wxT( "Tri-state" ), false );
117
118 if( thisStr == wxT( "power_in" ) )
119 return otherStr.IsSameAs( wxT( "Power input" ), false );
120
121 if( thisStr == wxT( "power_out" ) )
122 return otherStr.IsSameAs( wxT( "Power output" ), false );
123
124 if( thisStr == wxT( "no_connect" ) )
125 return otherStr.IsSameAs( wxT( "Unconnected" ), false );
126
127 return false;
128 }
129};
130
131
133{
134public:
136 LIBEVAL::VALUE( wxEmptyString ),
137 m_item( aItem )
138 {};
139
140 const wxString& AsString() const override
141 {
142 const_cast<PCBEXPR_NETCLASS_VALUE*>( this )->Set(
145 }
146
147 bool EqualTo( LIBEVAL::CONTEXT* aCtx, const VALUE* b ) const override
148 {
149 if( const PCBEXPR_NETCLASS_VALUE* bValue = dynamic_cast<const PCBEXPR_NETCLASS_VALUE*>( b ) )
150 return *( m_item->GetEffectiveNetClass() )
151 == *( bValue->m_item->GetEffectiveNetClass() );
152 else
153 return LIBEVAL::VALUE::EqualTo( aCtx, b );
154 }
155
156 bool NotEqualTo( LIBEVAL::CONTEXT* aCtx, const LIBEVAL::VALUE* b ) const override
157 {
158 if( const PCBEXPR_NETCLASS_VALUE* bValue = dynamic_cast<const PCBEXPR_NETCLASS_VALUE*>( b ) )
159 return m_item->GetEffectiveNetClass() != bValue->m_item->GetEffectiveNetClass();
160 else
161 return LIBEVAL::VALUE::NotEqualTo( aCtx, b );
162 }
163
164protected:
166};
167
168
170{
171public:
173 LIBEVAL::VALUE( wxEmptyString ), m_item( dynamic_cast<FOOTPRINT*>( aItem ) )
174 {};
175
176 const wxString& AsString() const override
177 {
178 if( !m_item )
180
181 if( const COMPONENT_CLASS* compClass = m_item->GetComponentClass() )
182 {
183 const_cast<PCBEXPR_COMPONENT_CLASS_VALUE*>( this )->Set( compClass->GetFullName() );
184 }
185
187 }
188
189 bool EqualTo( LIBEVAL::CONTEXT* aCtx, const VALUE* b ) const override
190 {
191 if( const PCBEXPR_COMPONENT_CLASS_VALUE* bValue =
192 dynamic_cast<const PCBEXPR_COMPONENT_CLASS_VALUE*>( b ) )
193 {
194 if( !m_item || !bValue->m_item )
195 return LIBEVAL::VALUE::EqualTo( aCtx, b );
196
197 const COMPONENT_CLASS* aClass = m_item->GetComponentClass();
198 const COMPONENT_CLASS* bClass = bValue->m_item->GetComponentClass();
199
200 // Note this depends on COMPONENT_CLASS_MANAGER maintaining ownership
201 // of all unique component class objects
202 return aClass == bClass;
203 }
204 else
205 {
206 return LIBEVAL::VALUE::EqualTo( aCtx, b );
207 }
208 }
209
210 bool NotEqualTo( LIBEVAL::CONTEXT* aCtx, const LIBEVAL::VALUE* b ) const override
211 {
212 if( const PCBEXPR_COMPONENT_CLASS_VALUE* bValue =
213 dynamic_cast<const PCBEXPR_COMPONENT_CLASS_VALUE*>( b ) )
214 {
215 if( !m_item || !bValue->m_item )
216 return LIBEVAL::VALUE::EqualTo( aCtx, b );
217
218 const COMPONENT_CLASS* aClass = m_item->GetComponentClass();
219 const COMPONENT_CLASS* bClass = bValue->m_item->GetComponentClass();
220
221 // Note this depends on COMPONENT_CLASS_MANAGER maintaining ownership
222 // of all unique component class objects
223 return aClass != bClass;
224 }
225 else
226 {
227 return LIBEVAL::VALUE::NotEqualTo( aCtx, b );
228 }
229 }
230
231protected:
233};
234
235
237{
238public:
240 LIBEVAL::VALUE( wxEmptyString ),
241 m_item( aItem )
242 {};
243
244 const wxString& AsString() const override
245 {
246 const_cast<PCBEXPR_NET_VALUE*>( this )->Set( m_item->GetNetname() );
248 }
249
250 bool EqualTo( LIBEVAL::CONTEXT* aCtx, const VALUE* b ) const override
251 {
252 if( const PCBEXPR_NET_VALUE* bValue = dynamic_cast<const PCBEXPR_NET_VALUE*>( b ) )
253 return m_item->GetNetCode() == bValue->m_item->GetNetCode();
254 else
255 return LIBEVAL::VALUE::EqualTo( aCtx, b );
256 }
257
258 bool NotEqualTo( LIBEVAL::CONTEXT* aCtx, const LIBEVAL::VALUE* b ) const override
259 {
260 if( const PCBEXPR_NET_VALUE* bValue = dynamic_cast<const PCBEXPR_NET_VALUE*>( b ) )
261 return m_item->GetNetCode() != bValue->m_item->GetNetCode();
262 else
263 return LIBEVAL::VALUE::NotEqualTo( aCtx, b );
264 }
265
266protected:
268};
269
270
272{
273 PCBEXPR_CONTEXT* context = static_cast<PCBEXPR_CONTEXT*>( aCtx );
274
275 if( m_itemIndex == 2 )
276 return new PCBEXPR_LAYER_VALUE( context->GetLayer() );
277
278 BOARD_ITEM* item = GetObject( aCtx );
279
280 if( !item )
281 return new LIBEVAL::VALUE();
282
283 auto it = m_matchingTypes.find( TYPE_HASH( *item ) );
284
285 if( it == m_matchingTypes.end() )
286 {
287 // Don't force user to type "A.Type == 'via' && A.Via_Type == 'buried'" when the
288 // simpler "A.Via_Type == 'buried'" is perfectly clear. Instead, return an undefined
289 // value when the property doesn't appear on a particular object.
290
291 return new LIBEVAL::VALUE();
292 }
293 else
294 {
296 {
297 return new LIBEVAL::VALUE( (double) item->Get<int>( it->second ) );
298 }
299 else
300 {
301 wxString str;
302
303 if( !m_isEnum )
304 {
305 str = item->Get<wxString>( it->second );
306
307 if( it->second->Name() == wxT( "Pin Type" ) )
308 return new PCBEXPR_PINTYPE_VALUE( str );
309 else
310 return new LIBEVAL::VALUE( str );
311 }
312 else
313 {
314 const wxAny& any = item->Get( it->second );
315 PCB_LAYER_ID layer;
316
317 if( it->second->Name() == wxT( "Layer" )
318 || it->second->Name() == wxT( "Layer Top" )
319 || it->second->Name() == wxT( "Layer Bottom" ) )
320 {
321 if( any.GetAs<PCB_LAYER_ID>( &layer ) )
322 return new PCBEXPR_LAYER_VALUE( layer );
323 else if( any.GetAs<wxString>( &str ) )
324 return new PCBEXPR_LAYER_VALUE( context->GetBoard()->GetLayerID( str ) );
325 }
326 else
327 {
328 if( any.GetAs<wxString>( &str ) )
329 return new LIBEVAL::VALUE( str );
330 }
331 }
332
333 return new LIBEVAL::VALUE();
334 }
335 }
336}
337
338
340{
341 BOARD_CONNECTED_ITEM* item = dynamic_cast<BOARD_CONNECTED_ITEM*>( GetObject( aCtx ) );
342
343 if( !item )
344 return new LIBEVAL::VALUE();
345
346 return new PCBEXPR_NETCLASS_VALUE( item );
347}
348
349
351{
352 BOARD_ITEM* item = dynamic_cast<BOARD_ITEM*>( GetObject( aCtx ) );
353
354 if( !item || item->Type() != PCB_FOOTPRINT_T )
355 return new LIBEVAL::VALUE();
356
357 return new PCBEXPR_COMPONENT_CLASS_VALUE( item );
358}
359
360
362{
363 BOARD_CONNECTED_ITEM* item = dynamic_cast<BOARD_CONNECTED_ITEM*>( GetObject( aCtx ) );
364
365 if( !item )
366 return new LIBEVAL::VALUE();
367
368 return new PCBEXPR_NET_VALUE( item );
369}
370
371
373{
374 BOARD_ITEM* item = GetObject( aCtx );
375
376 if( !item )
377 return new LIBEVAL::VALUE();
378
379 return new LIBEVAL::VALUE( ENUM_MAP<KICAD_T>::Instance().ToString( item->Type() ) );
380}
381
382
384{
386
387 return registry.Get( aName.Lower() );
388}
389
390
391std::unique_ptr<LIBEVAL::VAR_REF> PCBEXPR_UCODE::CreateVarRef( const wxString& aVar,
392 const wxString& aField )
393{
395 std::unique_ptr<PCBEXPR_VAR_REF> vref;
396
397 // Check for a couple of very common cases and compile them straight to "object code".
398
399 if( aField.CmpNoCase( wxT( "NetClass" ) ) == 0 )
400 {
401 if( aVar == wxT( "A" ) )
402 return std::make_unique<PCBEXPR_NETCLASS_REF>( 0 );
403 else if( aVar == wxT( "B" ) )
404 return std::make_unique<PCBEXPR_NETCLASS_REF>( 1 );
405 else
406 return nullptr;
407 }
408 else if( aField.CmpNoCase( wxT( "ComponentClass" ) ) == 0 )
409 {
410 if( aVar == wxT( "A" ) )
411 return std::make_unique<PCBEXPR_COMPONENT_CLASS_REF>( 0 );
412 else if( aVar == wxT( "B" ) )
413 return std::make_unique<PCBEXPR_COMPONENT_CLASS_REF>( 1 );
414 else
415 return nullptr;
416 }
417 else if( aField.CmpNoCase( wxT( "NetName" ) ) == 0 )
418 {
419 if( aVar == wxT( "A" ) )
420 return std::make_unique<PCBEXPR_NETNAME_REF>( 0 );
421 else if( aVar == wxT( "B" ) )
422 return std::make_unique<PCBEXPR_NETNAME_REF>( 1 );
423 else
424 return nullptr;
425 }
426 else if( aField.CmpNoCase( wxT( "Type" ) ) == 0 )
427 {
428 if( aVar == wxT( "A" ) )
429 return std::make_unique<PCBEXPR_TYPE_REF>( 0 );
430 else if( aVar == wxT( "B" ) )
431 return std::make_unique<PCBEXPR_TYPE_REF>( 1 );
432 else
433 return nullptr;
434 }
435
436 if( aVar == wxT( "A" ) || aVar == wxT( "AB" ) )
437 vref = std::make_unique<PCBEXPR_VAR_REF>( 0 );
438 else if( aVar == wxT( "B" ) )
439 vref = std::make_unique<PCBEXPR_VAR_REF>( 1 );
440 else if( aVar == wxT( "L" ) )
441 vref = std::make_unique<PCBEXPR_VAR_REF>( 2 );
442 else
443 return nullptr;
444
445 if( aField.length() == 0 ) // return reference to base object
446 {
447 return vref;
448 }
449
450 wxString field( aField );
451 field.Replace( wxT( "_" ), wxT( " " ) );
452
453 for( const PROPERTY_MANAGER::CLASS_INFO& cls : propMgr.GetAllClasses() )
454 {
455 if( propMgr.IsOfType( cls.type, TYPE_HASH( BOARD_ITEM ) ) )
456 {
457 PROPERTY_BASE* prop = propMgr.GetProperty( cls.type, field );
458
459 if( prop )
460 {
461 vref->AddAllowedClass( cls.type, prop );
462
463 if( prop->TypeHash() == TYPE_HASH( int ) )
464 {
465 vref->SetType( LIBEVAL::VT_NUMERIC );
466 }
467 else if( prop->TypeHash() == TYPE_HASH( bool ) )
468 {
469 vref->SetType( LIBEVAL::VT_NUMERIC );
470 }
471 else if( prop->TypeHash() == TYPE_HASH( wxString ) )
472 {
473 vref->SetType( LIBEVAL::VT_STRING );
474 }
475 else if ( prop->HasChoices() )
476 { // it's an enum, we treat it as string
477 vref->SetType( LIBEVAL::VT_STRING );
478 vref->SetIsEnum ( true );
479 }
480 else
481 {
482 wxFAIL_MSG( wxT( "PCBEXPR_UCODE::createVarRef: Unknown property type." ) );
483 }
484 }
485 }
486 }
487
488 if( vref->GetType() == LIBEVAL::VT_UNDEFINED )
489 vref->SetType( LIBEVAL::VT_PARSE_ERROR );
490
491 return vref;
492}
493
494
496{
497 if( m_items[0] )
498 return m_items[0]->GetBoard();
499
500 return nullptr;
501}
502
503
504/* --------------------------------------------------------------------------------------------
505 * Unit Resolvers
506 */
507
508const std::vector<wxString>& PCBEXPR_UNIT_RESOLVER::GetSupportedUnits() const
509{
510 static const std::vector<wxString> pcbUnits = { wxT( "mil" ), wxT( "mm" ), wxT( "in" ) };
511
512 return pcbUnits;
513}
514
515
517{
518 return _( "must be mm, in, or mil" );
519}
520
521
522double PCBEXPR_UNIT_RESOLVER::Convert( const wxString& aString, int unitId ) const
523{
524 double v = wxAtof( aString );
525
526 switch( unitId )
527 {
528 case 0: return EDA_UNIT_UTILS::UI::DoubleValueFromString( pcbIUScale, EDA_UNITS::MILS, aString );
529 case 1: return EDA_UNIT_UTILS::UI::DoubleValueFromString( pcbIUScale, EDA_UNITS::MILLIMETRES, aString );
530 case 2: return EDA_UNIT_UTILS::UI::DoubleValueFromString( pcbIUScale, EDA_UNITS::INCHES, aString );
531 default: return v;
532 }
533};
534
535
536const std::vector<wxString>& PCBEXPR_UNITLESS_RESOLVER::GetSupportedUnits() const
537{
538 static const std::vector<wxString> emptyUnits;
539
540 return emptyUnits;
541}
542
543
544double PCBEXPR_UNITLESS_RESOLVER::Convert( const wxString& aString, int unitId ) const
545{
546 return wxAtof( aString );
547};
548
549
551{
552 m_unitResolver.reset( aUnitResolver );
553}
554
555
556/* --------------------------------------------------------------------------------------------
557 * PCB Expression Evaluator
558 */
559
561 m_result( 0 ),
562 m_compiler( aUnitResolver ),
563 m_ucode(),
564 m_errorStatus()
565{
566}
567
568
570{
571}
572
573
574bool PCBEXPR_EVALUATOR::Evaluate( const wxString& aExpr )
575{
576 PCBEXPR_UCODE ucode;
577 PCBEXPR_CONTEXT preflightContext( NULL_CONSTRAINT, F_Cu );
578
579 if( !m_compiler.Compile( aExpr.ToUTF8().data(), &ucode, &preflightContext ) )
580 return false;
581
582 PCBEXPR_CONTEXT evaluationContext( NULL_CONSTRAINT, F_Cu );
583 LIBEVAL::VALUE* result = ucode.Run( &evaluationContext );
584
585 if( result->GetType() == LIBEVAL::VT_NUMERIC )
586 m_result = KiROUND( result->AsDouble() );
587
588 return true;
589}
590
constexpr EDA_IU_SCALE pcbIUScale
Definition: base_units.h:108
constexpr BOX2I KiROUND(const BOX2D &aBoxD)
Definition: box2.h:990
BASE_SET & set(size_t pos)
Definition: base_set.h:115
A base class derived from BOARD_ITEM for items that can be connected and have a net,...
virtual NETCLASS * GetEffectiveNetClass() const
Return the NETCLASS for this item.
A base class for any item which can be embedded within the BOARD container class, and therefore insta...
Definition: board_item.h:79
virtual const BOARD * GetBoard() const
Return the BOARD in which this BOARD_ITEM resides, or NULL if none.
Definition: board_item.cpp:47
Information pertinent to a Pcbnew printed circuit board.
Definition: board.h:290
PCB_LAYER_ID GetLayerID(const wxString &aLayerName) const
Return the ID of a layer.
Definition: board.cpp:559
std::unordered_map< wxString, LSET > m_LayerExpressionCache
Definition: board.h:1297
std::shared_mutex m_CachesMutex
Definition: board.h:1291
KICAD_T Type() const
Returns the type of object.
Definition: eda_item.h:101
static ENUM_MAP< T > & Instance()
Definition: property.h:663
const COMPONENT_CLASS * GetComponentClass() const
Definition: footprint.h:999
wxAny Get(PROPERTY_BASE *aProperty) const
Definition: inspectable.h:99
std::unique_ptr< UNIT_RESOLVER > m_unitResolver
bool Compile(const wxString &aString, UCODE *aCode, CONTEXT *aPreflightContext)
VALUE * Run(CONTEXT *ctx)
void Set(double aValue)
virtual const wxString & AsString() const
virtual bool NotEqualTo(CONTEXT *aCtx, const VALUE *b) const
virtual double AsDouble() const
VAR_TYPE_T GetType() const
virtual bool EqualTo(CONTEXT *aCtx, const VALUE *b) const
LSET is a set of PCB_LAYER_IDs.
Definition: lset.h:36
bool Contains(PCB_LAYER_ID aLayer) const
See if the layer set contains a PCB layer.
Definition: lset.h:60
const wxString GetVariableSubstitutionName() const
Gets the name of this (maybe aggregate) netclass in a format for label variable substitutions.
Definition: netclass.cpp:179
LIBEVAL::FUNC_CALL_REF Get(const wxString &name)
static PCBEXPR_BUILTIN_FUNCTIONS & Instance()
PCBEXPR_COMPILER(LIBEVAL::UNIT_RESOLVER *aUnitResolver)
LIBEVAL::VALUE * GetValue(LIBEVAL::CONTEXT *aCtx) override
bool NotEqualTo(LIBEVAL::CONTEXT *aCtx, const LIBEVAL::VALUE *b) const override
const wxString & AsString() const override
PCBEXPR_COMPONENT_CLASS_VALUE(BOARD_ITEM *aItem)
bool EqualTo(LIBEVAL::CONTEXT *aCtx, const VALUE *b) const override
BOARD_ITEM * m_items[2]
BOARD * GetBoard() const
PCB_LAYER_ID GetLayer() const
BOARD_ITEM * GetItem(int index) const
PCBEXPR_EVALUATOR(LIBEVAL::UNIT_RESOLVER *aUnitResolver)
PCBEXPR_COMPILER m_compiler
bool Evaluate(const wxString &aExpr)
PCBEXPR_LAYER_VALUE(PCB_LAYER_ID aLayer)
virtual bool EqualTo(LIBEVAL::CONTEXT *aCtx, const VALUE *b) const override
LIBEVAL::VALUE * GetValue(LIBEVAL::CONTEXT *aCtx) override
bool EqualTo(LIBEVAL::CONTEXT *aCtx, const VALUE *b) const override
BOARD_CONNECTED_ITEM * m_item
PCBEXPR_NETCLASS_VALUE(BOARD_CONNECTED_ITEM *aItem)
const wxString & AsString() const override
bool NotEqualTo(LIBEVAL::CONTEXT *aCtx, const LIBEVAL::VALUE *b) const override
LIBEVAL::VALUE * GetValue(LIBEVAL::CONTEXT *aCtx) override
bool EqualTo(LIBEVAL::CONTEXT *aCtx, const VALUE *b) const override
BOARD_CONNECTED_ITEM * m_item
PCBEXPR_NET_VALUE(BOARD_CONNECTED_ITEM *aItem)
bool NotEqualTo(LIBEVAL::CONTEXT *aCtx, const LIBEVAL::VALUE *b) const override
const wxString & AsString() const override
bool EqualTo(LIBEVAL::CONTEXT *aCtx, const VALUE *b) const override
PCBEXPR_PINTYPE_VALUE(const wxString &aPinTypeName)
LIBEVAL::VALUE * GetValue(LIBEVAL::CONTEXT *aCtx) override
virtual std::unique_ptr< LIBEVAL::VAR_REF > CreateVarRef(const wxString &aVar, const wxString &aField) override
virtual LIBEVAL::FUNC_CALL_REF CreateFuncCall(const wxString &aName) override
const std::vector< wxString > & GetSupportedUnits() const override
double Convert(const wxString &aString, int unitId) const override
double Convert(const wxString &aString, int unitId) const override
wxString GetSupportedUnitsMessage() const override
const std::vector< wxString > & GetSupportedUnits() const override
std::unordered_map< TYPE_ID, PROPERTY_BASE * > m_matchingTypes
LIBEVAL::VALUE * GetValue(LIBEVAL::CONTEXT *aCtx) override
LIBEVAL::VAR_TYPE_T m_type
BOARD_ITEM * GetObject(const LIBEVAL::CONTEXT *aCtx) const
virtual size_t TypeHash() const =0
Return type-id of the property type.
virtual bool HasChoices() const
Return true if this PROPERTY has a limited set of possible values.
Definition: property.h:241
Provide class metadata.Helper macro to map type hashes to names.
Definition: property_mgr.h:85
CLASSES_INFO GetAllClasses()
static PROPERTY_MANAGER & Instance()
Definition: property_mgr.h:87
PROPERTY_BASE * GetProperty(TYPE_ID aType, const wxString &aProperty) const
Return a property for a specific type.
bool IsOfType(TYPE_ID aDerived, TYPE_ID aBase) const
Return true if aDerived is inherited from aBase.
@ NULL_CONSTRAINT
Definition: drc_rule.h:48
#define _(s)
wxString LayerName(int aLayer)
Returns the default display name for a given layer.
Definition: layer_id.cpp:31
PCB_LAYER_ID
A quick note on layer IDs:
Definition: layer_ids.h:60
@ F_Cu
Definition: layer_ids.h:64
PCB_LAYER_ID ToLAYER_ID(int aLayer)
Definition: lset.cpp:810
KICOMMON_API double DoubleValueFromString(const EDA_IU_SCALE &aIuScale, EDA_UNITS aUnits, const wxString &aTextValue, EDA_DATA_TYPE aType=EDA_DATA_TYPE::DISTANCE)
Function DoubleValueFromString converts aTextValue to a double.
Definition: eda_units.cpp:576
std::function< void(CONTEXT *, void *)> FUNC_CALL_REF
BOARD * GetBoard()
#define TYPE_HASH(x)
Definition: property.h:71
@ PCB_FOOTPRINT_T
class FOOTPRINT, a footprint
Definition: typeinfo.h:86