From 75e4fa9b75e6641b3488653430e73e691e198763 Mon Sep 17 00:00:00 2001 From: Seth Hillbrand Date: Fri, 20 Aug 2021 10:24:08 -0700 Subject: [PATCH] Handle multiple annotation in search New schematic format needs to search client screen paths instead of maintaining multiple copies in a flat format. --- eeschema/tools/sch_editor_control.cpp | 32 +++++++++++++++------------ 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/eeschema/tools/sch_editor_control.cpp b/eeschema/tools/sch_editor_control.cpp index cd042c65f4..a4374a1855 100644 --- a/eeschema/tools/sch_editor_control.cpp +++ b/eeschema/tools/sch_editor_control.cpp @@ -425,6 +425,8 @@ int SCH_EDITOR_CONTROL::FindNext( const TOOL_EVENT& aEvent ) SCH_SHEET_LIST schematic = m_frame->Schematic().GetSheets(); SCH_SCREENS screens( m_frame->Schematic().Root() ); + screens.BuildClientSheetPathList(); + for( SCH_SCREEN* screen = screens.GetFirst(); screen; screen = screens.GetNext() ) { if( afterScreen ) @@ -435,24 +437,26 @@ int SCH_EDITOR_CONTROL::FindNext( const TOOL_EVENT& aEvent ) continue; } - SCH_SHEET_PATH* sheet = schematic.FindSheetForScreen( screen ); + for( SCH_SHEET_PATH sheet : screen->GetClientSheetPaths() ) + { + item = nextMatch( screen, &sheet, nullptr, data ); - item = nextMatch( screen, sheet, nullptr, data ); + if( item ) + { + m_frame->Schematic().SetCurrentSheet( sheet ); + m_frame->GetCurrentSheet().UpdateAllScreenReferences(); + + screen->TestDanglingEnds(); + + m_frame->SetScreen( screen ); + UpdateFind( ACTIONS::updateFind.MakeEvent() ); + + break; + } + } if( item ) - { - wxCHECK_MSG( sheet, 0, "Sheet not found for " + screen->GetFileName() ); - - m_frame->Schematic().SetCurrentSheet( *sheet ); - m_frame->GetCurrentSheet().UpdateAllScreenReferences(); - - screen->TestDanglingEnds(); - - m_frame->SetScreen( screen ); - UpdateFind( ACTIONS::updateFind.MakeEvent() ); - break; - } } }