Ensure driver connections are always properly initialized
Fixes https://gitlab.com/kicad/code/kicad/-/issues/6694
This commit is contained in:
parent
bc484784fc
commit
6544dca056
|
@ -176,9 +176,16 @@ bool CONNECTION_SUBGRAPH::ResolveDrivers( bool aCreateMarkers )
|
|||
|
||||
// Cache driver connection
|
||||
if( m_driver )
|
||||
{
|
||||
m_driver_connection = m_driver->Connection( &m_sheet );
|
||||
m_driver_connection->ConfigureFromLabel( GetNameForDriver( m_driver ) );
|
||||
m_driver_connection->SetDriver( m_driver );
|
||||
m_driver_connection->ClearDirty();
|
||||
}
|
||||
else
|
||||
{
|
||||
m_driver_connection = nullptr;
|
||||
}
|
||||
|
||||
if( aCreateMarkers && m_multiple_drivers )
|
||||
{
|
||||
|
@ -849,24 +856,9 @@ void CONNECTION_GRAPH::buildConnectionGraph()
|
|||
}
|
||||
}
|
||||
|
||||
if( !subgraph->ResolveDrivers() )
|
||||
{
|
||||
subgraph->ResolveDrivers();
|
||||
subgraph->m_dirty = false;
|
||||
}
|
||||
else
|
||||
{
|
||||
// Now the subgraph has only one driver
|
||||
SCH_ITEM* driver = subgraph->m_driver;
|
||||
SCH_SHEET_PATH sheet = subgraph->m_sheet;
|
||||
SCH_CONNECTION* connection = driver->Connection( &sheet );
|
||||
|
||||
connection->ConfigureFromLabel( subgraph->GetNameForDriver( driver ) );
|
||||
connection->SetDriver( driver );
|
||||
connection->ClearDirty();
|
||||
|
||||
subgraph->m_dirty = false;
|
||||
}
|
||||
}
|
||||
|
||||
return 1;
|
||||
};
|
||||
|
|
|
@ -186,9 +186,9 @@ SCH_CONNECTION* SCH_ITEM::InitializeConnection( const SCH_SHEET_PATH& aSheet,
|
|||
{
|
||||
connection = new SCH_CONNECTION( this );
|
||||
m_connection_map.insert( std::make_pair( aSheet, connection ) );
|
||||
connection->SetGraph( aGraph );
|
||||
}
|
||||
|
||||
connection->SetGraph( aGraph );
|
||||
connection->SetSheet( aSheet );
|
||||
return connection;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue