Commit f2ebfdf3 authored by jean-pierre charras's avatar jean-pierre charras

Pcbnew: rework on connection calculation: fix an issue for "composite" pads...

Pcbnew: rework on connection calculation: fix an issue for "composite"  pads (complex pad build by association of  some basic pads):
sometimes connections where not seen.
parent da757938
...@@ -346,7 +346,7 @@ int CONNECTIONS::SearchConnectedTracks( const TRACK * aTrack ) ...@@ -346,7 +346,7 @@ int CONNECTIONS::SearchConnectedTracks( const TRACK * aTrack )
continue; continue;
// We have a good candidate: calculate the actual distance // We have a good candidate: calculate the actual distance
// beteween ends, which should be <= dist max. // between ends, which should be <= dist max.
wxPoint delta = tracks_candidates[ii]->GetPoint() - position; wxPoint delta = tracks_candidates[ii]->GetPoint() - position;
int dist = (int) hypot( (double) delta.x, (double) delta.y ); int dist = (int) hypot( (double) delta.x, (double) delta.y );
...@@ -495,7 +495,7 @@ int CONNECTIONS::Merge_PadsSubNets( int aOldSubNet, int aNewSubNet ) ...@@ -495,7 +495,7 @@ int CONNECTIONS::Merge_PadsSubNets( int aOldSubNet, int aNewSubNet )
/* /*
* Change a subnet value to a new value, for tracks and pads which are connected to. * Change a subnet value to a new value, for tracks and pads which are connected to.
* The result is merging 2 clusters (or subnets) into only one cluster. * The result is merging 2 clusters (or subnets) into only one cluster.
* Note: the resultig sub net value is the smallest between aOldSubNet et aNewSubNet * Note: the resulting sub net value is the smallest between aOldSubNet et aNewSubNet
*/ */
int CONNECTIONS::Merge_SubNets( int aOldSubNet, int aNewSubNet ) int CONNECTIONS::Merge_SubNets( int aOldSubNet, int aNewSubNet )
{ {
...@@ -527,7 +527,9 @@ int CONNECTIONS::Merge_SubNets( int aOldSubNet, int aNewSubNet ) ...@@ -527,7 +527,9 @@ int CONNECTIONS::Merge_SubNets( int aOldSubNet, int aNewSubNet )
{ {
D_PAD * pad = curr_track->m_PadsConnected[ii]; D_PAD * pad = curr_track->m_PadsConnected[ii];
if( pad->GetSubNet() == aOldSubNet ) if( pad->GetSubNet() == aOldSubNet )
{
pad->SetSubNet( curr_track->GetSubNet() ); pad->SetSubNet( curr_track->GetSubNet() );
}
} }
if( curr_track == m_lastTrack ) if( curr_track == m_lastTrack )
...@@ -544,57 +546,16 @@ int CONNECTIONS::Merge_SubNets( int aOldSubNet, int aNewSubNet ) ...@@ -544,57 +546,16 @@ int CONNECTIONS::Merge_SubNets( int aOldSubNet, int aNewSubNet )
* from m_firstTrack to m_lastTrack have the same net * from m_firstTrack to m_lastTrack have the same net
* When 2 items are connected (a track to a pad, or a track to an other track), * When 2 items are connected (a track to a pad, or a track to an other track),
* they are grouped in a cluster. * they are grouped in a cluster.
* For pads, this is the .m_physical_connexion member which is a cluster identifier * The .m_Subnet member is the cluster identifier (subnet id)
* For tracks, this is the .m_Subnet member which is a cluster identifier
* For a given net, if all tracks are created, there is only one cluster. * For a given net, if all tracks are created, there is only one cluster.
* but if not all tracks are created, there are more than one cluster, * but if not all tracks are created, there are more than one cluster,
* and some ratsnests will be left active. * and some ratsnests will be left active.
* A ratsnest is active when it "connect" 2 items having different subnet id
*/ */
void CONNECTIONS::Propagate_SubNets() void CONNECTIONS::Propagate_SubNets()
{ {
int sub_netcode = 0; int sub_netcode = 1;
// Examine connections between intersecting pads
for( unsigned ii = 0; ii < m_sortedPads.size(); ii++ )
{
D_PAD * curr_pad = m_sortedPads[ii];
for( unsigned jj = 0; jj < curr_pad->m_PadsConnected.size(); jj++ )
{
D_PAD * pad = curr_pad->m_PadsConnected[jj];
if( curr_pad->GetSubNet() )
{
if( pad->GetSubNet() > 0 )
{
// The pad is already a cluster member, so we can merge the 2 clusters
Merge_PadsSubNets( pad->GetSubNet(), curr_pad->GetSubNet() );
}
else
{
// The pad is not yet attached to a cluster,
// so we can add this pad to the cluster
pad->SetSubNet( curr_pad->GetSubNet() );
}
}
else // the current pad is not attached to a cluster
{
if( pad->GetSubNet() > 0 )
{
// it is connected to a pad in a cluster, merge this pad
curr_pad->SetSubNet( pad->GetSubNet() );
}
else
{
// it is connected to a pad not in a cluster,
// so we must create a new cluster (only with the 2 pads.
sub_netcode++;
curr_pad->SetSubNet( sub_netcode );
pad->SetSubNet( curr_pad->GetSubNet() );
}
}
}
}
sub_netcode++;
TRACK* curr_track = (TRACK*)m_firstTrack; TRACK* curr_track = (TRACK*)m_firstTrack;
if( curr_track ) if( curr_track )
curr_track->SetSubNet( sub_netcode ); curr_track->SetSubNet( sub_netcode );
...@@ -679,6 +640,54 @@ void CONNECTIONS::Propagate_SubNets() ...@@ -679,6 +640,54 @@ void CONNECTIONS::Propagate_SubNets()
if( curr_track == m_lastTrack ) if( curr_track == m_lastTrack )
break; break;
} }
// Examine connections between intersecting pads, and propagate
// sub_netcodes to intersecting pads
for( unsigned ii = 0; ii < m_sortedPads.size(); ii++ )
{
D_PAD * curr_pad = m_sortedPads[ii];
for( unsigned jj = 0; jj < curr_pad->m_PadsConnected.size(); jj++ )
{
D_PAD * pad = curr_pad->m_PadsConnected[jj];
if( curr_pad->GetSubNet() ) // the current pad is already attached to a cluster
{
if( pad->GetSubNet() > 0 )
{
// The pad is already a cluster member, so we can merge the 2 clusters
// Store the initial subnets, which will be modified by Merge_PadsSubNets
int subnet1 = pad->GetSubNet();
int subnet2 = curr_pad->GetSubNet();
// merge subnets of pads only, even those not connected by tracks
Merge_PadsSubNets( subnet1, subnet2 );
// merge subnets of tracks (and pads, which are already merged)
Merge_SubNets( subnet1, subnet2 );
}
else
{
// The pad is not yet attached to a cluster,
// so we can add this pad to the cluster
pad->SetSubNet( curr_pad->GetSubNet() );
}
}
else // the current pad is not attached to a cluster
{
if( pad->GetSubNet() > 0 )
{
// the connected pad is in a cluster,
// so we can add the current pad to the cluster
curr_pad->SetSubNet( pad->GetSubNet() );
}
else
{
// the connected pad is not in a cluster,
// so we must create a new cluster, with the 2 pads.
sub_netcode++;
curr_pad->SetSubNet( sub_netcode );
pad->SetSubNet( curr_pad->GetSubNet() );
}
}
}
}
} }
/* /*
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment