Minor formatting cleanup.
This commit is contained in:
parent
7f8faffa3a
commit
288ab7ed6f
|
@ -20,6 +20,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <core/optional.h>
|
#include <core/optional.h>
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
#include "pns_arc.h"
|
#include "pns_arc.h"
|
||||||
#include "pns_debug_decorator.h"
|
#include "pns_debug_decorator.h"
|
||||||
|
@ -28,12 +29,8 @@
|
||||||
#include "pns_router.h"
|
#include "pns_router.h"
|
||||||
#include "pns_shove.h"
|
#include "pns_shove.h"
|
||||||
#include "pns_topology.h"
|
#include "pns_topology.h"
|
||||||
#include "pns_utils.h"
|
|
||||||
#include "pns_walkaround.h"
|
#include "pns_walkaround.h"
|
||||||
|
|
||||||
#include <board_item.h>
|
|
||||||
|
|
||||||
#include <memory>
|
|
||||||
|
|
||||||
namespace PNS {
|
namespace PNS {
|
||||||
|
|
||||||
|
@ -120,7 +117,6 @@ bool LINE_PLACER::handleSelfIntersections()
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
tail.Intersect( head, ips );
|
tail.Intersect( head, ips );
|
||||||
|
|
||||||
// no intesection points - nothing to reduce
|
// no intesection points - nothing to reduce
|
||||||
|
@ -182,7 +178,9 @@ bool LINE_PLACER::handlePullback()
|
||||||
int n = tail.PointCount();
|
int n = tail.PointCount();
|
||||||
|
|
||||||
if( n == 0 )
|
if( n == 0 )
|
||||||
|
{
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
else if( n == 1 )
|
else if( n == 1 )
|
||||||
{
|
{
|
||||||
m_p_start = tail.CPoint( 0 );
|
m_p_start = tail.CPoint( 0 );
|
||||||
|
@ -309,9 +307,9 @@ bool LINE_PLACER::mergeHead()
|
||||||
SHAPE_LINE_CHAIN& head = m_head.Line();
|
SHAPE_LINE_CHAIN& head = m_head.Line();
|
||||||
SHAPE_LINE_CHAIN& tail = m_tail.Line();
|
SHAPE_LINE_CHAIN& tail = m_tail.Line();
|
||||||
|
|
||||||
const int ForbiddenAngles = DIRECTION_45::ANG_ACUTE |
|
const int ForbiddenAngles = DIRECTION_45::ANG_ACUTE
|
||||||
DIRECTION_45::ANG_HALF_FULL |
|
| DIRECTION_45::ANG_HALF_FULL
|
||||||
DIRECTION_45::ANG_UNDEFINED;
|
| DIRECTION_45::ANG_UNDEFINED;
|
||||||
|
|
||||||
head.Simplify();
|
head.Simplify();
|
||||||
tail.Simplify();
|
tail.Simplify();
|
||||||
|
@ -491,12 +489,12 @@ bool LINE_PLACER::rhMarkObstacles( const VECTOR2I& aP, LINE& aNewHead )
|
||||||
// If we are allowing DRC violations, we don't push back to the hull
|
// If we are allowing DRC violations, we don't push back to the hull
|
||||||
if( !Settings().CanViolateDRC() )
|
if( !Settings().CanViolateDRC() )
|
||||||
{
|
{
|
||||||
for( auto& obs : obstacles )
|
for( OBSTACLE& obs : obstacles )
|
||||||
{
|
{
|
||||||
int cl = m_currentNode->GetClearance( obs.m_item, &newHead );
|
int cl = m_currentNode->GetClearance( obs.m_item, &newHead );
|
||||||
auto hull = obs.m_item->Hull( cl, newHead.Width(), newHead.Layer() );
|
const SHAPE_LINE_CHAIN hull = obs.m_item->Hull( cl, newHead.Width(), newHead.Layer() );
|
||||||
|
|
||||||
auto nearest = hull.NearestPoint( aP );
|
VECTOR2I nearest = hull.NearestPoint( aP );
|
||||||
Dbg()->AddLine( hull, 2, 10000 );
|
Dbg()->AddLine( hull, 2, 10000 );
|
||||||
|
|
||||||
if( ( nearest - aP ).EuclideanNorm() < newHead.Width() + cl )
|
if( ( nearest - aP ).EuclideanNorm() < newHead.Width() + cl )
|
||||||
|
@ -581,16 +579,14 @@ bool LINE_PLACER::rhStopAtNearestObstacle( const VECTOR2I& aP, LINE& aNewHead )
|
||||||
|
|
||||||
LINE l_cur = reduceToNearestObstacle( l0 );
|
LINE l_cur = reduceToNearestObstacle( l0 );
|
||||||
|
|
||||||
const auto l_shape = l_cur.CLine();
|
const SHAPE_LINE_CHAIN l_shape = l_cur.CLine();
|
||||||
|
|
||||||
if( l_shape.SegmentCount() == 0 )
|
if( l_shape.SegmentCount() == 0 )
|
||||||
{
|
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
|
|
||||||
if( l_shape.SegmentCount() == 1 )
|
if( l_shape.SegmentCount() == 1 )
|
||||||
{
|
{
|
||||||
auto s = l_shape.CSegment( 0 );
|
SEG s = l_shape.CSegment( 0 );
|
||||||
|
|
||||||
VECTOR2I dL( DIRECTION_45( s ).Left().ToVector() );
|
VECTOR2I dL( DIRECTION_45( s ).Left().ToVector() );
|
||||||
VECTOR2I dR( DIRECTION_45( s ).Right().ToVector() );
|
VECTOR2I dR( DIRECTION_45( s ).Right().ToVector() );
|
||||||
|
@ -691,17 +687,15 @@ bool LINE_PLACER::rhShoveOnly( const VECTOR2I& aP, LINE& aNewHead )
|
||||||
if( status == SHOVE::SH_OK || status == SHOVE::SH_HEAD_MODIFIED )
|
if( status == SHOVE::SH_OK || status == SHOVE::SH_HEAD_MODIFIED )
|
||||||
{
|
{
|
||||||
if( status == SHOVE::SH_HEAD_MODIFIED )
|
if( status == SHOVE::SH_HEAD_MODIFIED )
|
||||||
{
|
|
||||||
l2 = m_shove->NewHead();
|
l2 = m_shove->NewHead();
|
||||||
}
|
|
||||||
|
|
||||||
optimizer.SetWorld( m_currentNode );
|
optimizer.SetWorld( m_currentNode );
|
||||||
|
|
||||||
int effortLevel = OPTIMIZER::MERGE_OBTUSE;
|
int effortLevel = OPTIMIZER::MERGE_OBTUSE;
|
||||||
|
|
||||||
if( Settings().SmartPads() )
|
if( Settings().SmartPads() )
|
||||||
{
|
|
||||||
effortLevel = OPTIMIZER::SMART_PADS;
|
effortLevel = OPTIMIZER::SMART_PADS;
|
||||||
}
|
|
||||||
optimizer.SetEffortLevel( effortLevel );
|
optimizer.SetEffortLevel( effortLevel );
|
||||||
|
|
||||||
optimizer.SetCollisionMask( ITEM::ANY_T );
|
optimizer.SetCollisionMask( ITEM::ANY_T );
|
||||||
|
@ -818,7 +812,9 @@ void LINE_PLACER::routeStep( const VECTOR2I& aP )
|
||||||
LINE new_head;
|
LINE new_head;
|
||||||
|
|
||||||
wxLogTrace( "PNS", "INIT-DIR: %s head: %d, tail: %d segs",
|
wxLogTrace( "PNS", "INIT-DIR: %s head: %d, tail: %d segs",
|
||||||
m_initial_direction.Format().c_str(), m_head.SegmentCount(), m_tail.SegmentCount() );
|
m_initial_direction.Format().c_str(),
|
||||||
|
m_head.SegmentCount(),
|
||||||
|
m_tail.SegmentCount() );
|
||||||
|
|
||||||
for( i = 0; i < n_iter; i++ )
|
for( i = 0; i < n_iter; i++ )
|
||||||
{
|
{
|
||||||
|
@ -921,10 +917,7 @@ bool LINE_PLACER::SplitAdjacentSegments( NODE* aNode, ITEM* aSeg, const VECTOR2I
|
||||||
|
|
||||||
SEGMENT* s_old = static_cast<SEGMENT*>( aSeg );
|
SEGMENT* s_old = static_cast<SEGMENT*>( aSeg );
|
||||||
|
|
||||||
std::unique_ptr< SEGMENT > s_new[2] = {
|
std::unique_ptr<SEGMENT> s_new[2] = { Clone( *s_old ), Clone( *s_old ) };
|
||||||
Clone( *s_old ),
|
|
||||||
Clone( *s_old )
|
|
||||||
};
|
|
||||||
|
|
||||||
s_new[0]->SetEnds( s_old->Seg().A, aP );
|
s_new[0]->SetEnds( s_old->Seg().A, aP );
|
||||||
s_new[1]->SetEnds( aP, s_old->Seg().B );
|
s_new[1]->SetEnds( aP, s_old->Seg().B );
|
||||||
|
@ -948,7 +941,8 @@ bool LINE_PLACER::SetLayer( int aLayer )
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
else if( !m_startItem || ( m_startItem->OfKind( ITEM::VIA_T ) && m_startItem->Layers().Overlaps( aLayer ) ) )
|
else if( !m_startItem
|
||||||
|
|| ( m_startItem->OfKind( ITEM::VIA_T ) && m_startItem->Layers().Overlaps( aLayer ) ) )
|
||||||
{
|
{
|
||||||
m_currentLayer = aLayer;
|
m_currentLayer = aLayer;
|
||||||
m_head.Line().Clear();
|
m_head.Line().Clear();
|
||||||
|
@ -1024,7 +1018,9 @@ void LINE_PLACER::initPlacement()
|
||||||
setWorld( rootNode );
|
setWorld( rootNode );
|
||||||
|
|
||||||
wxLogTrace( "PNS", "world %p, intitial-direction %s layer %d",
|
wxLogTrace( "PNS", "world %p, intitial-direction %s layer %d",
|
||||||
m_world, m_direction.Format().c_str(), m_currentLayer );
|
m_world,
|
||||||
|
m_direction.Format().c_str(),
|
||||||
|
m_currentLayer );
|
||||||
|
|
||||||
m_lastNode = NULL;
|
m_lastNode = NULL;
|
||||||
m_currentNode = m_world;
|
m_currentNode = m_world;
|
||||||
|
@ -1033,9 +1029,7 @@ void LINE_PLACER::initPlacement()
|
||||||
m_shove.reset();
|
m_shove.reset();
|
||||||
|
|
||||||
if( m_currentMode == RM_Shove || m_currentMode == RM_Smart )
|
if( m_currentMode == RM_Shove || m_currentMode == RM_Smart )
|
||||||
{
|
|
||||||
m_shove = std::make_unique<SHOVE>( m_world->Branch(), Router() );
|
m_shove = std::make_unique<SHOVE>( m_world->Branch(), Router() );
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1066,7 +1060,10 @@ bool LINE_PLACER::Move( const VECTOR2I& aP, ITEM* aEndItem )
|
||||||
NODE* latestNode = m_currentNode;
|
NODE* latestNode = m_currentNode;
|
||||||
m_lastNode = latestNode->Branch();
|
m_lastNode = latestNode->Branch();
|
||||||
|
|
||||||
if( reachesEnd && eiDepth >= 0 && aEndItem && latestNode->Depth() > eiDepth && current.SegmentCount() )
|
if( reachesEnd
|
||||||
|
&& eiDepth >= 0
|
||||||
|
&& aEndItem && latestNode->Depth() > eiDepth
|
||||||
|
&& current.SegmentCount() )
|
||||||
{
|
{
|
||||||
SplitAdjacentSegments( m_lastNode, aEndItem, current.CPoint( -1 ) );
|
SplitAdjacentSegments( m_lastNode, aEndItem, current.CPoint( -1 ) );
|
||||||
|
|
||||||
|
@ -1102,8 +1099,10 @@ bool LINE_PLACER::FixRoute( const VECTOR2I& aP, ITEM* aEndItem, bool aForceFinis
|
||||||
pl.SetNet( m_currentNet );
|
pl.SetNet( m_currentNet );
|
||||||
}
|
}
|
||||||
else if (aEndItem->Net() <= 0 )
|
else if (aEndItem->Net() <= 0 )
|
||||||
|
{
|
||||||
aEndItem->SetNet( m_currentNet );
|
aEndItem->SetNet( m_currentNet );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Collisions still prevent fixing unless "Allow DRC violations" is checked
|
// Collisions still prevent fixing unless "Allow DRC violations" is checked
|
||||||
if( !Settings().CanViolateDRC() && m_world->CheckColliding( &pl ) )
|
if( !Settings().CanViolateDRC() && m_world->CheckColliding( &pl ) )
|
||||||
|
@ -1157,6 +1156,7 @@ bool LINE_PLACER::FixRoute( const VECTOR2I& aP, ITEM* aEndItem, bool aForceFinis
|
||||||
auto seg = std::make_unique<SEGMENT>( s, m_currentNet );
|
auto seg = std::make_unique<SEGMENT>( s, m_currentNet );
|
||||||
seg->SetWidth( pl.Width() );
|
seg->SetWidth( pl.Width() );
|
||||||
seg->SetLayer( m_currentLayer );
|
seg->SetLayer( m_currentLayer );
|
||||||
|
|
||||||
if( !m_lastNode->Add( std::move( seg ) ) )
|
if( !m_lastNode->Add( std::move( seg ) ) )
|
||||||
lastSeg = nullptr;
|
lastSeg = nullptr;
|
||||||
}
|
}
|
||||||
|
@ -1175,14 +1175,11 @@ bool LINE_PLACER::FixRoute( const VECTOR2I& aP, ITEM* aEndItem, bool aForceFinis
|
||||||
}
|
}
|
||||||
|
|
||||||
if( pl.EndsWithVia() )
|
if( pl.EndsWithVia() )
|
||||||
{
|
|
||||||
m_lastNode->Add( Clone( pl.Via() ) );
|
m_lastNode->Add( Clone( pl.Via() ) );
|
||||||
}
|
|
||||||
|
|
||||||
if( realEnd && lastSeg )
|
if( realEnd && lastSeg )
|
||||||
simplifyNewLine( m_lastNode, lastSeg );
|
simplifyNewLine( m_lastNode, lastSeg );
|
||||||
|
|
||||||
|
|
||||||
if( !realEnd )
|
if( !realEnd )
|
||||||
{
|
{
|
||||||
setInitialDirection( d_last );
|
setInitialDirection( d_last );
|
||||||
|
@ -1205,10 +1202,7 @@ bool LINE_PLACER::FixRoute( const VECTOR2I& aP, ITEM* aEndItem, bool aForceFinis
|
||||||
m_lastNode = m_lastNode->Branch();
|
m_lastNode = m_lastNode->Branch();
|
||||||
|
|
||||||
if ( m_shove )
|
if ( m_shove )
|
||||||
{
|
|
||||||
m_shove->AddLockedSpringbackNode( m_currentNode );
|
m_shove->AddLockedSpringbackNode( m_currentNode );
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
m_postureSolver.Clear();
|
m_postureSolver.Clear();
|
||||||
m_postureSolver.SetTolerance( m_head.Width() );
|
m_postureSolver.SetTolerance( m_head.Width() );
|
||||||
|
@ -1291,7 +1285,7 @@ void LINE_PLACER::removeLoops( NODE* aNode, LINE& aLatest )
|
||||||
|
|
||||||
for( int s = 0; s < aLatest.LinkCount(); s++ )
|
for( int s = 0; s < aLatest.LinkCount(); s++ )
|
||||||
{
|
{
|
||||||
auto seg = aLatest.GetLink(s);
|
LINKED_ITEM* seg = aLatest.GetLink(s);
|
||||||
LINE ourLine = aNode->AssembleLine( seg );
|
LINE ourLine = aNode->AssembleLine( seg );
|
||||||
JOINT a, b;
|
JOINT a, b;
|
||||||
std::vector<LINE> lines;
|
std::vector<LINE> lines;
|
||||||
|
@ -1299,9 +1293,7 @@ void LINE_PLACER::removeLoops( NODE* aNode, LINE& aLatest )
|
||||||
aNode->FindLineEnds( ourLine, a, b );
|
aNode->FindLineEnds( ourLine, a, b );
|
||||||
|
|
||||||
if( a == b )
|
if( a == b )
|
||||||
{
|
|
||||||
aNode->FindLineEnds( aLatest, a, b );
|
aNode->FindLineEnds( aLatest, a, b );
|
||||||
}
|
|
||||||
|
|
||||||
aNode->FindLinesBetweenJoints( a, b, lines );
|
aNode->FindLinesBetweenJoints( a, b, lines );
|
||||||
|
|
||||||
|
@ -1324,7 +1316,7 @@ void LINE_PLACER::removeLoops( NODE* aNode, LINE& aLatest )
|
||||||
wxLogTrace( "PNS", "total segs removed: %d/%d", removedCount, total );
|
wxLogTrace( "PNS", "total segs removed: %d/%d", removedCount, total );
|
||||||
}
|
}
|
||||||
|
|
||||||
for( auto s : toErase )
|
for( LINKED_ITEM* s : toErase )
|
||||||
aNode->Remove( s );
|
aNode->Remove( s );
|
||||||
|
|
||||||
aNode->Remove( aLatest );
|
aNode->Remove( aLatest );
|
||||||
|
@ -1382,7 +1374,7 @@ bool LINE_PLACER::buildInitialLine( const VECTOR2I& aP, LINE& aHead )
|
||||||
SHAPE_LINE_CHAIN l;
|
SHAPE_LINE_CHAIN l;
|
||||||
int initial_radius = 0;
|
int initial_radius = 0;
|
||||||
|
|
||||||
auto guessedDir = m_postureSolver.GetPosture( aP );
|
DIRECTION_45 guessedDir = m_postureSolver.GetPosture( aP );
|
||||||
|
|
||||||
if( m_p_start == aP )
|
if( m_p_start == aP )
|
||||||
{
|
{
|
||||||
|
@ -1461,7 +1453,7 @@ bool LINE_PLACER::AbortPlacement()
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
FIXED_TAIL::FIXED_TAIL ( int aLineCount )
|
FIXED_TAIL::FIXED_TAIL( int aLineCount )
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1476,7 +1468,8 @@ void FIXED_TAIL::Clear()
|
||||||
m_stages.clear();
|
m_stages.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void FIXED_TAIL::AddStage( VECTOR2I aStart, int aLayer, bool placingVias, DIRECTION_45 direction, NODE *aNode )
|
void FIXED_TAIL::AddStage( VECTOR2I aStart, int aLayer, bool placingVias, DIRECTION_45 direction,
|
||||||
|
NODE *aNode )
|
||||||
{
|
{
|
||||||
STAGE st;
|
STAGE st;
|
||||||
FIX_POINT pt;
|
FIX_POINT pt;
|
||||||
|
@ -1497,7 +1490,6 @@ bool FIXED_TAIL::PopStage( FIXED_TAIL::STAGE& aStage )
|
||||||
if( !m_stages.size() )
|
if( !m_stages.size() )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
|
||||||
aStage = m_stages.back();
|
aStage = m_stages.back();
|
||||||
|
|
||||||
if( m_stages.size() > 1 )
|
if( m_stages.size() > 1 )
|
||||||
|
|
|
@ -743,7 +743,7 @@ int ROUTER_TOOL::onViaCommand( const TOOL_EVENT& aEvent )
|
||||||
{
|
{
|
||||||
WX_INFOBAR* infobar = frame()->GetInfoBar();
|
WX_INFOBAR* infobar = frame()->GetInfoBar();
|
||||||
wxHyperlinkCtrl* button = new wxHyperlinkCtrl( infobar, wxID_ANY,
|
wxHyperlinkCtrl* button = new wxHyperlinkCtrl( infobar, wxID_ANY,
|
||||||
_("Show board setup"), wxEmptyString );
|
_( "Show board setup" ), wxEmptyString );
|
||||||
|
|
||||||
button->Bind( wxEVT_COMMAND_HYPERLINK, std::function<void( wxHyperlinkEvent& aEvent )>(
|
button->Bind( wxEVT_COMMAND_HYPERLINK, std::function<void( wxHyperlinkEvent& aEvent )>(
|
||||||
[&]( wxHyperlinkEvent& aEvent )
|
[&]( wxHyperlinkEvent& aEvent )
|
||||||
|
@ -764,7 +764,7 @@ int ROUTER_TOOL::onViaCommand( const TOOL_EVENT& aEvent )
|
||||||
{
|
{
|
||||||
WX_INFOBAR* infobar = frame()->GetInfoBar();
|
WX_INFOBAR* infobar = frame()->GetInfoBar();
|
||||||
wxHyperlinkCtrl* button = new wxHyperlinkCtrl( infobar, wxID_ANY,
|
wxHyperlinkCtrl* button = new wxHyperlinkCtrl( infobar, wxID_ANY,
|
||||||
_("Show board setup"), wxEmptyString );
|
_( "Show board setup" ), wxEmptyString );
|
||||||
|
|
||||||
button->Bind( wxEVT_COMMAND_HYPERLINK, std::function<void( wxHyperlinkEvent& aEvent )>(
|
button->Bind( wxEVT_COMMAND_HYPERLINK, std::function<void( wxHyperlinkEvent& aEvent )>(
|
||||||
[&]( wxHyperlinkEvent& aEvent )
|
[&]( wxHyperlinkEvent& aEvent )
|
||||||
|
@ -818,8 +818,8 @@ int ROUTER_TOOL::onViaCommand( const TOOL_EVENT& aEvent )
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case VIATYPE::MICROVIA:
|
case VIATYPE::MICROVIA:
|
||||||
wxASSERT_MSG( !selectLayer,
|
wxASSERT_MSG( !selectLayer, "Unexpected select layer for microvia (microvia layers are "
|
||||||
"Unexpected select layer for microvia (microvia layers are implicit)" );
|
"implicit)" );
|
||||||
|
|
||||||
if( currentLayer == F_Cu || currentLayer == In1_Cu )
|
if( currentLayer == F_Cu || currentLayer == In1_Cu )
|
||||||
{
|
{
|
||||||
|
@ -835,8 +835,8 @@ int ROUTER_TOOL::onViaCommand( const TOOL_EVENT& aEvent )
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
wxASSERT_MSG( false,
|
wxASSERT_MSG( false, "Invalid layer pair for microvia (must be on or adjacent to an "
|
||||||
"Invalid layer pair for microvia (must be on or adjacent to an outer layer)" );
|
"outer layer)" );
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue