PNS: Modify MarkObstacles logic to select shorter
When routing where we hit multiple obstacles, we choose the shortest path to allow overlapping hits to choose the shorter path, thus giving a better chance of returning true for the DRC-compliant path. Fixes #3773 | https://gitlab.com/kicad/code/kicad/issues/3773
This commit is contained in:
parent
40f97b55c7
commit
f7cb970a02
|
@ -2,7 +2,7 @@
|
|||
* KiRouter - a push-and-(sometimes-)shove PCB router
|
||||
*
|
||||
* Copyright (C) 2013-2017 CERN
|
||||
* Copyright (C) 2016 KiCad Developers, see AUTHORS.txt for contributors.
|
||||
* Copyright (C) 2016-2020 KiCad Developers, see AUTHORS.txt for contributors.
|
||||
* Author: Tomasz Wlostowski <tomasz.wlostowski@cern.ch>
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify it
|
||||
|
@ -452,7 +452,10 @@ bool LINE_PLACER::rhMarkObstacles( const VECTOR2I& aP, LINE& aNewHead )
|
|||
if( ( nearest - aP ).EuclideanNorm() < newHead.Width() + cl )
|
||||
{
|
||||
buildInitialLine( nearest, newHead );
|
||||
if ( newHead.CLine().Length() > bestHead.CLine().Length() )
|
||||
|
||||
// We want the shortest line here to ensure we don't break a clearance
|
||||
// rule on larger, overlapping items (e.g. vias)
|
||||
if( newHead.CLine().Length() < bestHead.CLine().Length() )
|
||||
{
|
||||
bestHead = newHead;
|
||||
hasBest = true;
|
||||
|
|
Loading…
Reference in New Issue