drc_proto: import latest Jeff & Jon's changes + update copyright headers
This commit is contained in:
parent
49c37014f7
commit
0a4c8cd45c
|
@ -1,8 +1,7 @@
|
||||||
/*
|
/*
|
||||||
* This program source code file is part of KiCad, a free EDA CAD application.
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
||||||
*
|
*
|
||||||
* Copyright (C) 2007-2016 Dick Hollenbeck, dick@softplc.com
|
* Copyright (C) 2019-2020 KiCad Developers, see AUTHORS.txt for contributors.
|
||||||
* Copyright (C) 2017-2019 KiCad Developers, see change_log.txt for contributors.
|
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License
|
* modify it under the terms of the GNU General Public License
|
||||||
|
|
|
@ -57,7 +57,7 @@ public:
|
||||||
* Function GetErrorText
|
* Function GetErrorText
|
||||||
* returns the string form of a drc error code.
|
* returns the string form of a drc error code.
|
||||||
*/
|
*/
|
||||||
::wxString GetErrorText( int aErrorCode = -1, bool aTranslate = true ) const override { return ""; } // fixme
|
::wxString GetErrorText( int aErrorCode = -1, bool aTranslate = true ) const { return ""; } // fixme
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Function ShowHtml
|
* Function ShowHtml
|
||||||
|
|
|
@ -1,3 +1,26 @@
|
||||||
|
/*
|
||||||
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2019-2020 KiCad Developers, see AUTHORS.txt for contributors.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, you may find one here:
|
||||||
|
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
||||||
|
* or you may search the http://www.gnu.org website for the version 2 license,
|
||||||
|
* or you may write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
|
*/
|
||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/*
|
/*
|
||||||
* This program source code file is part of KiCad, a free EDA CAD application.
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
||||||
*
|
*
|
||||||
* Copyright (C) 2018 KiCad Developers, see change_log.txt for contributors.
|
* Copyright (C) 2019-2020 KiCad Developers, see AUTHORS.txt for contributors.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License
|
* modify it under the terms of the GNU General Public License
|
||||||
|
@ -21,7 +21,6 @@
|
||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifndef DRC_PROVIDER__H
|
#ifndef DRC_PROVIDER__H
|
||||||
#define DRC_PROVIDER__H
|
#define DRC_PROVIDER__H
|
||||||
|
|
||||||
|
|
|
@ -1,3 +1,27 @@
|
||||||
|
/*
|
||||||
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2019-2020 KiCad Developers, see AUTHORS.txt for contributors.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, you may find one here:
|
||||||
|
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
||||||
|
* or you may search the http://www.gnu.org website for the version 2 license,
|
||||||
|
* or you may write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include <common.h>
|
#include <common.h>
|
||||||
#include <class_board.h>
|
#include <class_board.h>
|
||||||
#include <class_drawsegment.h>
|
#include <class_drawsegment.h>
|
||||||
|
@ -21,11 +45,14 @@ wxPoint test::DRC_TEST_PROVIDER_CLEARANCE_BASE::getLocation( TRACK* aTrack, ZONE
|
||||||
{
|
{
|
||||||
SHAPE_POLY_SET* conflictOutline;
|
SHAPE_POLY_SET* conflictOutline;
|
||||||
|
|
||||||
|
PCB_LAYER_ID l = aTrack->GetLayer();
|
||||||
|
|
||||||
if( aConflictZone->IsFilled() )
|
if( aConflictZone->IsFilled() )
|
||||||
conflictOutline = const_cast<SHAPE_POLY_SET*>( &aConflictZone->GetFilledPolysList() );
|
conflictOutline = const_cast<SHAPE_POLY_SET*>( &aConflictZone->GetFilledPolysList( l ) );
|
||||||
else
|
else
|
||||||
conflictOutline = aConflictZone->Outline();
|
conflictOutline = aConflictZone->Outline();
|
||||||
|
|
||||||
|
|
||||||
wxPoint pt1 = aTrack->GetPosition();
|
wxPoint pt1 = aTrack->GetPosition();
|
||||||
wxPoint pt2 = aTrack->GetEnd();
|
wxPoint pt2 = aTrack->GetEnd();
|
||||||
|
|
||||||
|
@ -118,7 +145,7 @@ bool test::DRC_TEST_PROVIDER_CLEARANCE_BASE::checkClearanceSegmToPad( const SEG&
|
||||||
SHAPE_RECT padShape( padBBox.GetPosition(), padBBox.GetWidth(), padBBox.GetHeight() );
|
SHAPE_RECT padShape( padBBox.GetPosition(), padBBox.GetWidth(), padBBox.GetHeight() );
|
||||||
int actual;
|
int actual;
|
||||||
|
|
||||||
if( padShape.DoCollide( refSeg, minClearance + widths, &actual ) )
|
if( padShape.Collide( refSeg, minClearance + widths, &actual ) )
|
||||||
{
|
{
|
||||||
*aActualDist = std::max( 0, actual - widths );
|
*aActualDist = std::max( 0, actual - widths );
|
||||||
return false;
|
return false;
|
||||||
|
@ -158,27 +185,25 @@ bool test::DRC_TEST_PROVIDER_CLEARANCE_BASE::checkClearancePadToPad( D_PAD* aRef
|
||||||
if( center2center - aRefPad->GetBoundingRadius() - aPad->GetBoundingRadius() >= aMinClearance )
|
if( center2center - aRefPad->GetBoundingRadius() - aPad->GetBoundingRadius() >= aMinClearance )
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
// JEY TODO:
|
int actual = INT_MAX;
|
||||||
// TOM TODO: MTV only works as a proxy for actual-distance for convex shapes
|
|
||||||
|
|
||||||
VECTOR2I mtv;
|
|
||||||
VECTOR2I maxMtv( 0, 0 );
|
|
||||||
|
|
||||||
for( const std::shared_ptr<SHAPE>& aShape : aRefPad->GetEffectiveShapes() )
|
for( const std::shared_ptr<SHAPE>& aShape : aRefPad->GetEffectiveShapes() )
|
||||||
{
|
{
|
||||||
for( const std::shared_ptr<SHAPE>& bShape : aPad->GetEffectiveShapes() )
|
for( const std::shared_ptr<SHAPE>& bShape : aPad->GetEffectiveShapes() )
|
||||||
{
|
{
|
||||||
if( aShape->Collide( bShape.get(), aMinClearance, mtv ) )
|
int this_dist;
|
||||||
{
|
|
||||||
if( mtv.SquaredEuclideanNorm() > maxMtv.SquaredEuclideanNorm() )
|
if( aShape->Collide( bShape.get(), aMinClearance, &this_dist ) )
|
||||||
maxMtv = mtv;
|
actual = std::min( actual, this_dist );
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if( maxMtv.x > 0 || maxMtv.y > 0 )
|
if( actual < INT_MAX )
|
||||||
{
|
{
|
||||||
*aActual = std::max( 0, aMinClearance - maxMtv.EuclideanNorm() );
|
// returns the actual clearance (clearance < aMinClearance) for diags:
|
||||||
|
if( aActual )
|
||||||
|
*aActual = std::max( 0, actual );
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -186,6 +211,7 @@ bool test::DRC_TEST_PROVIDER_CLEARANCE_BASE::checkClearancePadToPad( D_PAD* aRef
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool test::DRC_TEST_PROVIDER_CLEARANCE_BASE::poly2segmentDRC( wxPoint* aTref, int aTrefCount, wxPoint aSegStart, wxPoint aSegEnd,
|
bool test::DRC_TEST_PROVIDER_CLEARANCE_BASE::poly2segmentDRC( wxPoint* aTref, int aTrefCount, wxPoint aSegStart, wxPoint aSegEnd,
|
||||||
int aDist, int* aActual )
|
int aDist, int* aActual )
|
||||||
{
|
{
|
||||||
|
@ -222,6 +248,7 @@ bool test::DRC_TEST_PROVIDER_CLEARANCE_BASE::poly2segmentDRC( wxPoint* aTref, in
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if 0
|
||||||
/**
|
/**
|
||||||
* compare 2 convex polygons and return true if distance > aDist (if no error DRC)
|
* compare 2 convex polygons and return true if distance > aDist (if no error DRC)
|
||||||
* i.e if for each edge of the first polygon distance from each edge of the other polygon
|
* i.e if for each edge of the first polygon distance from each edge of the other polygon
|
||||||
|
@ -274,3 +301,4 @@ bool test::DRC_TEST_PROVIDER_CLEARANCE_BASE::poly2polyDRC( wxPoint* aTref, int a
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
#endif
|
|
@ -1,7 +1,9 @@
|
||||||
/*
|
/*
|
||||||
* This program source code file is part of KiCad, a free EDA CAD application.
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
||||||
*
|
*
|
||||||
* Copyright (C) 2018 KiCad Developers, see change_log.txt for contributors.
|
* Copyright (C) 2004-2019 Jean-Pierre Charras, jp.charras at wanadoo.fr
|
||||||
|
* Copyright (C) 2007 Dick Hollenbeck, dick@softplc.com
|
||||||
|
* Copyright (C) 2019-2020 KiCad Developers, see AUTHORS.txt for contributors.
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or
|
* This program is free software; you can redistribute it and/or
|
||||||
* modify it under the terms of the GNU General Public License
|
* modify it under the terms of the GNU General Public License
|
||||||
|
@ -55,8 +57,8 @@ protected:
|
||||||
bool checkClearancePadToPad( D_PAD* aRefPad, D_PAD* aPad, int aMinClearance, int* aActual );
|
bool checkClearancePadToPad( D_PAD* aRefPad, D_PAD* aPad, int aMinClearance, int* aActual );
|
||||||
bool poly2segmentDRC( wxPoint* aTref, int aTrefCount, wxPoint aSegStart, wxPoint aSegEnd,
|
bool poly2segmentDRC( wxPoint* aTref, int aTrefCount, wxPoint aSegStart, wxPoint aSegEnd,
|
||||||
int aDist, int* aActual );
|
int aDist, int* aActual );
|
||||||
bool poly2polyDRC( wxPoint* aTref, int aTrefCount, wxPoint* aTtest, int aTtestCount,
|
//bool poly2polyDRC( wxPoint* aTref, int aTrefCount, wxPoint* aTtest, int aTtestCount,
|
||||||
int aAllowedDist, int* actualDist );
|
// int aAllowedDist, int* actualDist );
|
||||||
|
|
||||||
wxPoint getLocation( TRACK* aTrack, const SEG& aConflictSeg );
|
wxPoint getLocation( TRACK* aTrack, const SEG& aConflictSeg );
|
||||||
wxPoint getLocation( TRACK* aTrack, ZONE_CONTAINER* aConflictZone );
|
wxPoint getLocation( TRACK* aTrack, ZONE_CONTAINER* aConflictZone );
|
||||||
|
|
|
@ -551,21 +551,26 @@ void test::DRC_TEST_PROVIDER_COPPER_CLEARANCE::doTrackDrc( TRACK* aRefSeg, TRACK
|
||||||
|
|
||||||
for( ZONE_CONTAINER* zone : m_board->Zones() )
|
for( ZONE_CONTAINER* zone : m_board->Zones() )
|
||||||
{
|
{
|
||||||
if( zone->GetFilledPolysList().IsEmpty() || zone->GetIsKeepout() )
|
if( !( refLayerSet & zone->GetLayerSet() ).any() || zone->GetIsKeepout() )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if( !( refLayerSet & zone->GetLayerSet() ).any() )
|
for( PCB_LAYER_ID layer : zone->GetLayerSet().Seq() )
|
||||||
continue;
|
{
|
||||||
|
if( zone->GetFilledPolysList( layer ).IsEmpty() )
|
||||||
|
continue;
|
||||||
|
|
||||||
if( zone->GetNetCode() && zone->GetNetCode() == aRefSeg->GetNetCode() )
|
if( zone->GetNetCode() && zone->GetNetCode() == aRefSeg->GetNetCode() )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
auto rule = m_drcEngine->EvalRulesForItems( test::DRC_RULE_ID_T::DRC_RULE_ID_CLEARANCE, aRefSeg, zone );
|
// fixme: per-layer onLayer() property
|
||||||
auto minClearance = rule->GetConstraint().GetValue().Min();
|
|
||||||
|
|
||||||
int widths = refSegWidth / 2;
|
auto rule = m_drcEngine->EvalRulesForItems( test::DRC_RULE_ID_T::DRC_RULE_ID_CLEARANCE, aRefSeg, zone );
|
||||||
int center2centerAllowed = minClearance + widths;
|
auto minClearance = rule->GetConstraint().GetValue().Min();
|
||||||
SHAPE_POLY_SET* outline = const_cast<SHAPE_POLY_SET*>( &zone->GetFilledPolysList() );
|
|
||||||
|
int widths = refSegWidth / 2;
|
||||||
|
int center2centerAllowed = minClearance + widths;
|
||||||
|
SHAPE_POLY_SET* outline =
|
||||||
|
const_cast<SHAPE_POLY_SET*>( &zone->GetFilledPolysList( layer ) );
|
||||||
|
|
||||||
SEG::ecoord center2center_squared = outline->SquaredDistance( testSeg );
|
SEG::ecoord center2center_squared = outline->SquaredDistance( testSeg );
|
||||||
|
|
||||||
|
@ -592,6 +597,7 @@ void test::DRC_TEST_PROVIDER_COPPER_CLEARANCE::doTrackDrc( TRACK* aRefSeg, TRACK
|
||||||
ReportWithMarker( drcItem, getLocation( aRefSeg, zone ) );
|
ReportWithMarker( drcItem, getLocation( aRefSeg, zone ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// fixme: board edge clearance to another rule
|
// fixme: board edge clearance to another rule
|
||||||
|
|
Loading…
Reference in New Issue