40#include <boost/functional/hash.hpp>
41#include <wx/filename.h>
58 return _(
"(Deleted Item)" );
63 return wxT(
"DELETED_SHEET_ITEM" );
94 void Show(
int , std::ostream& )
const override {}
102 return path.GetCurrentHash();
133 for(
size_t i = 0; i <
size; i++ )
170 if(
size() > aSheetPathToTest.
size() )
173 if(
size() < aSheetPathToTest.
size() )
177 for(
unsigned i = 0; i <
size(); i++ )
197 if( pageNumComp == 0 )
202 if( virtualPageA > virtualPageB )
204 else if( virtualPageA < virtualPageB )
214 if( aSheetPathToTest.
size() >
size() )
217 for(
size_t i = 0; i < aSheetPathToTest.
size(); ++i )
219 if(
at( i )->m_Uuid != aSheetPathToTest.
at( i )->
m_Uuid )
270 if( sheet->GetExcludedFromSim() )
282 if( sheet->GetExcludedFromBOM() )
294 if( sheet->GetExcludedFromBoard() )
306 if( sheet->GetDNP() )
322 for(
unsigned i = 1; i <
size(); i++ )
335 path.push_back( sheet->m_Uuid );
342 bool aStripTrailingSeparator )
const
346 if( aUseShortRootName )
354 if( !
empty() &&
at( 0 )->GetScreen() )
357 wxFileName fn = fileName;
359 s = fn.GetName() + wxS(
"/" );
363 for(
unsigned i = 1; i <
size(); i++ )
366 if( aStripTrailingSeparator && s.EndsWith(
"/" ) )
367 s = s.Left( s.length() - 1 );
375 std::vector<SCH_ITEM*> items;
378 std::back_inserter( items ),
422 bool aForceIncludeOrphanSymbols )
const
427 AppendSymbol( aReferences, symbol, aIncludePowerSymbols, aForceIncludeOrphanSymbols );
433 bool aIncludePowerSymbols,
434 bool aForceIncludeOrphanSymbols )
const
438 if( aIncludePowerSymbols || aSymbol->
GetRef(
this )[0] != wxT(
'#' ) )
445 aReferences.
AddItem( schReference );
452 bool aIncludePowerSymbols )
const
464 bool aIncludePowerSymbols )
const
468 if( !aIncludePowerSymbols && aSymbol->
GetRef(
this )[0] == wxT(
'#' ) )
477 wxString reference_str = schReference.
GetRef();
480 if( reference_str[reference_str.Len() - 1] ==
'?' )
483 aRefList[reference_str].AddItem( schReference );
496 auto pair = std::make_pair( aSrcFileName, aDestFileName );
503 wxCHECK_MSG( sch,
false,
"No SCHEMATIC found in SCH_SHEET_PATH::TestForRecursion!" );
506 wxFileName srcFn = aSrcFileName;
507 wxFileName destFn = aDestFileName;
509 if( srcFn.IsRelative() )
510 srcFn.MakeAbsolute( rootFn.GetPath() );
512 if( destFn.IsRelative() )
513 destFn.MakeAbsolute( rootFn.GetPath() );
516 if( srcFn == destFn )
531 if( cmpFn.IsRelative() )
532 cmpFn.MakeAbsolute( rootFn.GetPath() );
535 if( cmpFn == destFn )
543 if( i >=
size() || i == 0 )
557 if( cmpFn.IsRelative() )
558 cmpFn.MakeAbsolute( rootFn.GetPath() );
578 wxCHECK( sheet, wxEmptyString );
603 const wxString& aProjectName )
605 wxCHECK( !aProjectName.IsEmpty(), );
611 newSheetPath = newSheetPath + currentSheetPath;
617 wxCHECK2( symbol,
continue );
626 newSymbolInstance.
m_Path = newSheetPath.
Path();
635 newSymbolInstance.
m_Path = newSheetPath.
Path();
644 newSymbolInstance.
m_Path = newSheetPath.
Path();
659 wxCHECK2( symbol,
continue );
665 fullSheetPath = fullSheetPath + currentSheetPath;
673 wxCHECK( !aProjectName.IsEmpty() &&
LastScreen(), );
679 wxCHECK2( symbol,
continue );
705 if( sheetFileName.IsAbsolute() )
711 wxCHECK( screen && parentScreen, );
714 wxFileName parentFileName = parentScreen->
GetFileName();
718 wxCHECK( fileName.IsAbsolute() && parentFileName.IsAbsolute(), );
720 if( fileName.GetPath() == parentFileName.GetPath() )
724 else if( fileName.MakeRelativeTo( parentFileName.GetPath() ) )
734 wxT(
"\n File name: '%s'"
735 "\n parent file name '%s',"
736 "\n sheet '%s' file name '%s'." ),
738 Last()->GetFileName() );
744 if( aSheet !=
nullptr )
751 wxCHECK_RET( aSheet !=
nullptr, wxT(
"Cannot build sheet list from undefined sheet." ) );
753 std::vector<SCH_SHEET*> badSheets;
762 std::vector<SCH_ITEM*> childSheets;
769 if( aCheckIntegrity )
774 badSheets.push_back( sheet );
781 wxT(
"Recursion prevented in SCH_SHEET_LIST::BuildSheetList" ) );
788 if( aCheckIntegrity )
804 path.CachePageNumber();
806 std::sort( begin(), end(),
814 else if( retval > 0 )
826 if( aUpdateVirtualPageNums )
828 int virtualPageNum = 1;
862 auto it = std::remove_if( begin(), end(),
865 return std::find( aPageInclusions.begin(), aPageInclusions.end(),
867 == aPageInclusions.end();
920 if( aItem->m_Uuid == aID )
928 if( aChild->
m_Uuid == aID )
948 aMap[ aItem->m_Uuid ] = aItem;
950 aItem->RunOnChildren(
953 aMap[ aChild->
m_Uuid ] = aChild;
977 if( libSymbol && libSymbol->
IsPower() )
980 references.
AddItem( schReference );
986 std::map<wxString, int> ref_list;
988 for(
unsigned ii = 0; ii< references.
GetCount(); ++ii )
990 wxString curr_ref = references[ii].GetRef();
992 if( ref_list.find( curr_ref ) == ref_list.end() )
994 ref_list[curr_ref] = ii;
999 if( curr_ref.Last() <
'0' && curr_ref.Last() >
'9' )
1003 while( curr_ref.Last() >=
'0' && curr_ref.Last() <=
'9' )
1004 curr_ref.RemoveLast();
1006 references[ii].SetRef( curr_ref );
1015 for(
unsigned ii = 0; ii< references.
GetCount(); ++ii )
1017 if( references[ii].GetRef()[0] !=
'#' )
1019 wxString new_ref =
"#" + references[ii].GetRef();
1020 references[ii].SetRef( new_ref );
1025 references.
Annotate(
false, 0, 100, lockedSymbols, additionalreferences );
1031 bool aForceIncludeOrphanSymbols )
const
1034 sheet.
GetSymbols( aReferences, aIncludePowerSymbols, aForceIncludeOrphanSymbols );
1040 bool aIncludePowerSymbols,
1041 bool aForceIncludeOrphanSymbols )
const
1046 sheet.
GetSymbols( aReferences, aIncludePowerSymbols, aForceIncludeOrphanSymbols );
1057 aSheets.push_back( sheet );
1063 bool aIncludeLastSheet )
const
1069 if( !aIncludeLastSheet )
1070 testPath.pop_back();
1072 if( testPath == aPath )
1076 return std::nullopt;
1081 bool aIncludePowerSymbols )
const
1083 for(
auto it = begin(); it != end(); ++it )
1086 ( *it ).GetMultiUnitSymbols( tempMap, aIncludePowerSymbols );
1088 for( SCH_MULTI_UNIT_REFERENCE_MAP::value_type& pair : tempMap )
1091 unsigned n_refs = pair.second.GetCount();
1093 for(
unsigned thisRef = 0; thisRef < n_refs; ++thisRef )
1094 aRefList[pair.first].AddItem( pair.second[thisRef] );
1101 const wxString& aDestFileName )
1106 SCHEMATIC* sch = at( 0 ).LastScreen()->Schematic();
1108 wxCHECK_MSG( sch,
false,
"No SCHEMATIC found in SCH_SHEET_LIST::TestForRecursion!" );
1111 wxFileName destFn = aDestFileName;
1113 if( destFn.IsRelative() )
1114 destFn.MakeAbsolute( rootFn.GetPath() );
1117 for(
unsigned i = 0; i < size(); i++ )
1120 for(
unsigned j = 0; j < aSrcSheetHierarchy.size(); j++ )
1124 for(
unsigned k = 0; k < sheetPath->
size(); k++ )
1171 retval.push_back( sheetpath );
1179 const std::vector<SCH_SYMBOL_INSTANCE>& aSymbolInstances )
1187 wxCHECK2( symbol,
continue );
1190 sheetPathWithSymbolUuid.push_back( symbol->
m_Uuid );
1192 auto it = std::find_if( aSymbolInstances.begin(), aSymbolInstances.end(),
1195 return sheetPathWithSymbolUuid == r.m_Path;
1198 if( it == aSymbolInstances.end() )
1201 sheetPathWithSymbolUuid.
AsString() );
1210 if( !it->m_Value.IsEmpty() )
1213 if( !it->m_Footprint.IsEmpty() )
1229 wxCHECK2( sheet &&
path.Last(),
continue );
1231 auto it = std::find_if( aSheetInstances.begin(), aSheetInstances.end(),
1234 return path.Path() == r.m_Path;
1237 if( it == aSheetInstances.end() )
1240 path.Path().AsString() );
1245 ( sheet->
GetName().IsEmpty() ) ? wxString( wxT(
"root" ) ) : sheet->
GetName(),
1246 path.Path().AsString(), it->m_PageNumber );
1247 path.SetPageNumber( it->m_PageNumber );
1254 std::vector<KIID_PATH> paths;
1257 paths.emplace_back( sheetPath.
Path() );
1265 std::vector<SCH_SHEET_INSTANCE> retval;
1271 wxCHECK2( sheet,
continue );
1280 retval.push_back( instance );
1309 tmp.Printf(
"%d", pageNumber );
1317 const wxString& aProjectName )
1332 int aLastVirtualPageNumber )
1334 wxString pageNumber;
1335 int lastUsedPageNumber = 1;
1336 int nextVirtualPageNumber = aLastVirtualPageNumber;
1339 std::vector< wxString > usedPageNumbers;
1341 if( aPrefixSheetPath.
size() )
1347 pageNumber =
path.GetPageNumber();
1349 if( !pageNumber.IsEmpty() )
1350 usedPageNumbers.emplace_back( pageNumber );
1360 newSheetPath = newSheetPath + sheetPath;
1367 wxCHECK2( sheet,
continue );
1369 nextVirtualPageNumber += 1;
1386 pageNumber.Printf( wxT(
"%d" ), lastUsedPageNumber );
1387 lastUsedPageNumber += 1;
1388 }
while( std::find( usedPageNumbers.begin(), usedPageNumbers.end(), pageNumber ) !=
1389 usedPageNumbers.end() );
1410 int lastVirtualPageNumber = 1;
1418 return lastVirtualPageNumber;
1426 if(
path.Path() == aPath )
1438 for(
size_t i = 0; i <
path.size(); i++ )
1440 if(
path.at( i ) == aSheet )
bool IsContentModified() const
void SetContentModified(bool aModified=true)
A singleton item of this class is returned for a weak reference that no longer exists.
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 const wxString & GetText() const
Return the string associated with the text object.
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 override
Helper to retrieve the filename from the root sheet screen.
SCHEMATIC_SETTINGS & Settings() const
Instances are attached to a symbol or sheet and provide a place for the symbol's value,...
VECTOR2I GetPosition() const override
void SetText(const wxString &aText) override
const wxString & GetInternalName()
Get the initial name of the field set at creation (or set by SetName()).
Base class for any item which can be embedded within the SCHEMATIC container class,...
SCHEMATIC * Schematic() const
Searches the item hierarchy to find a SCHEMATIC.
virtual void RunOnChildren(const std::function< void(SCH_ITEM *)> &aFunction)
virtual void SetUnit(int aUnit)
void AutoplaceFields(SCH_SCREEN *aScreen, bool aManual) 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 Annotate(bool aUseSheetNum, int aSheetIntervalId, int aStartNumber, SCH_MULTI_UNIT_REFERENCE_MAP aLockedUnitMap, const SCH_REFERENCE_LIST &aAdditionalRefs, bool aStartAtCurrent=false)
Set the reference designators in the list that have not been annotated.
void SplitReferences()
Attempt to split all reference designators into a name (U) and number (1).
void AddItem(const SCH_REFERENCE &aItem)
void UpdateAnnotation()
Update the symbol references for the schematic project (or the current sheet).
A helper to define a symbol's reference designator in a schematic.
void SetSheetNumber(int aSheetNumber)
EE_RTREE & Items()
Gets the full RTree, usually for iterating.
const wxString & GetFileName() const
bool Remove(SCH_ITEM *aItem, bool aUpdateLibSymbol=true)
Remove aItem from the schematic associated with this screen.
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,...
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 * GetItem(const KIID &aID, SCH_SHEET_PATH *aPathOut=nullptr) const
Fetch a SCH_ITEM by ID.
void GetMultiUnitSymbols(SCH_MULTI_UNIT_REFERENCE_MAP &aRefList, bool aIncludePowerSymbols=true) const
Add a SCH_REFERENCE_LIST object to aRefList for each same-reference set of multi-unit parts in the li...
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
std::vector< SCH_SHEET_INSTANCE > GetSheetInstances() const
Fetch the instance information for all of the sheets in the hiearchy.
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.
bool AllSheetPageNumbersEmpty() const
Check all of the sheet instance for empty page numbers.
void GetSymbols(SCH_REFERENCE_LIST &aReferences, bool aIncludePowerSymbols=true, bool aForceIncludeOrphanSymbols=false) const
Add a SCH_REFERENCE object to aReferences for each symbol in the list of sheets.
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 AddNewSheetInstances(const SCH_SHEET_PATH &aPrefixSheetPath, int aLastVirtualPageNumber)
bool ContainsSheet(const SCH_SHEET *aSheet) const
std::vector< KIID_PATH > GetPaths() const
void GetSymbolsWithinPath(SCH_REFERENCE_LIST &aReferences, const SCH_SHEET_PATH &aSheetPath, bool aIncludePowerSymbols=true, bool aForceIncludeOrphanSymbols=false) const
Add a SCH_REFERENCE object to aReferences for each symbol in the list of sheets that are contained wi...
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...
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...
bool GetExcludedFromBOM() const
SCH_ITEM * GetItem(const KIID &aID) const
Fetch a SCH_ITEM by ID.
void AppendMultiUnitSymbol(SCH_MULTI_UNIT_REFERENCE_MAP &aRefList, SCH_SYMBOL *aSymbol, bool aIncludePowerSymbols=true) const
Append a SCH_REFERENCE_LIST object to aRefList based on aSymbol, storing same-reference set of multi-...
const SCH_SHEET * GetSheet(unsigned aIndex) const
bool empty() const
Forwarded method from std::vector.
void GetSymbols(SCH_REFERENCE_LIST &aReferences, bool aIncludePowerSymbols=true, bool aForceIncludeOrphanSymbols=false) const
Adds SCH_REFERENCE object to aReferences for each symbol in the sheet.
int ComparePageNum(const SCH_SHEET_PATH &aSheetPathToTest) const
Compare sheets by their page number.
size_t GetCurrentHash() const
wxString PathHumanReadable(bool aUseShortRootName=true, bool aStripTrailingSeparator=false) const
Return the sheet path in a human readable form made from the sheet names.
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.
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 GetMultiUnitSymbols(SCH_MULTI_UNIT_REFERENCE_MAP &aRefList, bool aIncludePowerSymbols=true) const
Add a SCH_REFERENCE_LIST object to aRefList for each same-reference set of multi-unit parts in the sh...
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.
void AppendSymbol(SCH_REFERENCE_LIST &aReferences, SCH_SYMBOL *aSymbol, bool aIncludePowerSymbols=true, bool aForceIncludeOrphanSymbols=false) const
Append a SCH_REFERENCE object to aReferences based on aSymbol.
std::map< std::pair< wxString, wxString >, bool > m_recursion_test_cache
Page numbers are maintained by the sheet load order.
bool GetExcludedFromSim() const
wxString PathAsString() const
Return the path of time stamps which do not changes even when editing sheet parameters.
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)
SCH_SHEET * Last() const
Return a pointer to the last SCH_SHEET of the list.
SCH_SHEET_PATH operator+(const SCH_SHEET_PATH &aOther)
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.
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.
std::vector< SCH_FIELD > & GetFields()
SCH_SCREEN * GetScreen() const
static int ComparePageNum(const wxString &aPageNumberA, const wxString &aPageNumberB)
Compares page numbers of schematic sheets.
void setPageNumber(const KIID_PATH &aInstance, const wxString &aPageNumber)
Set the page number for the sheet instance aInstance.
wxString getPageNumber(const KIID_PATH &aInstance) const
Return the sheet page number for aInstance.
void UpdatePrefix()
Set the prefix based on the current reference designator.
const std::vector< SCH_SYMBOL_INSTANCE > & GetInstances() const
void RemoveInstance(const SCH_SHEET_PATH &aInstancePath)
void SetValueFieldText(const wxString &aValue)
SCH_FIELD * GetField(MANDATORY_FIELD_T aFieldType)
Return a mandatory field in this symbol.
void SetFootprintFieldText(const wxString &aFootprint)
void AddHierarchicalReference(const KIID_PATH &aPath, const wxString &aRef, int aUnit)
Add a full hierarchical reference to this symbol.
bool GetInstance(SCH_SYMBOL_INSTANCE &aInstance, const KIID_PATH &aSheetPath, bool aTestFromEnd=false) const
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()
const wxString GetRef(const SCH_SHEET_PATH *aSheet, bool aIncludeUnit=false) const override
wxString GetPrefix() const
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.
wxString GetRefDesUnannotated(const wxString &aSource)
Return an unannotated refdes from either a prefix or an existing refdes.
Collection of utility functions for component reference designators (refdes)
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.
A simple container for sheet instance information.
A simple container for schematic symbol instance information.
Definition for symbol library class.
@ REFERENCE_FIELD
Field Reference of part, i.e. "IC21".
wxLogTrace helper definitions.
@ NOT_USED
the 3d code uses this value
VECTOR2< int32_t > VECTOR2I