Prevent crash with RTree modification invalidating iterator.

This commit is contained in:
Jeff Young 2021-09-19 11:34:09 +01:00
parent a5c4bace60
commit 0400c0a775
1 changed files with 12 additions and 8 deletions

View File

@ -1366,18 +1366,22 @@ void SCH_EDIT_FRAME::RecomputeIntersheetRefs()
bool show = Schematic().Settings().m_IntersheetRefsShow; bool show = Schematic().Settings().m_IntersheetRefsShow;
/* Refresh all global labels */ // Refresh all global labels. Note that we have to collect them first as the
for( EDA_ITEM* item : GetScreen()->Items().OfType( SCH_GLOBAL_LABEL_T ) ) // SCH_SCREEN::Update() call is going to invalidate the RTree iterator.
{
SCH_GLOBALLABEL* gLabel = (SCH_GLOBALLABEL*)( item );
SCH_FIELD* intersheetRef = gLabel->GetIntersheetRefs();
intersheetRef->SetVisible( show ); std::vector<SCH_GLOBALLABEL*> globalLabels;
for( EDA_ITEM* item : GetScreen()->Items().OfType( SCH_GLOBAL_LABEL_T ) )
globalLabels.push_back( static_cast<SCH_GLOBALLABEL*>( item ) );
for( SCH_GLOBALLABEL* globalLabel : globalLabels )
{
globalLabel->GetIntersheetRefs()->SetVisible( show );
if( show ) if( show )
{ {
GetScreen()->Update( gLabel ); GetScreen()->Update( globalLabel );
GetCanvas()->GetView()->Update( gLabel ); GetCanvas()->GetView()->Update( globalLabel );
} }
} }
} }