Handle multiple holes in footprints
Our basic logic for whether we have a hole or an outline in a footprint checks if there is copper pads outside of the closed edge. This misses the case where the footprint is used to align multiple holes but has no copper. Since we do not support multiple outlines in a board, we can safely assume that multiple, closed edges in a footprint represent holes and not outlines Fixes https://gitlab.com/kicad/code/kicad/issues/14468
This commit is contained in:
parent
b56db30019
commit
4b91c0c8ee
|
@ -641,7 +641,11 @@ bool BuildBoardPolygonOutlines( BOARD* aBoard, SHAPE_POLY_SET& aOutlines, int aE
|
||||||
// gets an opportunity to use these segments
|
// gets an opportunity to use these segments
|
||||||
nullptr );
|
nullptr );
|
||||||
|
|
||||||
if( success && isCopperOutside( fp, fpOutlines ) )
|
// Here, we test to see if we should make holes or outlines. Holes are made if the footprint
|
||||||
|
// has copper outside of a single, closed outline. If there are multiple outlines, we assume
|
||||||
|
// that the footprint edges represent holes as we do not support multiple boards. Similarly, if
|
||||||
|
// any of the footprint pads are located outside of the edges, then the edges are holes
|
||||||
|
if( success && ( isCopperOutside( fp, fpOutlines ) || fpOutlines.OutlineCount() > 1 ) )
|
||||||
{
|
{
|
||||||
fpHoles.Append( fpOutlines );
|
fpHoles.Append( fpOutlines );
|
||||||
}
|
}
|
||||||
|
@ -893,7 +897,8 @@ bool BuildFootprintPolygonOutlines( BOARD* aBoard, SHAPE_POLY_SET& aOutlines, in
|
||||||
wxLogTrace( traceBoardOutline, wxT( "Closed outline found" ) );
|
wxLogTrace( traceBoardOutline, wxT( "Closed outline found" ) );
|
||||||
|
|
||||||
// If copper is outside a closed polygon, treat it as a hole
|
// If copper is outside a closed polygon, treat it as a hole
|
||||||
if( isCopperOutside( footprint, outlines ) )
|
// If there are multiple outlines in the footprint, they are also holes
|
||||||
|
if( isCopperOutside( footprint, outlines ) || outlines.OutlineCount() > 1 )
|
||||||
{
|
{
|
||||||
wxLogTrace( traceBoardOutline, wxT( "Treating outline as a hole" ) );
|
wxLogTrace( traceBoardOutline, wxT( "Treating outline as a hole" ) );
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue