KiCad PCB EDA Suite
Loading...
Searching...
No Matches
typeinfo.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) 2014 CERN
5 * Copyright The KiCad Developers, see AUTHORS.txt for contributors.
6 * @author Tomasz Wlostowski <[email protected]>
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 __KICAD_TYPEINFO_H
27#define __KICAD_TYPEINFO_H
28
29
30#include <type_traits>
31
38template <class T, class I>
39bool IsA( const I* aObject )
40{
41 return aObject && std::remove_pointer<T>::type::ClassOf( aObject );
42}
43
44template <class T, class I>
45bool IsA( const I& aObject )
46{
47 return std::remove_pointer<T>::type::ClassOf( &aObject );
48}
49
59template<class Casted, class From>
60Casted dyn_cast( From aObject )
61{
62 if( std::remove_pointer<Casted>::type::ClassOf ( aObject ) )
63 return static_cast<Casted>( aObject );
64
65 return nullptr;
66}
67
68class EDA_ITEM;
69
70
75{
76 NOT_USED = -1,
77
81
82 // Items in pcb
111
112 // Be prudent with these types:
113 // they should be used only to locate a specific field type among PCB_FIELD_Ts
114 // N.B. If you add a type here, be sure to add it below to the BaseType()
119
120 // Be prudent with these types:
121 // they should be used only to locate specific item sub-types
122 // N.B. If you add a type here, be sure to add it below to the BaseType()
132
133 // Same for locating shapes types from PCB_SHAPE_T items
140
141 /*
142 * Draw items in library symbol.
143 *
144 * The order of these items effects the sort order for items inside the
145 * "DRAW/ENDDRAW" section of the symbol definition in a library file.
146 * If you add a new draw item, type, please make sure you add it so the
147 * sort order is logical.
148 */
155
156 // Schematic draw Items. The order of these items effects the sort order.
157 // It is currently ordered to mimic the old Eeschema locate behavior where
158 // the smallest item is the selected item.
177
178 // Be prudent with these types:
179 // they should be used only to locate a specific field type among SCH_FIELD_Ts
180 // N.B. If you add a type here, be sure to add it below to the BaseType()
185
186 // Same for picking wires, buses and graphics from SCH_ITEM_T items
190
191 // Same for picking labels, or labels attached to wires and/or buses
195
196 // Same for picking symbols which are power symbols
198
199 // matches any type
201
202 // General
204
206
207 /*
208 * For GerbView: item types:
209 */
213
214 /*
215 * For Pl_Editor: item types:
216 */
223
224 // serialized layout used in undo/redo commands
225 WS_PROXY_UNDO_ITEM_T, // serialized layout used in undo/redo commands
226 WS_PROXY_UNDO_ITEM_PLUS_T, // serialized layout plus page and title block settings
227
228 /*
229 * FOR PROJECT::_ELEMs
230 */
237
238 // New types appended here to preserve historical KICAD_T ordinals
239 // (IPC clients with stale protobuf-generated headers depend on stable values).
242
243 // End value
245};
246
247static_assert( S3D_CACHE_T == 104,
248 "KICAD_T ordinals are exposed via IPC; new values must be appended at the end "
249 "of the enum, not inserted into existing blocks." );
250
260constexpr KICAD_T BaseType( const KICAD_T aType )
261{
262 switch( aType )
263 {
268 return SCH_FIELD_T;
269
273 return SCH_LINE_T;
274
278 return SCH_LABEL_T;
279
281 return SCH_SYMBOL_T;
282
287 return PCB_FIELD_T;
288
290 case PCB_LOCATE_PTH_T:
292 return PCB_LOCATE_HOLE_T;
293
302
304 case PCB_DIM_CENTER_T:
305 case PCB_DIM_RADIAL_T:
307 case PCB_DIM_LEADER_T:
308 return PCB_DIMENSION_T;
309
310 default:
311 return aType;
312 }
313}
314
315constexpr bool IsNullType( const KICAD_T aType )
316{
317 return aType <= 0;
318}
319
320constexpr bool IsInstantiableType( const KICAD_T aType )
321{
322 if( IsNullType( aType ) )
323 return false;
324
325 switch( aType )
326 {
327 case SCH_LOCATE_ANY_T:
328
333
337
341
343
348
355 case PCB_LOCATE_PTH_T:
358
367
368 case PCB_DIMENSION_T:
369
370 case SCH_SCREEN_T:
371 case PCB_ITEM_LIST_T:
372 return false;
373
374 default:
375 break;
376 }
377
378 return true;
379
380}
381
382constexpr bool IsEeschemaType( const KICAD_T aType )
383{
384 switch( aType )
385 {
386 case SCH_MARKER_T:
387 case SCH_JUNCTION_T:
388 case SCH_NO_CONNECT_T:
391 case SCH_LINE_T:
392 case SCH_SHAPE_T:
393 case SCH_RULE_AREA_T:
394 case SCH_BITMAP_T:
395 case SCH_TEXT_T:
396 case SCH_TEXTBOX_T:
397 case SCH_TABLE_T:
398 case SCH_TABLECELL_T:
399 case SCH_LABEL_T:
402 case SCH_HIER_LABEL_T:
403 case SCH_FIELD_T:
404 case SCH_SYMBOL_T:
405 case SCH_SHEET_PIN_T:
406 case SCH_GROUP_T:
407 case SCH_SHEET_T:
408 case SCH_PIN_T:
409
414
418
422
424 case SCH_LOCATE_ANY_T:
425
426 case SCH_SCREEN_T:
427 case SCHEMATIC_T:
428
429 case LIB_SYMBOL_T:
430 return true;
431
432 default:
433 return false;
434 }
435}
436
437constexpr bool IsPcbnewType( const KICAD_T aType )
438{
439 switch( aType )
440 {
441 case PCB_T:
442
443 case PCB_FOOTPRINT_T:
444 case PCB_PAD_T:
445 case PCB_SHAPE_T:
447 case PCB_FIELD_T:
448 case PCB_TEXT_T:
449 case PCB_TEXTBOX_T:
450 case PCB_BARCODE_T:
451 case PCB_TABLE_T:
452 case PCB_TABLECELL_T:
453 case PCB_TRACE_T:
454 case PCB_VIA_T:
455 case PCB_ARC_T:
456 case PCB_MARKER_T:
457 case PCB_DIMENSION_T:
459 case PCB_DIM_LEADER_T:
460 case PCB_DIM_CENTER_T:
461 case PCB_DIM_RADIAL_T:
463 case PCB_TARGET_T:
464 case PCB_POINT_T:
465 case PCB_ZONE_T:
466 case PCB_ITEM_LIST_T:
467 case PCB_NETINFO_T:
468 case PCB_GROUP_T:
469 case PCB_GENERATOR_T:
470
481 case PCB_LOCATE_PTH_T:
493 return true;
494
495 default:
496 return false;
497 }
498}
499
500constexpr bool IsGerbviewType( const KICAD_T aType )
501{
502 switch( aType )
503 {
504 case GERBER_LAYOUT_T:
506 case GERBER_IMAGE_T:
507 return true;
508
509 default:
510 return false;
511 }
512}
513
514constexpr bool IsPageLayoutEditorType( const KICAD_T aType )
515{
516 switch( aType )
517 {
518 case WSG_LINE_T:
519 case WSG_RECT_T:
520 case WSG_POLY_T:
521 case WSG_TEXT_T:
522 case WSG_BITMAP_T:
523 case WSG_PAGE_T:
524
527 return true;
528
529 default:
530 return false;
531 }
532}
533
534constexpr bool IsMiscType( const KICAD_T aType )
535{
536 switch( aType )
537 {
538 case SCREEN_T:
539
541 case FP_LIB_TABLE_T:
543 case SYMBOL_LIBS_T:
544 case SEARCH_STACK_T:
545 case S3D_CACHE_T:
546 return true;
547
548 default:
549 return false;
550 }
551}
552
553constexpr bool IsTypeCorrect( KICAD_T aType )
554{
555 return IsNullType( aType )
556 || IsEeschemaType( aType )
557 || IsPcbnewType( aType )
558 || IsGerbviewType( aType )
559 || IsPageLayoutEditorType( aType )
560 || IsMiscType( aType );
561}
562
563#endif // __KICAD_TYPEINFO_H
A base class for most all the KiCad significant classes used in schematics and boards.
Definition eda_item.h:100
#define I(x, y, z)
Definition md5_hash.cpp:18
constexpr KICAD_T BaseType(const KICAD_T aType)
Return the underlying type of the given type.
Definition typeinfo.h:260
constexpr bool IsGerbviewType(const KICAD_T aType)
Definition typeinfo.h:500
KICAD_T
The set of class identification values stored in EDA_ITEM::m_structType.
Definition typeinfo.h:75
@ FP_LIB_TABLE_T
Definition typeinfo.h:232
@ SCH_GROUP_T
Definition typeinfo.h:174
@ SCH_TABLE_T
Definition typeinfo.h:166
@ PCB_SHAPE_LOCATE_ELLIPSE_ARC_T
Definition typeinfo.h:241
@ PCB_T
Definition typeinfo.h:79
@ PCB_SHAPE_T
class PCB_SHAPE, a segment not on copper layers
Definition typeinfo.h:85
@ PCB_DIM_ORTHOGONAL_T
class PCB_DIM_ORTHOGONAL, a linear dimension constrained to x/y
Definition typeinfo.h:103
@ SCH_LINE_T
Definition typeinfo.h:164
@ PCB_FIELD_LOCATE_VALUE_T
Definition typeinfo.h:116
@ LIB_SYMBOL_T
Definition typeinfo.h:149
@ SCH_NO_CONNECT_T
Definition typeinfo.h:161
@ PCB_DIM_LEADER_T
class PCB_DIM_LEADER, a leader dimension (graphic item)
Definition typeinfo.h:100
@ SCH_FIELD_LOCATE_REFERENCE_T
Definition typeinfo.h:181
@ PCB_GENERATOR_T
class PCB_GENERATOR, generator on a layer
Definition typeinfo.h:88
@ PCB_LOCATE_BOARD_EDGE_T
Definition typeinfo.h:131
@ PCB_VIA_T
class PCB_VIA, a via (like a track segment on a copper layer)
Definition typeinfo.h:94
@ SCH_FIELD_LOCATE_FOOTPRINT_T
Definition typeinfo.h:183
@ TYPE_NOT_INIT
Definition typeinfo.h:78
@ MAX_STRUCT_TYPE_ID
Definition typeinfo.h:244
@ SCH_SYMBOL_T
Definition typeinfo.h:173
@ PCB_DIM_CENTER_T
class PCB_DIM_CENTER, a center point marking (graphic item)
Definition typeinfo.h:101
@ PCB_LOCATE_NPTH_T
Definition typeinfo.h:130
@ PCB_GROUP_T
class PCB_GROUP, a set of BOARD_ITEMs
Definition typeinfo.h:108
@ SCH_TABLECELL_T
Definition typeinfo.h:167
@ PCB_TEXTBOX_T
class PCB_TEXTBOX, wrapped text on a layer
Definition typeinfo.h:90
@ PCB_ZONE_T
class ZONE, a copper pour area
Definition typeinfo.h:105
@ PCB_LOCATE_BLINDVIA_T
Definition typeinfo.h:125
@ SCH_ITEM_LOCATE_WIRE_T
Definition typeinfo.h:187
@ SCH_FIELD_T
Definition typeinfo.h:151
@ PCB_TEXT_T
class PCB_TEXT, text on a layer
Definition typeinfo.h:89
@ PCB_LOCATE_TEXT_T
Definition typeinfo.h:127
@ SCH_DIRECTIVE_LABEL_T
Definition typeinfo.h:172
@ SCH_LABEL_T
Definition typeinfo.h:168
@ SCH_LOCATE_ANY_T
Definition typeinfo.h:200
@ SCH_FIELD_LOCATE_VALUE_T
Definition typeinfo.h:182
@ S3D_CACHE_T
Definition typeinfo.h:236
@ SCH_SHEET_T
Definition typeinfo.h:176
@ SCH_ITEM_LOCATE_BUS_T
Definition typeinfo.h:188
@ PCB_REFERENCE_IMAGE_T
class PCB_REFERENCE_IMAGE, bitmap on a layer
Definition typeinfo.h:86
@ SCH_MARKER_T
Definition typeinfo.h:159
@ PCB_ITEM_LIST_T
class BOARD_ITEM_LIST, a list of board items
Definition typeinfo.h:106
@ SCH_SHAPE_T
Definition typeinfo.h:150
@ WSG_POLY_T
Definition typeinfo.h:219
@ SCH_RULE_AREA_T
Definition typeinfo.h:171
@ PCB_FIELD_T
class PCB_FIELD, text associated with a footprint property
Definition typeinfo.h:87
@ PCB_LOCATE_STDVIA_T
Definition typeinfo.h:123
@ GERBER_DRAW_ITEM_T
Definition typeinfo.h:211
@ SCH_HIER_LABEL_T
Definition typeinfo.h:170
@ NOT_USED
the 3d code uses this value
Definition typeinfo.h:76
@ PCB_LOCATE_BURIEDVIA_T
Definition typeinfo.h:126
@ PCB_MARKER_T
class PCB_MARKER, a marker used to show something
Definition typeinfo.h:96
@ WSG_LINE_T
Definition typeinfo.h:217
@ SCH_BUS_BUS_ENTRY_T
Definition typeinfo.h:163
@ PCB_BARCODE_T
class PCB_BARCODE, a barcode (graphic item)
Definition typeinfo.h:98
@ SCH_SCREEN_T
Definition typeinfo.h:203
@ PCB_TARGET_T
class PCB_TARGET, a target (graphic item)
Definition typeinfo.h:104
@ SCH_LABEL_LOCATE_ANY_T
Definition typeinfo.h:192
@ PCB_SHAPE_LOCATE_CIRCLE_T
Definition typeinfo.h:136
@ PCB_SHAPE_LOCATE_SEGMENT_T
Definition typeinfo.h:134
@ SCH_FIELD_LOCATE_DATASHEET_T
Definition typeinfo.h:184
@ PCB_SHAPE_LOCATE_RECT_T
Definition typeinfo.h:135
@ SYMBOL_LIB_TABLE_T
Definition typeinfo.h:231
@ SCH_ITEM_LOCATE_GRAPHIC_LINE_T
Definition typeinfo.h:189
@ PCB_SHAPE_LOCATE_ELLIPSE_T
Definition typeinfo.h:240
@ SCHEMATIC_T
Definition typeinfo.h:205
@ SCH_LABEL_LOCATE_WIRE_T
Definition typeinfo.h:193
@ WSG_TEXT_T
Definition typeinfo.h:220
@ PCB_TABLECELL_T
class PCB_TABLECELL, PCB_TEXTBOX for use in tables
Definition typeinfo.h:92
@ PCB_FOOTPRINT_T
class FOOTPRINT, a footprint
Definition typeinfo.h:83
@ SCH_SHEET_PIN_T
Definition typeinfo.h:175
@ PCB_DIM_ALIGNED_T
class PCB_DIM_ALIGNED, a linear dimension (graphic item)
Definition typeinfo.h:99
@ PCB_FIELD_LOCATE_REFERENCE_T
Definition typeinfo.h:115
@ SCH_TEXT_T
Definition typeinfo.h:152
@ PCB_SHAPE_LOCATE_BEZIER_T
Definition typeinfo.h:139
@ WSG_PAGE_T
Definition typeinfo.h:222
@ WS_PROXY_UNDO_ITEM_T
Definition typeinfo.h:225
@ SEARCH_STACK_T
Definition typeinfo.h:235
@ SYMBOL_LIBS_T
Definition typeinfo.h:234
@ SCH_LABEL_LOCATE_BUS_T
Definition typeinfo.h:194
@ PCB_LOCATE_PTH_T
Definition typeinfo.h:129
@ PCB_PAD_T
class PAD, a pad in a footprint
Definition typeinfo.h:84
@ WSG_RECT_T
Definition typeinfo.h:218
@ PCB_SHAPE_LOCATE_POLY_T
Definition typeinfo.h:138
@ PCB_SHAPE_LOCATE_ARC_T
Definition typeinfo.h:137
@ SCH_SYMBOL_LOCATE_POWER_T
Definition typeinfo.h:197
@ DESIGN_BLOCK_LIB_TABLE_T
Definition typeinfo.h:233
@ GERBER_IMAGE_T
Definition typeinfo.h:212
@ SCH_BUS_WIRE_ENTRY_T
Definition typeinfo.h:162
@ GERBER_LAYOUT_T
Definition typeinfo.h:210
@ SCREEN_T
not really an item, used to identify a screen
Definition typeinfo.h:80
@ SCH_BITMAP_T
Definition typeinfo.h:165
@ PCB_BOARD_OUTLINE_T
class PCB_BOARD_OUTLINE_T, a pcb board outline item
Definition typeinfo.h:109
@ PCB_ARC_T
class PCB_ARC, an arc track segment on a copper layer
Definition typeinfo.h:95
@ WS_PROXY_UNDO_ITEM_PLUS_T
Definition typeinfo.h:226
@ PCB_LOCATE_UVIA_T
Definition typeinfo.h:124
@ PCB_DIMENSION_T
class PCB_DIMENSION_BASE: abstract dimension meta-type
Definition typeinfo.h:97
@ PCB_TABLE_T
class PCB_TABLE, table of PCB_TABLECELLs
Definition typeinfo.h:91
@ PCB_NETINFO_T
class NETINFO_ITEM, a description of a net
Definition typeinfo.h:107
@ SCH_TEXTBOX_T
Definition typeinfo.h:153
@ WSG_BITMAP_T
Definition typeinfo.h:221
@ PCB_LOCATE_HOLE_T
Definition typeinfo.h:128
@ PCB_FIELD_LOCATE_DATASHEET_T
Definition typeinfo.h:118
@ PCB_POINT_T
class PCB_POINT, a 0-dimensional point
Definition typeinfo.h:110
@ PCB_TRACE_T
class PCB_TRACK, a track segment (segment on a copper layer)
Definition typeinfo.h:93
@ PCB_DIM_RADIAL_T
class PCB_DIM_RADIAL, a radius or diameter dimension
Definition typeinfo.h:102
@ SCH_GLOBAL_LABEL_T
Definition typeinfo.h:169
@ PCB_FIELD_LOCATE_FOOTPRINT_T
Definition typeinfo.h:117
@ SCH_JUNCTION_T
Definition typeinfo.h:160
@ SCH_PIN_T
Definition typeinfo.h:154
constexpr bool IsTypeCorrect(KICAD_T aType)
Definition typeinfo.h:553
constexpr bool IsPcbnewType(const KICAD_T aType)
Definition typeinfo.h:437
constexpr bool IsMiscType(const KICAD_T aType)
Definition typeinfo.h:534
constexpr bool IsInstantiableType(const KICAD_T aType)
Definition typeinfo.h:320
Casted dyn_cast(From aObject)
A lightweight dynamic downcast.
Definition typeinfo.h:60
constexpr bool IsNullType(const KICAD_T aType)
Definition typeinfo.h:315
bool IsA(const I *aObject)
Check if the type of aObject is T.
Definition typeinfo.h:39
constexpr bool IsEeschemaType(const KICAD_T aType)
Definition typeinfo.h:382
constexpr bool IsPageLayoutEditorType(const KICAD_T aType)
Definition typeinfo.h:514