KiCad PCB EDA Suite
Loading...
Searching...
No Matches
sch_sheet.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 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#ifndef SCH_SHEEET_H
26#define SCH_SHEEET_H
27
28#include <sch_field.h>
29
30class KIID_PATH;
31class SCH_SCREEN;
33class SCH_SHEET_LIST;
34class SCH_SHEET_PIN;
35class SCH_SHEET_PATH;
36class EDA_DRAW_FRAME;
37class SCH_NO_CONNECT;
38
39
40#define MIN_SHEET_WIDTH 500 // Units are mils.
41#define MIN_SHEET_HEIGHT 150 // Units are mils.
42
43
47class SCH_SHEET : public SCH_ITEM
48{
49public:
50 SCH_SHEET( EDA_ITEM* aParent = nullptr, const VECTOR2I& aPos = VECTOR2I( 0, 0 ),
51 VECTOR2I aSize = VECTOR2I( schIUScale.MilsToIU( MIN_SHEET_WIDTH ),
52 schIUScale.MilsToIU( MIN_SHEET_HEIGHT ) ) );
53
60 SCH_SHEET( const SCH_SHEET& aSheet );
61
62 ~SCH_SHEET();
63
64 static inline bool ClassOf( const EDA_ITEM* aItem )
65 {
66 return aItem && SCH_SHEET_T == aItem->Type();
67 }
68
69 wxString GetClass() const override
70 {
71 return wxT( "SCH_SHEET" );
72 }
73
83 bool IsMovableFromAnchorPoint() const override { return false; }
84
88 std::vector<SCH_FIELD>& GetFields() { return m_fields; }
89 const std::vector<SCH_FIELD>& GetFields() const { return m_fields; }
90
95 SCH_FIELD* GetField( FIELD_T aFieldType );
96 const SCH_FIELD* GetField( FIELD_T aFieldNdx ) const;
97
105 SCH_FIELD* GetField( const wxString& aFieldName );
106 const SCH_FIELD* GetField( const wxString& aFieldName ) const;
107
111 int GetNextFieldOrdinal() const;
112
118 void SetFields( const std::vector<SCH_FIELD>& aFields );
119
130 void AddOptionalField( const SCH_FIELD& aField );
131
132 void SetFieldText( const wxString& aFieldName, const wxString& aFieldText, const SCH_SHEET_PATH* aPath = nullptr,
133 const wxString& aVariantName = wxEmptyString );
134
135 wxString GetFieldText( const wxString& aFieldName, const SCH_SHEET_PATH* aPath = nullptr,
136 const wxString& aVariantName = wxEmptyString ) const;
137
138 wxString GetShownName( bool aAllowExtraText ) const
139 {
140 return GetField( FIELD_T::SHEET_NAME )->GetShownText( aAllowExtraText );
141 }
142 wxString GetName() const { return GetField( FIELD_T::SHEET_NAME )->GetText(); }
143 void SetName( const wxString& aName ) { GetField( FIELD_T::SHEET_NAME )->SetText( aName ); }
144
145 SCH_SCREEN* GetScreen() const { return m_screen; }
146
147 VECTOR2I GetSize() const { return m_size; }
148 void SetSize( const VECTOR2I& aSize ) { m_size = aSize; }
149
150 int GetBorderWidth() const { return m_borderWidth; }
151 void SetBorderWidth( int aWidth ) { m_borderWidth = aWidth; }
152
154 void SetBorderColor( KIGFX::COLOR4D aColor ) { m_borderColor = aColor; }
155
158
164 bool IsVirtualRootSheet() const;
165
173 bool IsTopLevelSheet() const;
174
186 void SetScreen( SCH_SCREEN* aScreen );
187
193 int GetScreenCount() const;
194
198 void GetContextualTextVars( wxArrayString* aVars ) const;
199
205 bool ResolveTextVar( const SCH_SHEET_PATH* aPath, wxString* token, int aDepth = 0 ) const;
206
207 void GetMsgPanelInfo( EDA_DRAW_FRAME* aFrame, std::vector<MSG_PANEL_ITEM>& aList ) override;
208
209 /* there is no member for orientation in sch_sheet, to preserve file
210 * format, we detect orientation based on pin edges
211 */
212 bool IsVerticalOrientation() const;
213
218 std::map<SCH_SHEET_PIN*, SCH_NO_CONNECT*> GetNoConnects() const;
219
220 void SetPositionIgnoringPins( const VECTOR2I& aPosition );
221
231 void AddPin( SCH_SHEET_PIN* aSheetPin );
232
233 std::vector<SCH_SHEET_PIN*>& GetPins() { return m_pins; }
234 const std::vector<SCH_SHEET_PIN*>& GetPins() const { return m_pins; }
235
241 void RemovePin( const SCH_SHEET_PIN* aSheetPin );
242
249 void CleanupSheet();
250
258 SCH_SHEET_PIN* GetPin( const VECTOR2I& aPosition );
259
266 bool HasPin( const wxString& aName ) const;
267
268 bool HasPins() const { return !m_pins.empty(); }
269
275 bool HasUndefinedPins() const;
276
288 int GetMinWidth( bool aFromLeft ) const;
289
300 int GetMinHeight( bool aFromTop ) const;
301
302 int GetPenWidth() const override;
303
307 const BOX2I GetBodyBoundingBox() const;
308
309 const BOX2I GetBoundingBox() const override;
310
318
319 void swapData( SCH_ITEM* aItem ) override;
320
324 int SymbolCount() const;
325
333 bool SearchHierarchy( const wxString& aFilename, SCH_SCREEN** aScreen );
334
345 bool LocatePathOfScreen( SCH_SCREEN* aScreen, SCH_SHEET_PATH* aList );
346
352 int CountSheets() const;
353
361 int CountActiveSheets() const;
362
369 int CountSheets( const wxString& aFileName ) const;
370
376 wxString GetFileName() const
377 {
379 }
380
381 // Set a new filename without changing anything else
382 void SetFileName( const wxString& aFilename )
383 {
384 // Filenames are stored using unix notation
385 wxString tmp = aFilename;
386 tmp.Replace( wxT( "\\" ), wxT( "/" ) );
388 }
389
390 // Geometric transforms (used in block operations):
391
392 void Move( const VECTOR2I& aMoveVector ) override;
393 void MirrorHorizontally( int aCenter ) override;
394 void MirrorVertically( int aCenter ) override;
395 void Rotate( const VECTOR2I& aCenter, bool aRotateCCW ) override;
396
397 bool Matches( const EDA_SEARCH_DATA& aSearchData, void* aAuxData ) const override;
398
399 bool IsReplaceable() const override { return true; }
400
406 void Resize( const VECTOR2I& aSize );
407
408 void AutoplaceFields( SCH_SCREEN* aScreen, AUTOPLACE_ALGO aAlgo ) override;
409
410 void GetEndPoints( std::vector <DANGLING_END_ITEM>& aItemList ) override;
411
412 bool UpdateDanglingState( std::vector<DANGLING_END_ITEM>& aItemListByType,
413 std::vector<DANGLING_END_ITEM>& aItemListByPos,
414 const SCH_SHEET_PATH* aPath = nullptr ) override;
415
416 bool IsConnectable() const override { return true; }
417
418 bool HasConnectivityChanges( const SCH_ITEM* aItem,
419 const SCH_SHEET_PATH* aInstance = nullptr ) const override;
420
421 bool CanConnect( const SCH_ITEM* aItem ) const override
422 {
423 return ( aItem->Type() == SCH_LINE_T && aItem->GetLayer() == LAYER_WIRE )
424 || ( aItem->Type() == SCH_LINE_T && aItem->GetLayer() == LAYER_BUS )
425 || ( aItem->Type() == SCH_NO_CONNECT_T )
426 || ( aItem->Type() == SCH_SYMBOL_T );
427 }
428
429 std::vector<VECTOR2I> GetConnectionPoints() const override;
430
431 INSPECT_RESULT Visit( INSPECTOR inspector, void* testData,
432 const std::vector<KICAD_T>& aScanTypes ) override;
433
434 void RunOnChildren( const std::function<void( SCH_ITEM* )>& aFunction, RECURSE_MODE aMode ) override;
435
439 void SetExcludedFromSim( bool aExcludeFromSim, const SCH_SHEET_PATH* aInstance = nullptr,
440 const wxString& aVariantName = wxEmptyString ) override;
441 bool GetExcludedFromSim( const SCH_SHEET_PATH* aInstance = nullptr,
442 const wxString& aVariantName = wxEmptyString ) const override;
443
444 bool GetExcludedFromSimProp() const;
445 void SetExcludedFromSimProp( bool aEnable );
446
450 void SetExcludedFromBOM( bool aExcludeFromBOM, const SCH_SHEET_PATH* aInstance = nullptr,
451 const wxString& aVariantName = wxEmptyString ) override;
452 bool GetExcludedFromBOM( const SCH_SHEET_PATH* aInstance = nullptr,
453 const wxString& aVariantName = wxEmptyString ) const override;
454
455 bool GetExcludedFromBOMProp() const;
456 void SetExcludedFromBOMProp( bool aEnable );
457
461 void SetExcludedFromBoard( bool aExclude, const SCH_SHEET_PATH* aInstance = nullptr,
462 const wxString& aVariantName = wxEmptyString ) override
463 {
464 m_excludedFromBoard = aExclude;
465 }
466
467 bool GetExcludedFromBoard( const SCH_SHEET_PATH* aInstance = nullptr,
468 const wxString& aVariantName = wxEmptyString ) const override
469 {
470 return m_excludedFromBoard;
471 }
472
474 void SetExcludedFromBoardProp( bool aExclude ) { SetExcludedFromBoard( aExclude ); }
475
479 bool GetDNP( const SCH_SHEET_PATH* aInstance = nullptr,
480 const wxString& aVariantName = wxEmptyString ) const override;
481 void SetDNP( bool aDNP, const SCH_SHEET_PATH* aInstance = nullptr,
482 const wxString& aVariantName = wxEmptyString ) override;
483 bool GetDNPProp() const;
484 void SetDNPProp( bool aEnable );
485
486 wxString GetItemDescription( UNITS_PROVIDER* aUnitsProvider, bool aFull ) const override;
487
488 BITMAPS GetMenuImage() const override;
489
490 SCH_SHEET& operator=( const SCH_ITEM& aSheet );
491
492 bool operator <( const SCH_ITEM& aItem ) const override;
493
494 std::vector<int> ViewGetLayers() const override;
495
496 VECTOR2I GetPosition() const override { return m_pos; }
497 void SetPosition( const VECTOR2I& aPosition ) override;
498
499 bool HitTest( const VECTOR2I& aPosition, int aAccuracy ) const override;
500 bool HitTest( const BOX2I& aRect, bool aContained, int aAccuracy = 0 ) const override;
501 bool HitTest( const SHAPE_LINE_CHAIN& aPoly, bool aContained ) const override;
502
503 void Plot( PLOTTER* aPlotter, bool aBackground, const SCH_PLOT_OPTS& aPlotOpts,
504 int aUnit, int aBodyStyle, const VECTOR2I& aOffset, bool aDimmed ) override;
505
506 EDA_ITEM* Clone() const override;
507
511 const std::vector<SCH_SHEET_INSTANCE>& GetInstances() const { return m_instances; }
512
522 bool HasRootInstance() const;
523
532 const SCH_SHEET_INSTANCE& GetRootInstance() const;
533
534 void RemoveInstance( const KIID_PATH& aInstancePath );
535
536 void AddInstance( const SCH_SHEET_INSTANCE& aInstance );
537
538 void DeleteVariant( const KIID_PATH& aPath, const wxString& aVariantName );
539
540 void RenameVariant( const KIID_PATH& aPath, const wxString& aOldName, const wxString& aNewName );
541
542 void CopyVariant( const KIID_PATH& aPath, const wxString& aSourceVariant,
543 const wxString& aNewVariant );
544
545 void AddVariant( const SCH_SHEET_PATH& aInstance, const SCH_SHEET_VARIANT& aVariant );
546 void DeleteVariant( const SCH_SHEET_PATH& aInstance, const wxString& aVariantName )
547 {
548 DeleteVariant( aInstance.Path(), aVariantName );
549 }
550
551 void RenameVariant( const SCH_SHEET_PATH& aInstance, const wxString& aOldName,
552 const wxString& aNewName )
553 {
554 RenameVariant( aInstance.Path(), aOldName, aNewName );
555 }
556
557 void CopyVariant( const SCH_SHEET_PATH& aInstance, const wxString& aSourceVariant,
558 const wxString& aNewVariant )
559 {
560 CopyVariant( aInstance.Path(), aSourceVariant, aNewVariant );
561 }
562
569 bool HasPageNumberChanges( const SCH_SHEET& aOther ) const;
570
576 static int ComparePageNum( const wxString& aPageNumberA, const wxString& aPageNumberB );
577
578 double Similarity( const SCH_ITEM& aOther ) const override;
579
580 bool operator==( const SCH_ITEM& aOther ) const override;
581
582#if defined(DEBUG)
583 void Show( int nestLevel, std::ostream& os ) const override;
584#endif
585
586protected:
589
590 void setInstances( const std::vector<SCH_SHEET_INSTANCE>& aInstances )
591 {
592 m_instances = aInstances;
593 }
594
608 bool addInstance( const KIID_PATH& aInstance );
609
619 wxString getPageNumber( const KIID_PATH& aParentPath ) const;
620
630 void setPageNumber( const KIID_PATH& aInstance, const wxString& aPageNumber );
631
632 bool getInstance( SCH_SHEET_INSTANCE& aInstance, const KIID_PATH& aSheetPath,
633 bool aTestFromEnd = false ) const;
634
636 const SCH_SHEET_INSTANCE* getInstance( const KIID_PATH& aPath ) const;
637
638 SCH_SHEET_INSTANCE* getInstance( const SCH_SHEET_PATH& aPath ) { return getInstance( aPath.Path() ); }
639 const SCH_SHEET_INSTANCE* getInstance( const SCH_SHEET_PATH& aPath ) const { return getInstance( aPath.Path() ); }
640
648 void renumberPins();
649
654 SCH_SHEET_PATH findSelf() const;
655
656private:
657 bool doIsConnected( const VECTOR2I& aPosition ) const override;
658
659 friend class SCH_SHEET_PIN;
660 friend class SCH_SHEET_LIST;
661
662private:
663 SCH_SCREEN* m_screen; // Screen that contains the physical data for the
664 // sheet. In complex hierarchies multiple sheets
665 // can share a common screen.
666
667 std::vector<SCH_SHEET_PIN*> m_pins; // The list of sheet connection points.
668 std::vector<SCH_FIELD> m_fields;
669
673 bool m_DNP;
674
675 VECTOR2I m_pos; // The position of the sheet.
676 VECTOR2I m_size; // The size of the sheet.
680
681 std::vector<SCH_SHEET_INSTANCE> m_instances;
682};
683
684
685#endif // SCH_SHEEET_H
constexpr EDA_IU_SCALE schIUScale
Definition base_units.h:114
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
A color representation with 4 components: red, green, blue, alpha.
Definition color4d.h:105
Base plotter engine class.
Definition plotter.h:136
virtual const wxString & GetText() const override
Return the string associated with the text object.
Definition sch_field.h:118
wxString GetShownText(const SCH_SHEET_PATH *aPath, bool aAllowExtraText, int aDepth=0, const wxString &aVariantName=wxEmptyString) const
void SetText(const wxString &aText) override
Object to parser s-expression symbol library and schematic file formats.
Base class for any item which can be embedded within the SCHEMATIC container class,...
Definition sch_item.h:167
SCH_LAYER_ID GetLayer() const
Return the layer this item is on.
Definition sch_item.h:340
SCH_ITEM(EDA_ITEM *aParent, KICAD_T aType, int aUnit=0, int aBodyStyle=0)
Definition sch_item.cpp:54
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
KIID_PATH Path() const
Get the sheet path as an KIID_PATH.
Define a sheet pin (label) used in sheets to create hierarchical schematics.
Variant information for a schematic sheet.
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
Definition sch_sheet.h:48
void GetEndPoints(std::vector< DANGLING_END_ITEM > &aItemList) override
Add the schematic item end points to aItemList if the item has end points.
void GetContextualTextVars(wxArrayString *aVars) const
Return the list of system text vars & fields for this sheet.
friend SCH_SHEET_PATH
Definition sch_sheet.h:587
void SetBorderColor(KIGFX::COLOR4D aColor)
Definition sch_sheet.h:154
const std::vector< SCH_SHEET_PIN * > & GetPins() const
Definition sch_sheet.h:234
friend class SCH_SHEET_PIN
Definition sch_sheet.h:659
VECTOR2I m_size
Definition sch_sheet.h:676
void SetFileName(const wxString &aFilename)
Definition sch_sheet.h:382
bool HasConnectivityChanges(const SCH_ITEM *aItem, const SCH_SHEET_PATH *aInstance=nullptr) const override
Check if aItem has connectivity changes against this object.
wxString GetFileName() const
Return the filename corresponding to this sheet.
Definition sch_sheet.h:376
bool getInstance(SCH_SHEET_INSTANCE &aInstance, const KIID_PATH &aSheetPath, bool aTestFromEnd=false) const
BITMAPS GetMenuImage() const override
Return a pointer to an image to be used in menus.
void SetExcludedFromSim(bool aExcludeFromSim, const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) override
Set or clear the exclude from simulation flag.
void CopyVariant(const KIID_PATH &aPath, const wxString &aSourceVariant, const wxString &aNewVariant)
void SetSize(const VECTOR2I &aSize)
Definition sch_sheet.h:148
void RemoveInstance(const KIID_PATH &aInstancePath)
void SetDNP(bool aDNP, const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) override
bool addInstance(const KIID_PATH &aInstance)
Add a new instance aSheetPath to the instance list.
void AddPin(SCH_SHEET_PIN *aSheetPin)
Add aSheetPin to the sheet.
bool HasRootInstance() const
Check to see if this sheet has a root sheet instance.
wxString GetClass() const override
Return the class name.
Definition sch_sheet.h:69
wxString getPageNumber(const KIID_PATH &aParentPath) const
Return the sheet page number for aParentPath.
void SetExcludedFromBOM(bool aExcludeFromBOM, const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) override
Set or clear the exclude from schematic bill of materials flag.
int GetPenWidth() const override
std::map< SCH_SHEET_PIN *, SCH_NO_CONNECT * > GetNoConnects() const
EDA_ITEM * Clone() const override
Create a duplicate of this item with linked list members set to NULL.
bool IsConnectable() const override
Definition sch_sheet.h:416
bool IsTopLevelSheet() const
Check if this sheet is a top-level sheet.
SCH_SHEET_PATH findSelf() const
Get the sheetpath of this sheet.
bool GetDNPProp() const
bool Matches(const EDA_SEARCH_DATA &aSearchData, void *aAuxData) const override
Compare the item against the search criteria in aSearchData.
bool GetExcludedFromBoardProp() const
Definition sch_sheet.h:473
double Similarity(const SCH_ITEM &aOther) const override
Return a measure of how likely the other object is to represent the same object.
bool GetExcludedFromBOMProp() const
VECTOR2I m_pos
Definition sch_sheet.h:675
void CopyVariant(const SCH_SHEET_PATH &aInstance, const wxString &aSourceVariant, const wxString &aNewVariant)
Definition sch_sheet.h:557
std::vector< SCH_FIELD > & GetFields()
Return a reference to the vector holding the sheet's fields.
Definition sch_sheet.h:88
KIGFX::COLOR4D m_borderColor
Definition sch_sheet.h:678
SCH_FIELD * GetField(FIELD_T aFieldType)
Return a mandatory field in this sheet.
bool m_excludedFromBOM
Definition sch_sheet.h:671
wxString GetName() const
Definition sch_sheet.h:142
void renumberPins()
Renumber the sheet pins in the sheet.
VECTOR2I GetRotationCenter() const
Rotating around the boundingBox's center can cause walking when the sheetname or filename is longer t...
SCH_SHEET_PIN * GetPin(const VECTOR2I &aPosition)
Return the sheet pin item found at aPosition in the sheet.
bool GetExcludedFromBOM(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
bool operator<(const SCH_ITEM &aItem) const override
void CleanupSheet()
Delete sheet label which do not have a corresponding hierarchical label.
void RemovePin(const SCH_SHEET_PIN *aSheetPin)
Remove aSheetPin from the sheet.
void SetPositionIgnoringPins(const VECTOR2I &aPosition)
bool SearchHierarchy(const wxString &aFilename, SCH_SCREEN **aScreen)
Search the existing hierarchy for an instance of screen loaded from aFileName.
bool GetExcludedFromSim(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
bool LocatePathOfScreen(SCH_SCREEN *aScreen, SCH_SHEET_PATH *aList)
Search the existing hierarchy for an instance of screen loaded from aFileName.
std::vector< SCH_SHEET_INSTANCE > m_instances
Definition sch_sheet.h:681
bool HasUndefinedPins() const
Check all sheet labels against schematic for undefined hierarchical labels.
bool m_excludedFromSim
Definition sch_sheet.h:670
void SetPosition(const VECTOR2I &aPosition) override
wxString GetFieldText(const wxString &aFieldName, const SCH_SHEET_PATH *aPath=nullptr, const wxString &aVariantName=wxEmptyString) const
void SetBackgroundColor(KIGFX::COLOR4D aColor)
Definition sch_sheet.h:157
int SymbolCount() const
Count our own symbols, without the power symbols.
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 IsReplaceable() const override
Override this method in any derived object that supports test find and replace.
Definition sch_sheet.h:399
void SetDNPProp(bool aEnable)
void AddInstance(const SCH_SHEET_INSTANCE &aInstance)
int GetMinWidth(bool aFromLeft) const
Return the minimum width of the sheet based on the widths of the sheet pin text.
bool operator==(const SCH_ITEM &aOther) const override
SCH_SCREEN * m_screen
Definition sch_sheet.h:663
std::vector< int > ViewGetLayers() const override
Return the layers the item is drawn on (which may be more than its "home" layer)
std::vector< SCH_FIELD > m_fields
Definition sch_sheet.h:668
void RenameVariant(const KIID_PATH &aPath, const wxString &aOldName, const wxString &aNewName)
VECTOR2I GetSize() const
Definition sch_sheet.h:147
KIGFX::COLOR4D m_backgroundColor
Definition sch_sheet.h:679
void SetExcludedFromBoard(bool aExclude, const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) override
Set or clear exclude from board netlist flag.
Definition sch_sheet.h:461
void DeleteVariant(const KIID_PATH &aPath, const wxString &aVariantName)
SCH_SHEET(EDA_ITEM *aParent=nullptr, const VECTOR2I &aPos=VECTOR2I(0, 0), VECTOR2I aSize=VECTOR2I(schIUScale.MilsToIU(MIN_SHEET_WIDTH), schIUScale.MilsToIU(MIN_SHEET_HEIGHT)))
Definition sch_sheet.cpp:55
void SetName(const wxString &aName)
Definition sch_sheet.h:143
int CountSheets() const
Count the number of sheets found in "this" sheet including all of the subsheets.
int GetNextFieldOrdinal() const
Return the next ordinal for a user field for this sheet.
SCH_SCREEN * GetScreen() const
Definition sch_sheet.h:145
void SetExcludedFromSimProp(bool aEnable)
bool HasPins() const
Definition sch_sheet.h:268
VECTOR2I GetPosition() const override
Definition sch_sheet.h:496
const BOX2I GetBodyBoundingBox() const
Return a bounding box for the sheet body but not the fields.
bool HasPin(const wxString &aName) const
Check if the sheet already has a sheet pin named aName.
static int ComparePageNum(const wxString &aPageNumberA, const wxString &aPageNumberB)
Compare page numbers of schematic sheets.
void SetFieldText(const wxString &aFieldName, const wxString &aFieldText, const SCH_SHEET_PATH *aPath=nullptr, const wxString &aVariantName=wxEmptyString)
void MirrorHorizontally(int aCenter) override
Mirror item horizontally about aCenter.
void AddOptionalField(const SCH_FIELD &aField)
Add an optional @aField to the list of fields.
void SetFields(const std::vector< SCH_FIELD > &aFields)
Set multiple schematic fields.
int CountActiveSheets() const
Count the number of sheets found in "this" sheet including all of the subsheets.
int GetScreenCount() const
Return the number of times the associated screen for the sheet is being used.
void SetScreen(SCH_SCREEN *aScreen)
Set the SCH_SCREEN associated with this sheet to aScreen.
SCH_SHEET & operator=(const SCH_ITEM &aSheet)
bool HasPageNumberChanges(const SCH_SHEET &aOther) const
Check if the instance data of this sheet has any changes compared to aOther.
const SCH_SHEET_INSTANCE & GetRootInstance() const
Return the root sheet instance data.
bool doIsConnected(const VECTOR2I &aPosition) const override
Provide the object specific test to see if it is connected to aPosition.
void swapData(SCH_ITEM *aItem) override
Swap the internal data structures aItem with the schematic item.
bool m_excludedFromBoard
Definition sch_sheet.h:672
void setInstances(const std::vector< SCH_SHEET_INSTANCE > &aInstances)
Definition sch_sheet.h:590
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
const std::vector< SCH_FIELD > & GetFields() const
Definition sch_sheet.h:89
std::vector< VECTOR2I > GetConnectionPoints() const override
Add all the connection points for this item to aPoints.
KIGFX::COLOR4D GetBorderColor() const
Definition sch_sheet.h:153
std::vector< SCH_SHEET_PIN * > m_pins
Definition sch_sheet.h:667
bool IsMovableFromAnchorPoint() const override
Return true for items which are moved with the anchor point at mouse cursor and false for items moved...
Definition sch_sheet.h:83
bool CanConnect(const SCH_ITEM *aItem) const override
Definition sch_sheet.h:421
INSPECT_RESULT Visit(INSPECTOR inspector, void *testData, const std::vector< KICAD_T > &aScanTypes) override
May be re-implemented for each derived class in order to handle all the types given by its member dat...
friend class SCH_SHEET_LIST
Definition sch_sheet.h:660
void SetBorderWidth(int aWidth)
Definition sch_sheet.h:151
static bool ClassOf(const EDA_ITEM *aItem)
Definition sch_sheet.h:64
void MirrorVertically(int aCenter) override
Mirror item vertically about aCenter.
void setPageNumber(const KIID_PATH &aInstance, const wxString &aPageNumber)
Set the page number for the sheet instance aInstance.
bool IsVirtualRootSheet() const
void AutoplaceFields(SCH_SCREEN *aScreen, AUTOPLACE_ALGO aAlgo) override
int GetMinHeight(bool aFromTop) const
Return the minimum height that the sheet can be resized based on the sheet pin positions.
bool GetDNP(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
Set or clear the 'Do Not Populate' flags.
bool GetExcludedFromSimProp() const
void SetExcludedFromBoardProp(bool aExclude)
Definition sch_sheet.h:474
int m_borderWidth
Definition sch_sheet.h:677
wxString GetItemDescription(UNITS_PROVIDER *aUnitsProvider, bool aFull) const override
Return a user-visible description string of this item.
bool UpdateDanglingState(std::vector< DANGLING_END_ITEM > &aItemListByType, std::vector< DANGLING_END_ITEM > &aItemListByPos, const SCH_SHEET_PATH *aPath=nullptr) override
Test the schematic item to aItemList to check if it's dangling state has changed.
bool GetExcludedFromBoard(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
Definition sch_sheet.h:467
void Resize(const VECTOR2I &aSize)
Resize this sheet to aSize and adjust all of the labels accordingly.
void Move(const VECTOR2I &aMoveVector) override
Move the item by aMoveVector to a new position.
int GetBorderWidth() const
Definition sch_sheet.h:150
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 m_DNP
Definition sch_sheet.h:673
std::vector< SCH_SHEET_PIN * > & GetPins()
Definition sch_sheet.h:233
void RunOnChildren(const std::function< void(SCH_ITEM *)> &aFunction, RECURSE_MODE aMode) override
void SetExcludedFromBOMProp(bool aEnable)
wxString GetShownName(bool aAllowExtraText) const
Definition sch_sheet.h:138
void DeleteVariant(const SCH_SHEET_PATH &aInstance, const wxString &aVariantName)
Definition sch_sheet.h:546
friend SCH_IO_KICAD_SEXPR_PARSER
Definition sch_sheet.h:588
void Rotate(const VECTOR2I &aCenter, bool aRotateCCW) override
Rotate the item around aCenter 90 degrees in the clockwise direction.
void AddVariant(const SCH_SHEET_PATH &aInstance, const SCH_SHEET_VARIANT &aVariant)
bool ResolveTextVar(const SCH_SHEET_PATH *aPath, wxString *token, int aDepth=0) const
Resolve any references to system tokens supported by the sheet.
const std::vector< SCH_SHEET_INSTANCE > & GetInstances() const
Definition sch_sheet.h:511
void RenameVariant(const SCH_SHEET_PATH &aInstance, const wxString &aOldName, const wxString &aNewName)
Definition sch_sheet.h:551
SCH_SHEET_INSTANCE * getInstance(const SCH_SHEET_PATH &aPath)
Definition sch_sheet.h:638
bool IsVerticalOrientation() const
const SCH_SHEET_INSTANCE * getInstance(const SCH_SHEET_PATH &aPath) const
Definition sch_sheet.h:639
bool HitTest(const VECTOR2I &aPosition, int aAccuracy) const override
Test if aPosition is inside or on the boundary of this item.
KIGFX::COLOR4D GetBackgroundColor() const
Definition sch_sheet.h:156
Represent a polyline containing arcs as well as line segments: A chain of connected line and/or arc s...
RECURSE_MODE
Definition eda_item.h:50
INSPECT_RESULT
Definition eda_item.h:44
const INSPECTOR_FUNC & INSPECTOR
std::function passed to nested users by ref, avoids copying std::function.
Definition eda_item.h:91
@ LAYER_WIRE
Definition layer_ids.h:452
@ LAYER_BUS
Definition layer_ids.h:453
AUTOPLACE_ALGO
Definition sch_item.h:68
#define MIN_SHEET_HEIGHT
Definition sch_sheet.h:41
#define MIN_SHEET_WIDTH
Definition sch_sheet.h:40
A simple container for sheet instance information.
FIELD_T
The set of all field indices assuming an array like sequence that a SCH_COMPONENT or LIB_PART can hol...
@ SCH_LINE_T
Definition typeinfo.h:167
@ SCH_NO_CONNECT_T
Definition typeinfo.h:164
@ SCH_SYMBOL_T
Definition typeinfo.h:176
@ SCH_SHEET_T
Definition typeinfo.h:179
VECTOR2< int32_t > VECTOR2I
Definition vector2d.h:695