Connectivity: don't consider neighbor propagation when types don't match
Fixes: lp:1831608 * https://bugs.launchpad.net/kicad/+bug/1831608
This commit is contained in:
parent
1142eb259b
commit
607650be22
|
@ -1091,9 +1091,12 @@ void CONNECTION_GRAPH::buildConnectionGraph()
|
||||||
|
|
||||||
if( sch_pin->IsPowerConnection() )
|
if( sch_pin->IsPowerConnection() )
|
||||||
{
|
{
|
||||||
auto c = std::make_shared<SCH_CONNECTION>( possible_driver,
|
auto pin = static_cast<SCH_PIN *>( possible_driver );
|
||||||
aSubgraph->m_sheet );
|
auto c = std::make_shared<SCH_CONNECTION>( pin, aSubgraph->m_sheet );
|
||||||
c->SetName( static_cast<SCH_PIN *>( possible_driver )->GetName() );
|
c->ConfigureFromLabel( pin->GetName() );
|
||||||
|
|
||||||
|
if( c->Type() != aSubgraph->m_driver_connection->Type() )
|
||||||
|
continue;
|
||||||
|
|
||||||
if( c->Name( true ) == aSubgraph->m_driver_connection->Name( true ) )
|
if( c->Name( true ) == aSubgraph->m_driver_connection->Name( true ) )
|
||||||
continue;
|
continue;
|
||||||
|
@ -1111,9 +1114,12 @@ void CONNECTION_GRAPH::buildConnectionGraph()
|
||||||
case SCH_HIER_LABEL_T:
|
case SCH_HIER_LABEL_T:
|
||||||
case SCH_LABEL_T:
|
case SCH_LABEL_T:
|
||||||
{
|
{
|
||||||
auto c = std::make_shared<SCH_CONNECTION>( possible_driver,
|
auto text = static_cast<SCH_TEXT*>( possible_driver );
|
||||||
aSubgraph->m_sheet );
|
auto c = std::make_shared<SCH_CONNECTION>( text, aSubgraph->m_sheet );
|
||||||
c->SetName( static_cast<SCH_TEXT*>( possible_driver )->GetShownText() );
|
c->ConfigureFromLabel( text->GetShownText() );
|
||||||
|
|
||||||
|
if( c->Type() != aSubgraph->m_driver_connection->Type() )
|
||||||
|
continue;
|
||||||
|
|
||||||
if( c->Name( true ) == aSubgraph->m_driver_connection->Name( true ) )
|
if( c->Name( true ) == aSubgraph->m_driver_connection->Name( true ) )
|
||||||
continue;
|
continue;
|
||||||
|
@ -1340,6 +1346,9 @@ void CONNECTION_GRAPH::buildConnectionGraph()
|
||||||
|
|
||||||
for( CONNECTION_SUBGRAPH* parent : it.second )
|
for( CONNECTION_SUBGRAPH* parent : it.second )
|
||||||
{
|
{
|
||||||
|
if( parent->m_absorbed )
|
||||||
|
parent = parent->m_absorbed_by;
|
||||||
|
|
||||||
SCH_CONNECTION* match = matchBusMember( parent->m_driver_connection, link_member );
|
SCH_CONNECTION* match = matchBusMember( parent->m_driver_connection, link_member );
|
||||||
|
|
||||||
if( !match )
|
if( !match )
|
||||||
|
|
|
@ -68,11 +68,11 @@ public:
|
||||||
PRIORITY_GLOBAL
|
PRIORITY_GLOBAL
|
||||||
};
|
};
|
||||||
|
|
||||||
|
explicit CONNECTION_SUBGRAPH( SCH_EDIT_FRAME* aFrame ) :
|
||||||
CONNECTION_SUBGRAPH( SCH_EDIT_FRAME* aFrame ) :
|
m_dirty( false ), m_absorbed( false ), m_absorbed_by( nullptr ), m_code( -1 ),
|
||||||
m_dirty( false ), m_absorbed( false ), m_code( -1 ), m_multiple_drivers( false ),
|
m_multiple_drivers( false ), m_strong_driver( false ), m_local_driver( false ),
|
||||||
m_strong_driver( false ), m_no_connect( nullptr ), m_bus_entry( nullptr ),
|
m_no_connect( nullptr ), m_bus_entry( nullptr ), m_driver( nullptr ), m_frame( aFrame ),
|
||||||
m_driver( nullptr ), m_frame( aFrame ), m_driver_connection( nullptr )
|
m_driver_connection( nullptr )
|
||||||
{}
|
{}
|
||||||
/**
|
/**
|
||||||
* Determines which potential driver should drive the subgraph.
|
* Determines which potential driver should drive the subgraph.
|
||||||
|
|
Loading…
Reference in New Issue