Prevent merging tracks across pads
When merging co-linear tracks, we should maintain the existing break if it exists on pads, vias and other connection points
This commit is contained in:
parent
8f670552a6
commit
3a29d94c0a
|
@ -540,6 +540,19 @@ bool TRACKS_CLEANER::mergeCollinearSegments( PCB_TRACK* aSeg1, PCB_TRACK* aSeg2
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Now find the removed end(s) and stop merging if it is a node:
|
||||||
|
if( aSeg1->GetStart() != dummy_seg.GetStart() && aSeg1->GetStart() != dummy_seg.GetEnd() )
|
||||||
|
{
|
||||||
|
if( testTrackEndpointIsNode( aSeg1, true ) )
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if( aSeg1->GetEnd() != dummy_seg.GetStart() && aSeg1->GetEnd() != dummy_seg.GetEnd() )
|
||||||
|
{
|
||||||
|
if( testTrackEndpointIsNode( aSeg1, false ) )
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
std::shared_ptr<CLEANUP_ITEM> item = std::make_shared<CLEANUP_ITEM>( CLEANUP_MERGE_TRACKS );
|
std::shared_ptr<CLEANUP_ITEM> item = std::make_shared<CLEANUP_ITEM>( CLEANUP_MERGE_TRACKS );
|
||||||
item->SetItems( aSeg1, aSeg2 );
|
item->SetItems( aSeg1, aSeg2 );
|
||||||
m_itemsList->push_back( item );
|
m_itemsList->push_back( item );
|
||||||
|
|
Loading…
Reference in New Issue