router: correctly assign owner via/pad to its hole when committing the world state
fixes #14852
This commit is contained in:
parent
b57d77dd0b
commit
ae8ea3b938
|
@ -476,8 +476,11 @@ const ITEM_SET NODE::HitTest( const VECTOR2I& aPoint ) const
|
||||||
|
|
||||||
void NODE::addSolid( SOLID* aSolid )
|
void NODE::addSolid( SOLID* aSolid )
|
||||||
{
|
{
|
||||||
if( aSolid->HasHole() && aSolid->Hole()->BelongsTo( aSolid ) )
|
if( aSolid->HasHole() )
|
||||||
|
{
|
||||||
|
assert( aSolid->Hole()->BelongsTo( aSolid ) );
|
||||||
addHole( aSolid->Hole() );
|
addHole( aSolid->Hole() );
|
||||||
|
}
|
||||||
|
|
||||||
if( aSolid->IsRoutable() )
|
if( aSolid->IsRoutable() )
|
||||||
linkJoint( aSolid->Pos(), aSolid->Layers(), aSolid->Net(), aSolid );
|
linkJoint( aSolid->Pos(), aSolid->Layers(), aSolid->Net(), aSolid );
|
||||||
|
@ -496,8 +499,14 @@ void NODE::Add( std::unique_ptr< SOLID >&& aSolid )
|
||||||
|
|
||||||
void NODE::addVia( VIA* aVia )
|
void NODE::addVia( VIA* aVia )
|
||||||
{
|
{
|
||||||
if( aVia->HasHole() && aVia->Hole()->BelongsTo( aVia ) )
|
if( aVia->HasHole() )
|
||||||
|
{
|
||||||
|
if( ! aVia->Hole()->BelongsTo( aVia ) )
|
||||||
|
{
|
||||||
|
assert( false );
|
||||||
|
}
|
||||||
addHole( aVia->Hole() );
|
addHole( aVia->Hole() );
|
||||||
|
}
|
||||||
|
|
||||||
linkJoint( aVia->Pos(), aVia->Layers(), aVia->Net(), aVia );
|
linkJoint( aVia->Pos(), aVia->Layers(), aVia->Net(), aVia );
|
||||||
aVia->SetOwner( this );
|
aVia->SetOwner( this );
|
||||||
|
@ -705,7 +714,7 @@ void NODE::doRemove( ITEM* aItem )
|
||||||
if( hole )
|
if( hole )
|
||||||
{
|
{
|
||||||
m_index->Remove( hole ); // hole is not directly owned by NODE but by the parent SOLID/VIA.
|
m_index->Remove( hole ); // hole is not directly owned by NODE but by the parent SOLID/VIA.
|
||||||
hole->SetOwner( hole->ParentPadVia() );
|
hole->SetOwner( aItem );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -815,6 +824,11 @@ void NODE::Remove( VIA* aVia )
|
||||||
{
|
{
|
||||||
removeViaIndex( aVia );
|
removeViaIndex( aVia );
|
||||||
doRemove( aVia );
|
doRemove( aVia );
|
||||||
|
|
||||||
|
if( !aVia->Owner() )
|
||||||
|
{
|
||||||
|
assert( aVia->Hole()->BelongsTo( aVia ) );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -845,7 +859,10 @@ void NODE::Remove( ITEM* aItem )
|
||||||
SOLID* solid = static_cast<SOLID*>( aItem );
|
SOLID* solid = static_cast<SOLID*>( aItem );
|
||||||
|
|
||||||
if( solid->HasHole() )
|
if( solid->HasHole() )
|
||||||
|
{
|
||||||
Remove( solid->Hole() );
|
Remove( solid->Hole() );
|
||||||
|
solid->Hole()->SetOwner( solid );
|
||||||
|
}
|
||||||
|
|
||||||
Remove( static_cast<SOLID*>( aItem ) );
|
Remove( static_cast<SOLID*>( aItem ) );
|
||||||
break;
|
break;
|
||||||
|
@ -870,7 +887,10 @@ void NODE::Remove( ITEM* aItem )
|
||||||
VIA* via = static_cast<VIA*>( aItem );
|
VIA* via = static_cast<VIA*>( aItem );
|
||||||
|
|
||||||
if( via->HasHole() )
|
if( via->HasHole() )
|
||||||
|
{
|
||||||
Remove( via->Hole() );
|
Remove( via->Hole() );
|
||||||
|
via->Hole()->SetOwner( via );
|
||||||
|
}
|
||||||
|
|
||||||
Remove( static_cast<VIA*>( aItem ) );
|
Remove( static_cast<VIA*>( aItem ) );
|
||||||
break;
|
break;
|
||||||
|
@ -1406,6 +1426,11 @@ void NODE::Commit( NODE* aNode )
|
||||||
|
|
||||||
for( ITEM* item : *aNode->m_index )
|
for( ITEM* item : *aNode->m_index )
|
||||||
{
|
{
|
||||||
|
if( item->HasHole() )
|
||||||
|
{
|
||||||
|
item->Hole()->SetOwner( item );
|
||||||
|
}
|
||||||
|
|
||||||
item->SetRank( -1 );
|
item->SetRank( -1 );
|
||||||
item->Unmark();
|
item->Unmark();
|
||||||
add( item );
|
add( item );
|
||||||
|
|
Loading…
Reference in New Issue