Prevent crash with RTree modification invalidating iterator.
This commit is contained in:
parent
a5c4bace60
commit
0400c0a775
|
@ -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 );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue