36#include <wx/filename.h>
54 return _(
"(Deleted Item)" );
59 return wxT(
"DELETED_SHEET_ITEM" );
90 void Show(
int , std::ostream& )
const override {}
119 return path.GetCurrentHash();
147 m_sheets = std::move( aOther.m_sheets );
165 for(
size_t i = 0; i <
size; i++ )
195 if(
size() > aSheetPathToTest.
size() )
198 if(
size() < aSheetPathToTest.
size() )
202 for(
unsigned i = 0; i <
size(); i++ )
204 if(
at( i )->m_Uuid < aSheetPathToTest.
at( i )->
m_Uuid )
207 if(
at( i )->m_Uuid != aSheetPathToTest.
at( i )->
m_Uuid )
222 if( pageNumComp == 0 )
227 if( virtualPageA > virtualPageB )
229 else if( virtualPageA < virtualPageB )
239 if( aSheetPathToTest.
size() >
size() )
242 for(
size_t i = 0; i < aSheetPathToTest.
size(); ++i )
244 if(
at( i )->m_Uuid != aSheetPathToTest.
at( i )->
m_Uuid )
295 if( sheet->GetExcludedFromSim() )
305 if( aVariantName.IsEmpty() )
310 while( !
copy.empty() )
327 if( sheet->GetExcludedFromBOM() )
337 if( aVariantName.IsEmpty() )
342 while( !
copy.empty() )
359 if( sheet->GetExcludedFromBoard() )
369 if( aVariantName.IsEmpty() )
374 while( !
copy.empty() )
391 if( sheet->GetDNP() )
401 if( aVariantName.IsEmpty() )
406 while( !
copy.empty() )
427 for(
unsigned i = 1; i <
size(); i++ )
453 for(
size_t i = 1; i <
size; i++ )
461 bool aStripTrailingSeparator,
462 bool aEscapeSheetNames )
const
469 if( !
empty() &&
at( 0 )->IsVirtualRootSheet() )
472 if( aUseShortRootName )
480 if(
size() > startIdx &&
at( startIdx )->GetScreen() )
483 wxFileName fn = fileName;
485 s = fn.GetName() + wxS(
"/" );
492 size_t loopStart = startIdx + 1;
494 if( aUseShortRootName &&
size() > startIdx )
500 loopStart = startIdx;
503 for(
unsigned i = loopStart; i <
size(); i++ )
507 if( aEscapeSheetNames )
510 s << sheetName << wxS(
"/" );
513 if( aStripTrailingSeparator && s.EndsWith(
"/" ) )
514 s = s.Left( s.length() - 1 );
522 std::vector<SCH_ITEM*> items;
525 std::back_inserter( items ),
533 std::optional<wxString> variantName;
577 bool isPowerSymbol = !aReference.IsEmpty() && aReference[0] == wxT(
'#' );
579 switch( aSymbolFilter )
586 default:
return !isPowerSymbol;
592 bool aForceIncludeOrphanSymbols )
const
597 AppendSymbol( aReferences, symbol, aSymbolFilter, aForceIncludeOrphanSymbols );
603 bool aForceIncludeOrphanSymbols )
const
614 aReferences.
AddItem( schReference );
644 wxString reference_str = schReference.
GetRef();
647 if( reference_str[reference_str.Len() - 1] ==
'?' )
650 aRefList[reference_str].AddItem( schReference );
663 auto pair = std::make_pair( aSrcFileName, aDestFileName );
670 wxCHECK_MSG( sch,
false,
"No SCHEMATIC found in SCH_SHEET_PATH::TestForRecursion!" );
673 wxFileName srcFn = aSrcFileName;
674 wxFileName destFn = aDestFileName;
676 if( srcFn.IsRelative() )
677 srcFn.MakeAbsolute( rootFn.GetPath() );
679 if( destFn.IsRelative() )
680 destFn.MakeAbsolute( rootFn.GetPath() );
683 if( srcFn == destFn )
698 if( cmpFn.IsRelative() )
699 cmpFn.MakeAbsolute( rootFn.GetPath() );
702 if( cmpFn == destFn )
710 if( i >=
size() || i == 0 )
724 if( cmpFn.IsRelative() )
725 cmpFn.MakeAbsolute( rootFn.GetPath() );
745 wxCHECK( sheet, wxEmptyString );
749 if( !tmpPath.empty() )
752 return wxEmptyString;
762 if( pageStr.ToLong( &page ) )
777 if( !tmpPath.empty() )
783 wxCHECK_MSG(
false, , wxS(
"Sheet paths must have a least one valid sheet." ) );
792 const wxString& aProjectName )
794 wxCHECK( !aProjectName.IsEmpty(), );
800 newSheetPath = newSheetPath + currentSheetPath;
806 wxCHECK2( symbol,
continue );
815 newSymbolInstance.
m_Path = newSheetPath.
Path();
824 newSymbolInstance.
m_Path = newSheetPath.
Path();
833 newSymbolInstance.
m_Path = newSheetPath.
Path();
848 wxCHECK2( symbol,
continue );
854 fullSheetPath = fullSheetPath + currentSheetPath;
866 wxLogTrace(
traceSchSheetPaths,
"CheckForMissingSymbolInstances for path: %s (project: %s)",
875 wxCHECK2( symbol,
continue );
888 (
LastScreen()->GetFileFormatVersionAtLoad() <= 20200310 ) )
895 " Legacy format: Using reference '%s' from field, unit %d",
904 const std::vector<SCH_SYMBOL_INSTANCE>& instances = symbol->
GetInstances();
906 auto sourceIt = std::find_if( instances.begin(), instances.end(),
909 return aInstance.m_ProjectName == aProjectName;
912 if( sourceIt == instances.end() )
913 sourceIt = instances.begin();
915 symbolInstance = *sourceIt;
918 " Using available instance (project '%s'): ref=%s, unit=%d, variants=%zu",
919 sourceIt->m_ProjectName, symbolInstance.
m_Reference,
930 " No instance data: Using reference '%s' from field, unit %d",
939 " Created instance: ref=%s, path=%s",
945 " Symbol %s already has instance: ref=%s, path=%s",
961 if( sheetFileName.IsAbsolute() )
967 wxCHECK( screen && parentScreen, );
970 wxFileName parentFileName = parentScreen->
GetFileName();
974 wxCHECK( fileName.IsAbsolute() && parentFileName.IsAbsolute(), );
976 if( fileName.GetPath() == parentFileName.GetPath() )
980 else if( fileName.MakeRelativeTo( parentFileName.GetPath() ) )
990 wxT(
"\n File name: '%s'"
991 "\n parent file name '%s',"
992 "\n sheet '%s' file name '%s'." ),
994 Last()->GetFileName() );
1000 if( aSheet !=
nullptr )
1011 "BuildSheetList called with sheet '%s' (UUID=%s, isVirtualRoot=%d)",
1019 wxLogTrace(
traceSchSheetPaths,
" Skipping virtual root, processing children only" );
1023 std::vector<SCH_ITEM*> childSheets;
1026 for(
SCH_ITEM* item : childSheets )
1036 std::vector<SCH_SHEET*> badSheets;
1045 std::vector<SCH_ITEM*> childSheets;
1048 for(
SCH_ITEM* item : childSheets )
1052 if( aCheckIntegrity )
1057 badSheets.push_back( sheet );
1064 wxT(
"Recursion prevented in SCH_SHEET_LIST::BuildSheetList" ) );
1071 if( aCheckIntegrity )
1087 path.CachePageNumber();
1089 std::sort( begin(),
end(),
1093 size_t common_len = 0;
1094 size_t min_len = std::min( a.
size(), b.
size() );
1096 while( common_len < min_len && a.
at( common_len )->
m_Uuid == b.
at( common_len )->
m_Uuid )
1101 if( common_len == a.
size() )
1103 if( common_len == b.
size() )
1114 for(
size_t i = 0; i < common_len; i++ )
1115 ancestor.push_back( a.
at( i )->
m_Uuid );
1136 if( aUpdateVirtualPageNums )
1138 int virtualPageNum = 1;
1149 path.CachePageNumber();
1151 std::sort( begin(),
end(),
1159 else if( retval > 0 )
1171 if( aUpdateVirtualPageNums )
1173 int virtualPageNum = 1;
1207 auto it = std::remove_if( begin(),
end(),
1210 return std::find( aPageInclusions.begin(),
1211 aPageInclusions.end(),
1221 wxString pageNumber;
1224 std::set<int> usedPageNumbers;
1228 wxString existingPageNum =
path.GetPageNumber();
1231 if( existingPageNum.ToLong( &pageNum ) && pageNum > 0 )
1232 usedPageNumbers.insert(
static_cast<int>( pageNum ) );
1236 int nextAvailable = 1;
1238 while( usedPageNumbers.count( nextAvailable ) > 0 )
1241 pageNumber.Printf( wxT(
"%d" ), nextAvailable );
1284 if( aAllowNullptrReturn )
1295 if( aItem->m_Uuid == aID )
1303 if( aChild->
m_Uuid == aID )
1304 childMatch = aChild;
1324 aMap[ aItem->m_Uuid ] = aItem;
1326 aItem->RunOnChildren(
1329 aMap[ aChild->
m_Uuid ] = aChild;
1353 if( libSymbol && libSymbol->
IsPower() )
1356 references.
AddItem( schReference );
1362 std::map<wxString, int> ref_list;
1364 for(
unsigned ii = 0; ii< references.
GetCount(); ++ii )
1366 wxString curr_ref = references[ii].GetRef();
1368 if( curr_ref.IsEmpty() )
1371 if( ref_list.find( curr_ref ) == ref_list.end() )
1373 ref_list[curr_ref] = ii;
1378 if( curr_ref.Last() <
'0' && curr_ref.Last() >
'9' )
1382 while( !curr_ref.IsEmpty() && curr_ref.Last() >=
'0' && curr_ref.Last() <=
'9' )
1383 curr_ref.RemoveLast();
1385 references[ii].SetRef( curr_ref );
1394 for(
unsigned ii = 0; ii< references.
GetCount(); ++ii )
1398 if( ref_unit.
GetRef()[0] !=
'#' )
1400 wxString new_ref =
"#" + ref_unit.
GetRef();
1401 ref_unit.
SetRef( new_ref );
1409 bool aForceIncludeOrphanSymbols )
const
1412 sheet.
GetSymbols( aReferences, aSymbolFilter, aForceIncludeOrphanSymbols );
1417 SYMBOL_FILTER aSymbolFilter,
bool aForceIncludeOrphanSymbols )
const
1422 sheet.
GetSymbols( aReferences, aSymbolFilter, aForceIncludeOrphanSymbols );
1433 aSheets.push_back( sheet );
1439 bool aIncludeLastSheet )
const
1445 if( !aIncludeLastSheet )
1446 testPath.pop_back();
1448 if( testPath == aPath )
1452 return std::nullopt;
1458 for(
auto it = begin(); it !=
end(); ++it )
1461 ( *it ).GetMultiUnitSymbols( tempMap, aSymbolFilter );
1463 for( SCH_MULTI_UNIT_REFERENCE_MAP::value_type& pair : tempMap )
1466 unsigned n_refs = pair.second.GetCount();
1468 for(
unsigned thisRef = 0; thisRef < n_refs; ++thisRef )
1469 aRefList[pair.first].AddItem( pair.second[thisRef] );
1476 const wxString& aDestFileName )
1481 SCHEMATIC* sch = at( 0 ).LastScreen()->Schematic();
1483 wxCHECK_MSG( sch,
false,
"No SCHEMATIC found in SCH_SHEET_LIST::TestForRecursion!" );
1486 wxFileName destFn = aDestFileName;
1488 if( destFn.IsRelative() )
1489 destFn.MakeAbsolute( rootFn.GetPath() );
1492 for(
unsigned i = 0; i < size(); i++ )
1495 for(
unsigned j = 0; j < aSrcSheetHierarchy.size(); j++ )
1499 for(
unsigned k = 0; k < sheetPath->
size(); k++ )
1546 retval.push_back( sheetpath );
1554 const std::vector<SCH_SYMBOL_INSTANCE>& aSymbolInstances )
1562 wxCHECK2( symbol,
continue );
1565 sheetPathWithSymbolUuid.push_back( symbol->
m_Uuid );
1567 auto it = std::find_if( aSymbolInstances.begin(), aSymbolInstances.end(),
1570 return sheetPathWithSymbolUuid == r.m_Path;
1573 if( it == aSymbolInstances.end() )
1576 sheetPathWithSymbolUuid.
AsString() );
1585 if( !it->m_Value.IsEmpty() )
1588 if( !it->m_Footprint.IsEmpty() )
1604 wxCHECK2( sheet &&
path.Last(),
continue );
1606 auto it = std::find_if( aSheetInstances.begin(), aSheetInstances.end(),
1609 return path.Path() == r.m_Path;
1612 if( it == aSheetInstances.end() )
1615 path.Path().AsString() );
1620 ( sheet->
GetName().IsEmpty() ) ? wxString( wxT(
"root" ) ) : sheet->
GetName(),
1621 path.Path().AsString(), it->m_PageNumber );
1622 path.SetPageNumber( it->m_PageNumber );
1629 std::vector<KIID_PATH> paths;
1632 paths.emplace_back( sheetPath.
Path() );
1640 std::vector<SCH_SHEET_INSTANCE> retval;
1646 wxCHECK2( sheet,
continue );
1655 retval.push_back( std::move( instance ) );
1687 tmp.Printf(
"%d", pageNumber );
1695 const wxString& aProjectName )
1710 int aLastVirtualPageNumber )
1712 wxString pageNumber;
1713 int lastUsedPageNumber = 1;
1714 int nextVirtualPageNumber = aLastVirtualPageNumber;
1717 std::vector< wxString > usedPageNumbers;
1719 if( aPrefixSheetPath.
size() )
1725 pageNumber =
path.GetPageNumber();
1727 if( !pageNumber.IsEmpty() )
1728 usedPageNumbers.emplace_back( pageNumber );
1738 newSheetPath = newSheetPath + sheetPath;
1745 wxCHECK2( sheet,
continue );
1747 nextVirtualPageNumber += 1;
1764 pageNumber.Printf( wxT(
"%d" ), lastUsedPageNumber );
1765 lastUsedPageNumber += 1;
1766 }
while( std::find( usedPageNumbers.begin(), usedPageNumbers.end(), pageNumber ) !=
1767 usedPageNumbers.end() );
1782 "SCH_SHEET_LIST::CheckForMissingSymbolInstances: Processing %zu sheet paths",
1788 " Processing sheet path: '%s' (size=%zu, KIID_PATH='%s')",
1799 int lastVirtualPageNumber = 1;
1807 return lastVirtualPageNumber;
1815 if(
path.Path() == aPath )
1827 for(
size_t i = 0; i <
path.size(); i++ )
1829 if(
path.at( i ) == aSheet )
1842 return std::nullopt;
1846 if(
path.LastScreen() == aScreen )
1847 return std::optional<SCH_SHEET_PATH>(
path );
1850 return std::nullopt;
bool IsContentModified() const
void SetContentModified(bool aModified=true)
wxString GetClass() const override
Return the class name.
void SetPosition(const VECTOR2I &) override
static DELETED_SHEET_ITEM * GetInstance()
double Similarity(const SCH_ITEM &aOther) const override
Return a measure of how likely the other object is to represent the same object.
void Rotate(const VECTOR2I &aCenter, bool aRotateCCW) override
Rotate the item around aCenter 90 degrees in the clockwise direction.
void Move(const VECTOR2I &aMoveVector) override
Move the item by aMoveVector to a new position.
wxString GetItemDescription(UNITS_PROVIDER *aUnitsProvider, bool aFull) const override
Return a user-visible description string of this item.
bool operator==(const SCH_ITEM &aOther) const override
void MirrorVertically(int aCenter) override
Mirror item vertically about aCenter.
void MirrorHorizontally(int aCenter) override
Mirror item horizontally about aCenter.
KICAD_T Type() const
Returns the type of object.
virtual void UpdateHatching() const
virtual bool IsVisible() const
virtual void SetVisible(bool aVisible)
EE_TYPE OfType(KICAD_T aType) const
wxString AsString() const
wxString AsString() const
Define a library symbol object.
bool IsPower() const override
int GetUnitCount() const override
bool m_IntersheetRefsShow
Holds all the data relating to one schematic.
wxString GetFileName() const
Helper to retrieve the filename from the root sheet screen.
SCHEMATIC_SETTINGS & Settings() const
wxString GetCurrentVariant() const
Return the current variant being edited.
std::vector< SCH_SHEET * > GetTopLevelSheets() const
Get the list of top-level sheets.
VECTOR2I GetPosition() const override
virtual const wxString & GetText() const override
Return the string associated with the text object.
wxString GetShownText(const SCH_SHEET_PATH *aPath, bool aAllowExtraText, int aDepth=0, const wxString &aVariantName=wxEmptyString) const
void SetText(const wxString &aText) override
SCH_FIELD * GetField(FIELD_T aFieldType)
Return a mandatory field in this label.
Base class for any item which can be embedded within the SCHEMATIC container class,...
virtual void RunOnChildren(const std::function< void(SCH_ITEM *)> &aFunction, RECURSE_MODE aMode)
SCHEMATIC * Schematic() const
Search the item hierarchy to find a SCHEMATIC.
virtual void SetUnit(int aUnit)
SCH_ITEM(EDA_ITEM *aParent, KICAD_T aType, int aUnit=0, int aBodyStyle=0)
void AutoplaceFields(SCH_SCREEN *aScreen, AUTOPLACE_ALGO aAlgo) override
std::vector< SCH_FIELD > & GetFields()
Container to create a flattened list of symbols because in a complex hierarchy, a symbol can be used ...
void SplitReferences()
Attempt to split all reference designators into a name (U) and number (1).
void AddItem(const SCH_REFERENCE &aItem)
A helper to define a symbol's reference designator in a schematic.
void SetRef(const wxString &aReference)
void SetSheetNumber(int aSheetNumber)
EE_RTREE & Items()
Get the full RTree, usually for iterating.
const wxString & GetFileName() const
SCHEMATIC * Schematic() const
void Update(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
Update aItem's bounding box in the tree.
void GetSheets(std::vector< SCH_ITEM * > *aItems) const
Similar to Items().OfType( SCH_SHEET_T ), but return the sheets in a deterministic order (L-R,...
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
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.
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.
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 * 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
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.
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)
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
void SetFileName(const wxString &aFilename)
wxString GetFileName() const
Return the filename corresponding to this sheet.
bool getInstance(SCH_SHEET_INSTANCE &aInstance, const KIID_PATH &aSheetPath, bool aTestFromEnd=false) const
bool addInstance(const KIID_PATH &aInstance)
Add a new instance aSheetPath to the instance list.
wxString getPageNumber(const KIID_PATH &aParentPath) const
Return the sheet page number for aParentPath.
bool IsTopLevelSheet() const
Check if this sheet is a top-level sheet.
SCH_FIELD * GetField(FIELD_T aFieldType)
Return a mandatory field in this sheet.
bool GetExcludedFromBOM(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
bool GetExcludedFromSim(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
SCH_SCREEN * GetScreen() const
static int ComparePageNum(const wxString &aPageNumberA, const wxString &aPageNumberB)
Compare page numbers of schematic sheets.
void setPageNumber(const KIID_PATH &aInstance, const wxString &aPageNumber)
Set the page number for the sheet instance aInstance.
bool IsVirtualRootSheet() const
bool GetDNP(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
Set or clear the 'Do Not Populate' flags.
bool GetExcludedFromBoard(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
void InitializeAttributes(const SCH_SYMBOL &aSymbol)
void UpdatePrefix()
Set the prefix based on the current reference designator.
bool GetExcludedFromSim(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
const std::vector< SCH_SYMBOL_INSTANCE > & GetInstances() const
void RemoveInstance(const SCH_SHEET_PATH &aInstancePath)
bool GetExcludedFromBOM(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
void SetFootprintFieldText(const wxString &aFootprint)
void AddHierarchicalReference(const KIID_PATH &aPath, const wxString &aRef, int aUnit)
Add a full hierarchical reference to this symbol.
void SetValueFieldText(const wxString &aValue, const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString)
bool GetExcludedFromPosFiles(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
bool GetInstance(SCH_SYMBOL_INSTANCE &aInstance, const KIID_PATH &aSheetPath, bool aTestFromEnd=false) const
bool GetExcludedFromBoard(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
int GetUnitSelection(const SCH_SHEET_PATH *aSheet) const
Return the instance-specific unit selection for the given sheet path.
std::unique_ptr< LIB_SYMBOL > & GetLibSymbolRef()
virtual bool GetDNP(const SCH_SHEET_PATH *aInstance=nullptr, const wxString &aVariantName=wxEmptyString) const override
Set or clear the 'Do Not Populate' flag.
const wxString GetRef(const SCH_SHEET_PATH *aSheet, bool aIncludeUnit=false) const override
SCH_FIELD * GetField(FIELD_T aFieldType)
Return a mandatory field in this symbol.
bool m_ExcludedFromPosFiles
static bool empty(const wxTextEntryBase *aCtrl)
const wxChar *const tracePathsAndFiles
Flag to enable path and file name debug output.
const wxChar *const traceSchSheetPaths
Flag to enable debug output of schematic symbol sheet path manipulation code.
static constexpr void hash_combine(std::size_t &seed)
This is a dummy function to take the final case of hash_combine below.
Collection of utility functions for component reference designators (refdes)
static bool matchesSymbolFilter(const wxString &aReference, SYMBOL_FILTER aSymbolFilter)
Definition of the SCH_SHEET_PATH and SCH_SHEET_LIST classes for Eeschema.
std::map< wxString, SCH_REFERENCE_LIST > SCH_MULTI_UNIT_REFERENCE_MAP
Container to map reference designators for multi-unit parts.
@ SYMBOL_FILTER_NON_POWER
wxString EscapeString(const wxString &aSource, ESCAPE_CONTEXT aContext)
The Escape/Unescape routines use HTML-entity-reference-style encoding to handle characters which are:...
A simple container for sheet instance information.
A simple container for schematic symbol instance information.
std::map< wxString, SCH_SYMBOL_VARIANT > m_Variants
A list of symbol variants.
size_t operator()(const SCH_SHEET_PATH &path) const
@ INTERSHEET_REFS
Global label cross-reference page numbers.
@ REFERENCE
Field Reference of part, i.e. "IC21".
table push_back({ "Source", "Layer", "Vertices", "Strategy", "Build(us)", "ns/query", "Mquery/s", "Inside" })
wxLogTrace helper definitions.
@ NOT_USED
the 3d code uses this value
VECTOR2< int32_t > VECTOR2I