KiCad PCB EDA Suite
Loading...
Searching...
No Matches
sch_sheet_path.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) 2017 Jean-Pierre Charras, jp.charras at wanadoo.fr
5 * Copyright (C) 2011 Wayne Stambaugh <[email protected]>
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
30
31#ifndef CLASS_DRAWSHEET_PATH_H
32#define CLASS_DRAWSHEET_PATH_H
33
34#include <map>
35#include <memory>
36#include <optional>
37
38#include <kiid.h>
39#include <wx/string.h>
40
41class SCH_SYMBOL;
42class SCH_SHEET;
43
50
55{
56public:
57 VARIANT( const wxString& aName = wxEmptyString ) :
58 m_Name( aName ),
59 m_ExcludedFromSim( false ),
60 m_ExcludedFromBOM( false ),
61 m_ExcludedFromBoard( false ),
63 m_DNP( false )
64 {
65 }
66
67 virtual ~VARIANT() = default;
68
69 wxString m_Name;
70 wxString m_Description;
75 bool m_DNP;
76 std::map<wxString, wxString> m_Fields;
77};
78
79
89{
90public:
91 SCH_SYMBOL_VARIANT( const wxString& aName = wxEmptyString ) :
92 VARIANT( aName )
93 {}
94
95 void InitializeAttributes( const SCH_SYMBOL& aSymbol );
96
97 virtual ~SCH_SYMBOL_VARIANT() = default;
98};
99
100
105{
107
108 // Things that can be annotated:
109 wxString m_Reference;
110 int m_Unit = 1;
111
112 // Do not use. This is left over from the dubious decision to instantiate symbol value
113 // and footprint fields. This is now handle by variants.
114 wxString m_Value;
115 wxString m_Footprint;
116
117 // The project name associated with this instance.
119
120 bool m_DNP = false;
121 bool m_ExcludedFromBOM = false;
122 bool m_ExcludedFromSim = false;
125
127 std::map<wxString, SCH_SYMBOL_VARIANT> m_Variants;
128};
129
130
142{
143public:
144 SCH_SHEET_VARIANT( const wxString& aName = wxEmptyString ) :
145 VARIANT( aName )
146 {}
147
148 virtual ~SCH_SHEET_VARIANT() = default;
149
150 void InitializeAttributes( const SCH_SHEET& aSheet );
151};
152
153
158{
160
161 wxString m_PageNumber;
162
163 // The project name associated with this instance.
165
166 bool m_DNP = false;
167 bool m_ExcludedFromBOM = false;
168 bool m_ExcludedFromSim = false;
171
173 std::map<wxString, SCH_SHEET_VARIANT> m_Variants;
174};
175
176
209
210
211class EDA_ITEM;
212class SCH_SHEET;
213class SCH_SCREEN;
214class SCH_MARKER;
215class SCH_ITEM;
216class SCH_SYMBOL;
218
219
223typedef std::map<wxString, SCH_REFERENCE_LIST> SCH_MULTI_UNIT_REFERENCE_MAP;
224
235{
236public:
238
239 SCH_SHEET_PATH( const SCH_SHEET_PATH& aOther );
240
241 SCH_SHEET_PATH& operator=( const SCH_SHEET_PATH& aOther );
242
243 // Move assignment operator
245
246 SCH_SHEET_PATH operator+( const SCH_SHEET_PATH& aOther );
247
248 ~SCH_SHEET_PATH() = default;
249
251 SCH_SHEET* at( size_t aIndex ) const { return m_sheets.at( aIndex ); }
252
254 void clear()
255 {
256 m_sheets.clear();
257 Rehash();
258 }
259
261 bool empty() const { return m_sheets.empty(); }
262
264 void pop_back()
265 {
266 m_sheets.pop_back();
267 Rehash();
268 }
269
271 void push_back( SCH_SHEET* aSheet )
272 {
273 m_sheets.push_back( aSheet );
274 Rehash();
275 }
276
278 size_t size() const { return m_sheets.size(); }
279
280 std::vector<SCH_SHEET*>::iterator erase( std::vector<SCH_SHEET*>::const_iterator aPosition )
281 {
282 return m_sheets.erase( aPosition );
283 }
284
285 void Rehash();
286
287 size_t GetCurrentHash() const { return m_current_hash; }
288
298 void SetVirtualPageNumber( int aPageNumber ) { m_virtualPageNumber = aPageNumber; }
299
301
307 void SetPageNumber( const wxString& aPageNumber );
308
309 wxString GetPageNumber() const;
310
311 int GetPageNumberAsInt() const;
312
313 const SCH_SHEET* GetSheet( unsigned aIndex ) const
314 {
315 SCH_SHEET* retv = nullptr;
316
317 if( aIndex < size() )
318 retv = at( aIndex );
319
320 return retv;
321 }
322
331 int Cmp( const SCH_SHEET_PATH& aSheetPathToTest ) const;
332
334 wxString GetCachedPageNumber() const { return m_cached_page_number; }
335
344 int ComparePageNum( const SCH_SHEET_PATH& aSheetPathToTest ) const;
345
352 bool IsContainedWithin( const SCH_SHEET_PATH& aSheetPathToTest ) const;
353
359 SCH_SHEET* Last() const;
360
365
366
368 SCH_SCREEN* LastScreen() const;
369
370 bool GetExcludedFromSim() const;
371 bool GetExcludedFromSim( const wxString& aVariantName ) const;
372 bool GetExcludedFromBOM() const;
373 bool GetExcludedFromBOM( const wxString& aVariantName ) const;
374 bool GetExcludedFromBoard() const;
375 bool GetExcludedFromBoard( const wxString& aVariantName ) const;
376 bool GetDNP() const;
377 bool GetDNP( const wxString& aVariantName ) const;
378
382 SCH_ITEM* ResolveItem( const KIID& aID ) const;
383
389 wxString PathAsString() const;
390
396 KIID_PATH Path() const;
397
413 wxString PathHumanReadable( bool aUseShortRootName = true,
414 bool aStripTrailingSeparator = false,
415 bool aEscapeSheetNames = false ) const;
416
423 void UpdateAllScreenReferences() const;
424
435 void AppendSymbol( SCH_REFERENCE_LIST& aReferences, SCH_SYMBOL* aSymbol,
436 SYMBOL_FILTER aSymbolFilter, bool aForceIncludeOrphanSymbols = false ) const;
437
447 void GetSymbols( SCH_REFERENCE_LIST& aReferences, SYMBOL_FILTER aSymbolFilter,
448 bool aForceIncludeOrphanSymbols = false ) const;
449
461 SYMBOL_FILTER aSymbolFilter ) const;
462
473 SYMBOL_FILTER aSymbolFilter ) const;
474
484 bool TestForRecursion( const wxString& aSrcFileName, const wxString& aDestFileName );
485
503
521 void AddNewSymbolInstances( const SCH_SHEET_PATH& aPrefixSheetPath,
522 const wxString& aProjectName );
523
524 void RemoveSymbolInstances( const SCH_SHEET_PATH& aPrefixSheetPath );
525
526 void CheckForMissingSymbolInstances( const wxString& aProjectName );
527
528 bool operator==( const SCH_SHEET_PATH& d1 ) const;
529
530 bool operator!=( const SCH_SHEET_PATH& d1 ) const { return !( *this == d1 ) ; }
531
532 bool operator<( const SCH_SHEET_PATH& d1 ) const { return m_sheets < d1.m_sheets; }
533
534private:
535 void initFromOther( const SCH_SHEET_PATH& aOther );
536
537protected:
538 std::vector<SCH_SHEET*> m_sheets;
539
541 mutable wxString m_cached_page_number;
542
544
545 std::map<std::pair<wxString, wxString>, bool> m_recursion_test_cache;
546};
547
548
549namespace std
550{
551 template<> struct hash<SCH_SHEET_PATH>
552 {
553 size_t operator()( const SCH_SHEET_PATH& path ) const;
554 };
555}
556
558{
559 size_t operator()( const SCH_SHEET_PATH& path ) const
560 {
561 return path.GetCurrentHash();
562 }
563};
564
566{
567 bool operator()( const SCH_SHEET_PATH& lhs, const SCH_SHEET_PATH& rhs ) const
568 {
569 return lhs.GetCurrentHash() < rhs.GetCurrentHash();
570 }
571};
572
573
582class SCH_SHEET_LIST : public std::vector<SCH_SHEET_PATH>
583{
584public:
590 SCH_SHEET_LIST( SCH_SHEET* aSheet = nullptr );
591
593
599 bool IsModified() const;
600
601 void ClearModifyStatus();
602
608 SCH_ITEM* ResolveItem( const KIID& aID, SCH_SHEET_PATH* aPathOut = nullptr,
609 bool aAllowNullptrReturn = false ) const;
610
614 void FillItemMap( std::map<KIID, EDA_ITEM*>& aMap );
615
625
635 void GetSymbols( SCH_REFERENCE_LIST& aReferences, SYMBOL_FILTER aSymbolFilter,
636 bool aForceIncludeOrphanSymbols = false ) const;
637
649 void GetSymbolsWithinPath( SCH_REFERENCE_LIST& aReferences, const SCH_SHEET_PATH& aSheetPath,
650 SYMBOL_FILTER aSymbolFilter,
651 bool aForceIncludeOrphanSymbols = false ) const;
652
660 void GetSheetsWithinPath( std::vector<SCH_SHEET_PATH>& aSheets,
661 const SCH_SHEET_PATH& aSheetPath ) const;
662
663
669 std::optional<SCH_SHEET_PATH> GetSheetPathByKIIDPath( const KIID_PATH& aPath,
670 bool aIncludeLastSheet = true ) const;
671
672
682 SYMBOL_FILTER aSymbolFilter ) const;
683
692 bool TestForRecursion( const SCH_SHEET_LIST& aSrcSheetHierarchy,
693 const wxString& aDestFileName );
694
700
706
710 SCH_SHEET_LIST FindAllSheetsForScreen( const SCH_SCREEN* aScreen ) const;
711
726 void BuildSheetList( SCH_SHEET* aSheet, bool aCheckIntegrity );
727
737 void SortByPageNumbers( bool aUpdateVirtualPageNums = true );
738
744 void SortByHierarchicalPageNumbers( bool aUpdateVirtualPageNums = true );
745
746 bool NameExists( const wxString& aSheetName ) const;
747
748 bool PageNumberExists( const wxString& aPageNumber ) const;
749
755 void TrimToPageNumbers( const std::vector<wxString>& aPageInclusions );
756
760 wxString GetNextPageNumber() const;
761
769 void UpdateSymbolInstanceData( const std::vector<SCH_SYMBOL_INSTANCE>& aSymbolInstances );
770
778 void UpdateSheetInstanceData( const std::vector<SCH_SHEET_INSTANCE>& aSheetInstances );
779
780 std::vector<KIID_PATH> GetPaths() const;
781
787 std::vector<SCH_SHEET_INSTANCE> GetSheetInstances() const;
788
797 bool AllSheetPageNumbersEmpty() const;
798
806
814 void AddNewSymbolInstances( const SCH_SHEET_PATH& aPrefixSheetPath,
815 const wxString& aProjectName );
816
817 void AddNewSheetInstances( const SCH_SHEET_PATH& aPrefixSheetPath,
818 int aLastVirtualPageNumber );
819
820 int GetLastVirtualPageNumber() const;
821
822 void RemoveSymbolInstances( const SCH_SHEET_PATH& aPrefixSheetPath );
823
824 void CheckForMissingSymbolInstances( const wxString& aProjectName );
825
826 bool HasPath( const KIID_PATH& aPath ) const;
827
828 bool ContainsSheet( const SCH_SHEET* aSheet ) const;
829
839 std::optional<SCH_SHEET_PATH> GetOrdinalPath( const SCH_SCREEN* aScreen ) const;
840
841private:
843};
844
845#endif // CLASS_DRAWSHEET_PATH_H
A base class for most all the KiCad significant classes used in schematics and boards.
Definition eda_item.h:100
Definition kiid.h:48
Base class for any item which can be embedded within the SCHEMATIC container class,...
Definition sch_item.h:168
Container to create a flattened list of symbols because in a complex hierarchy, a symbol can be used ...
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
std::optional< SCH_SHEET_PATH > GetSheetPathByKIIDPath(const KIID_PATH &aPath, bool aIncludeLastSheet=true) const
Finds a SCH_SHEET_PATH that matches the provided KIID_PATH.
SCH_ITEM * ResolveItem(const KIID &aID, SCH_SHEET_PATH *aPathOut=nullptr, bool aAllowNullptrReturn=false) const
Fetch a SCH_ITEM by ID.
std::optional< SCH_SHEET_PATH > GetOrdinalPath(const SCH_SCREEN *aScreen) const
Return the ordinal sheet path of aScreen.
void FillItemMap(std::map< KIID, EDA_ITEM * > &aMap)
Fill an item cache for temporary use when many items need to be fetched.
SCH_SHEET_PATH m_currentSheetPath
void TrimToPageNumbers(const std::vector< wxString > &aPageInclusions)
Truncates the list by removing sheet's with page numbers not in the given list.
void SortByPageNumbers(bool aUpdateVirtualPageNums=true)
Sort the list of sheets by page number.
void AddNewSymbolInstances(const SCH_SHEET_PATH &aPrefixSheetPath, const wxString &aProjectName)
Attempt to add new symbol instances for all symbols in this list of sheet paths prefixed with aPrefix...
bool NameExists(const wxString &aSheetName) const
void GetSymbolsWithinPath(SCH_REFERENCE_LIST &aReferences, const SCH_SHEET_PATH &aSheetPath, SYMBOL_FILTER aSymbolFilter, bool aForceIncludeOrphanSymbols=false) const
Add a SCH_REFERENCE object to aReferences for each symbol in the list of sheets that are contained wi...
std::vector< SCH_SHEET_INSTANCE > GetSheetInstances() const
Fetch the instance information for all of the sheets in the hierarchy.
void UpdateSheetInstanceData(const std::vector< SCH_SHEET_INSTANCE > &aSheetInstances)
Update all of the sheet instance information using aSheetInstances.
void SetInitialPageNumbers()
Set initial sheet page numbers.
void RemoveSymbolInstances(const SCH_SHEET_PATH &aPrefixSheetPath)
SCH_SHEET_LIST FindAllSheetsForScreen(const SCH_SCREEN *aScreen) const
Return a SCH_SHEET_LIST with a copy of all the SCH_SHEET_PATH using a particular screen.
wxString GetNextPageNumber() const
bool AllSheetPageNumbersEmpty() const
Check all of the sheet instance for empty page numbers.
bool IsModified() const
Check the entire hierarchy for any modifications.
SCH_SHEET_LIST(SCH_SHEET *aSheet=nullptr)
Construct a flattened list of SCH_SHEET_PATH objects from aSheet.
void AnnotatePowerSymbols()
Silently annotate the not yet annotated power symbols of the entire hierarchy of the sheet path list.
int GetLastVirtualPageNumber() const
void UpdateSymbolInstanceData(const std::vector< SCH_SYMBOL_INSTANCE > &aSymbolInstances)
Update all of the symbol instance information using aSymbolInstances.
void GetSheetsWithinPath(std::vector< SCH_SHEET_PATH > &aSheets, const SCH_SHEET_PATH &aSheetPath) const
Add a SCH_SHEET_PATH object to aSheets for each sheet in the list that are contained within aSheetPat...
bool PageNumberExists(const wxString &aPageNumber) const
void SortByHierarchicalPageNumbers(bool aUpdateVirtualPageNums=true)
This works like SortByPageNumbers, but it sorts the sheets first by their hierarchical depth and then...
void AddNewSheetInstances(const SCH_SHEET_PATH &aPrefixSheetPath, int aLastVirtualPageNumber)
void GetMultiUnitSymbols(SCH_MULTI_UNIT_REFERENCE_MAP &aRefList, SYMBOL_FILTER aSymbolFilter) const
Add a SCH_REFERENCE_LIST object to aRefList for each same-reference set of multi-unit parts in the li...
bool ContainsSheet(const SCH_SHEET *aSheet) const
std::vector< KIID_PATH > GetPaths() const
void BuildSheetList(SCH_SHEET *aSheet, bool aCheckIntegrity)
Build the list of sheets and their sheet path from aSheet.
SCH_SHEET_PATH FindSheetForScreen(const SCH_SCREEN *aScreen)
Return the first SCH_SHEET_PATH object (not necessarily the only one) using a particular screen.
void CheckForMissingSymbolInstances(const wxString &aProjectName)
bool HasPath(const KIID_PATH &aPath) const
SCH_SHEET_PATH * FindSheetForPath(const SCH_SHEET_PATH *aPath)
Return a pointer to the first SCH_SHEET_PATH object (not necessarily the only one) matching the provi...
void GetSymbols(SCH_REFERENCE_LIST &aReferences, SYMBOL_FILTER aSymbolFilter, bool aForceIncludeOrphanSymbols=false) const
Add a SCH_REFERENCE object to aReferences for each symbol in the list of sheets.
bool TestForRecursion(const SCH_SHEET_LIST &aSrcSheetHierarchy, const wxString &aDestFileName)
Test every SCH_SHEET_PATH in this SCH_SHEET_LIST to verify if adding the sheets stored in aSrcSheetHi...
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
void AppendSymbol(SCH_REFERENCE_LIST &aReferences, SCH_SYMBOL *aSymbol, SYMBOL_FILTER aSymbolFilter, bool aForceIncludeOrphanSymbols=false) const
Append a SCH_REFERENCE object to aReferences based on aSymbol.
bool GetExcludedFromBOM() const
bool operator!=(const SCH_SHEET_PATH &d1) const
const SCH_SHEET * GetSheet(unsigned aIndex) const
bool empty() const
Forwarded method from std::vector.
int ComparePageNum(const SCH_SHEET_PATH &aSheetPathToTest) const
Compare sheets by their page number.
size_t GetCurrentHash() const
void GetMultiUnitSymbols(SCH_MULTI_UNIT_REFERENCE_MAP &aRefList, SYMBOL_FILTER aSymbolFilter) const
Add a SCH_REFERENCE_LIST object to aRefList for each same-reference set of multi-unit parts in the sh...
void GetSymbols(SCH_REFERENCE_LIST &aReferences, SYMBOL_FILTER aSymbolFilter, bool aForceIncludeOrphanSymbols=false) const
Adds SCH_REFERENCE object to aReferences for each symbol in the sheet.
std::vector< SCH_SHEET * >::iterator erase(std::vector< SCH_SHEET * >::const_iterator aPosition)
bool operator==(const SCH_SHEET_PATH &d1) const
void AddNewSymbolInstances(const SCH_SHEET_PATH &aPrefixSheetPath, const wxString &aProjectName)
Attempt to add new symbol instances for all symbols in this sheet path prefixed with aPrefixSheetPath...
KIID_PATH Path() const
Get the sheet path as an KIID_PATH.
bool TestForRecursion(const wxString &aSrcFileName, const wxString &aDestFileName)
Test the SCH_SHEET_PATH file names to check adding the sheet stored in the file aSrcFileName to the s...
void UpdateAllScreenReferences() const
Update all the symbol references for this sheet path.
bool operator<(const SCH_SHEET_PATH &d1) const
void MakeFilePathRelativeToParentSheet()
Make the sheet file name relative to its parent sheet.
SCH_ITEM * ResolveItem(const KIID &aID) const
Fetch a SCH_ITEM by ID.
wxString GetCachedPageNumber() const
std::vector< SCH_SHEET * > m_sheets
SCH_SCREEN * LastScreen()
int Cmp(const SCH_SHEET_PATH &aSheetPathToTest) const
Compare if this is the same sheet path as aSheetPathToTest.
void initFromOther(const SCH_SHEET_PATH &aOther)
wxString m_cached_page_number
wxString GetPageNumber() const
void RemoveSymbolInstances(const SCH_SHEET_PATH &aPrefixSheetPath)
void CheckForMissingSymbolInstances(const wxString &aProjectName)
bool IsContainedWithin(const SCH_SHEET_PATH &aSheetPathToTest) const
Check if this path is contained inside aSheetPathToTest.
~SCH_SHEET_PATH()=default
void CachePageNumber() const
SCH_SHEET * at(size_t aIndex) const
Forwarded method from std::vector.
void SetVirtualPageNumber(int aPageNumber)
Set the sheet instance virtual page number.
wxString PathHumanReadable(bool aUseShortRootName=true, bool aStripTrailingSeparator=false, bool aEscapeSheetNames=false) const
Return the sheet path in a human readable form made from the sheet names.
std::map< std::pair< wxString, wxString >, bool > m_recursion_test_cache
bool GetExcludedFromSim() const
wxString PathAsString() const
Return the path of time stamps which do not changes even when editing sheet parameters.
void AppendMultiUnitSymbol(SCH_MULTI_UNIT_REFERENCE_MAP &aRefList, SCH_SYMBOL *aSymbol, SYMBOL_FILTER aSymbolFilter) const
Append a SCH_REFERENCE_LIST object to aRefList based on aSymbol, storing same-reference set of multi-...
bool GetExcludedFromBoard() const
void SetPageNumber(const wxString &aPageNumber)
Set the sheet instance user definable page number.
SCH_SHEET_PATH & operator=(const SCH_SHEET_PATH &aOther)
int GetPageNumberAsInt() const
bool GetDNP() const
SCH_SHEET * Last() const
Return a pointer to the last SCH_SHEET of the list.
SCH_SHEET_PATH operator+(const SCH_SHEET_PATH &aOther)
int m_virtualPageNumber
Page numbers are maintained by the sheet load order.
void push_back(SCH_SHEET *aSheet)
Forwarded method from std::vector.
void clear()
Forwarded method from std::vector.
size_t size() const
Forwarded method from std::vector.
int GetVirtualPageNumber() const
void pop_back()
Forwarded method from std::vector.
void InitializeAttributes(const SCH_SHEET &aSheet)
SCH_SHEET_VARIANT(const wxString &aName=wxEmptyString)
virtual ~SCH_SHEET_VARIANT()=default
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
Definition sch_sheet.h:48
virtual ~SCH_SYMBOL_VARIANT()=default
void InitializeAttributes(const SCH_SYMBOL &aSymbol)
SCH_SYMBOL_VARIANT(const wxString &aName=wxEmptyString)
Schematic symbol object.
Definition sch_symbol.h:76
wxString m_Name
virtual ~VARIANT()=default
bool m_ExcludedFromBOM
std::map< wxString, wxString > m_Fields
bool m_ExcludedFromPosFiles
bool m_ExcludedFromSim
bool m_ExcludedFromBoard
wxString m_Description
VARIANT(const wxString &aName=wxEmptyString)
STL namespace.
std::map< wxString, SCH_REFERENCE_LIST > SCH_MULTI_UNIT_REFERENCE_MAP
Container to map reference designators for multi-unit parts.
SYMBOL_FILTER
@ SYMBOL_FILTER_NON_POWER
@ SYMBOL_FILTER_ALL
@ SYMBOL_FILTER_POWER
A simple container for sheet instance information.
std::map< wxString, SCH_SHEET_VARIANT > m_Variants
A list of sheet variants.
A simple container for schematic symbol instance information.
std::map< wxString, SCH_SYMBOL_VARIANT > m_Variants
A list of symbol variants.
bool operator()(const SCH_SHEET_PATH &lhs, const SCH_SHEET_PATH &rhs) const
size_t operator()(const SCH_SHEET_PATH &path) const
size_t operator()(const SCH_SHEET_PATH &path) const
std::string path