Allow sheet recursion, fix sheet paths in "Highlight on PCB".

"Highlight on PCB" and "Select" - "Items in Same Hierarchical Sheet"
actions were extended to select items on subsheets too.

"Highlight on PCB" now uses a proper full sheet path, allowing it to
work in subsheets.

Fixes https://gitlab.com/kicad/code/kicad/issues/11493
This commit is contained in:
Alex 2022-05-11 07:45:47 +03:00 committed by Seth Hillbrand
parent 8cd289cf69
commit 6b2bb4d808
3 changed files with 6 additions and 17 deletions

View File

@ -379,7 +379,8 @@ void SCH_EDIT_FRAME::ExecuteRemoteCommand( const char* cmdline )
} }
std::string FormatProbeItem( EDA_ITEM* aItem, SCH_SYMBOL* aSymbol ) std::string FormatProbeItem( const SCH_SHEET_PATH& aCurrentSheet, EDA_ITEM* aItem,
SCH_SYMBOL* aSymbol )
{ {
// This is a keyword followed by a quoted string. // This is a keyword followed by a quoted string.
@ -403,20 +404,8 @@ std::string FormatProbeItem( EDA_ITEM* aItem, SCH_SYMBOL* aSymbol )
{ {
// For cross probing, we need the full path of the sheet, because // For cross probing, we need the full path of the sheet, because
// in complex hierarchies the sheet uuid of not unique // in complex hierarchies the sheet uuid of not unique
SCH_SHEET* sheet = (SCH_SHEET*)aItem;
wxString full_path;
SCH_SHEET* parent = sheet; wxString full_path = aCurrentSheet.PathAsString() + aItem->m_Uuid.AsString();
while( (parent = dynamic_cast<SCH_SHEET*>( parent->GetParent() ) ) )
{
if( parent->GetParent() ) // The root sheet has no parent and path is just "/"
{
full_path.Prepend( parent->m_Uuid.AsString() );
full_path.Prepend( "/" );
}
}
full_path += "/" + sheet->m_Uuid.AsString();
return StrPrintf( "$SHEET: \"%s\"", TO_UTF8( full_path ) ); return StrPrintf( "$SHEET: \"%s\"", TO_UTF8( full_path ) );
} }
@ -454,7 +443,7 @@ void SCH_EDIT_FRAME::SendMessageToPCBNEW( EDA_ITEM* aObjectToSync, SCH_SYMBOL* a
if( !aObjectToSync ) if( !aObjectToSync )
return; return;
std::string packet = FormatProbeItem( aObjectToSync, aLibItem ); std::string packet = FormatProbeItem( GetCurrentSheet(), aObjectToSync, aLibItem );
if( !packet.empty() ) if( !packet.empty() )
{ {

View File

@ -1366,7 +1366,7 @@ void PCB_SELECTION_TOOL::selectAllItemsOnSheet( wxString& aSheetPath )
if( aSheetPath.IsEmpty() ) if( aSheetPath.IsEmpty() )
aSheetPath += '/'; aSheetPath += '/';
if( footprint_path == aSheetPath ) if( footprint_path.StartsWith( aSheetPath ) )
footprintList.push_back( footprint ); footprintList.push_back( footprint );
} }

View File

@ -315,7 +315,7 @@ private:
void selectAllItemsOnNet( int aNetCode, bool aSelect = true ); void selectAllItemsOnNet( int aNetCode, bool aSelect = true );
/** /**
* Select all items with the given sheet timestamp/UUID name (the sheet path). * Select all items on a sheet and its subsheets, given the full sheet path.
* *
* The path of the root sheet is "/". * The path of the root sheet is "/".
*/ */