From aa4dcb2bf11302d6a31dcfe1ec1218da5364df75 Mon Sep 17 00:00:00 2001 From: Jeff Young Date: Tue, 21 Dec 2021 21:06:52 +0000 Subject: [PATCH] Make sure undo/redo of pagesetup is done to correct sheet. Fixes https://gitlab.com/kicad/code/kicad/issues/9999 --- eeschema/schematic_undo_redo.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/eeschema/schematic_undo_redo.cpp b/eeschema/schematic_undo_redo.cpp index 396955f69e..e445376381 100644 --- a/eeschema/schematic_undo_redo.cpp +++ b/eeschema/schematic_undo_redo.cpp @@ -266,10 +266,9 @@ void SCH_EDIT_FRAME::PutDataInPreviousState( PICKED_ITEMS_LIST* aList ) // same item can be changed and deleted in the same complex command). for( int ii = aList->GetCount() - 1; ii >= 0; ii-- ) { - UNDO_REDO status = aList->GetPickedItemStatus((unsigned) ii ); + UNDO_REDO status = aList->GetPickedItemStatus( (unsigned) ii ); EDA_ITEM* eda_item = aList->GetPickedItem( (unsigned) ii ); - SCH_SCREEN* screen = - dynamic_cast< SCH_SCREEN* >( aList->GetScreenForItem( (unsigned) ii ) ); + SCH_SCREEN* screen = dynamic_cast( aList->GetScreenForItem( (unsigned) ii ) ); wxCHECK( screen, /* void */ ); @@ -295,6 +294,9 @@ void SCH_EDIT_FRAME::PutDataInPreviousState( PICKED_ITEMS_LIST* aList ) } else if( status == UNDO_REDO::PAGESETTINGS ) { + SetCurrentSheet( *m_schematic->GetSheets().FindSheetForScreen( screen ) ); + DisplayCurrentSheet(); + // swap current settings with stored settings DS_PROXY_UNDO_ITEM alt_item( this ); DS_PROXY_UNDO_ITEM* item = static_cast( eda_item );