Pcbnew: allows filled option ( 0 outlines width ) for graphic items rect and circle.
It was allowed inside editors, dialog properties and when saving the board file. However it was not allowed when reading the file. It is now allowed. Fixes #6355 https://gitlab.com/kicad/code/kicad/issues/6355
This commit is contained in:
parent
8ec0cef572
commit
fb218e3c9b
|
@ -1513,7 +1513,8 @@ void PCB_IO::format( D_PAD* aPad, int aNestLevel ) const
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
m_out->Print( 0, ") (width %s))", FormatInternalUnits( primitive->GetWidth() ).c_str() );
|
m_out->Print( newLine ? 0 : nested_level, ") (width %s))",
|
||||||
|
FormatInternalUnits( primitive->GetWidth() ).c_str() );
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -594,14 +594,18 @@ BOARD* PCB_PARSER::parseBOARD_unchecked()
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_gr_arc:
|
case T_gr_arc:
|
||||||
case T_gr_circle:
|
|
||||||
case T_gr_curve:
|
case T_gr_curve:
|
||||||
case T_gr_rect:
|
|
||||||
case T_gr_line:
|
case T_gr_line:
|
||||||
case T_gr_poly:
|
|
||||||
m_board->Add( parsePCB_SHAPE(), ADD_MODE::APPEND );
|
m_board->Add( parsePCB_SHAPE(), ADD_MODE::APPEND );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case T_gr_poly:
|
||||||
|
case T_gr_circle:
|
||||||
|
case T_gr_rect:
|
||||||
|
// these filled shapes are allowed and are filled if the line width = 0
|
||||||
|
m_board->Add( parsePCB_SHAPE( true ), ADD_MODE::APPEND );
|
||||||
|
break;
|
||||||
|
|
||||||
case T_gr_text:
|
case T_gr_text:
|
||||||
m_board->Add( parsePCB_TEXT(), ADD_MODE::APPEND );
|
m_board->Add( parsePCB_TEXT(), ADD_MODE::APPEND );
|
||||||
break;
|
break;
|
||||||
|
@ -2088,7 +2092,7 @@ void PCB_PARSER::parseNETCLASS()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
PCB_SHAPE* PCB_PARSER::parsePCB_SHAPE( bool aAllowCirclesZeroWidth )
|
PCB_SHAPE* PCB_PARSER::parsePCB_SHAPE( bool aAllowZeroWidth )
|
||||||
{
|
{
|
||||||
wxCHECK_MSG( CurTok() == T_gr_arc || CurTok() == T_gr_circle || CurTok() == T_gr_curve ||
|
wxCHECK_MSG( CurTok() == T_gr_arc || CurTok() == T_gr_circle || CurTok() == T_gr_curve ||
|
||||||
CurTok() == T_gr_rect || CurTok() == T_gr_line || CurTok() == T_gr_poly, NULL,
|
CurTok() == T_gr_rect || CurTok() == T_gr_line || CurTok() == T_gr_poly, NULL,
|
||||||
|
@ -2275,12 +2279,10 @@ PCB_SHAPE* PCB_PARSER::parsePCB_SHAPE( bool aAllowCirclesZeroWidth )
|
||||||
NeedRIGHT();
|
NeedRIGHT();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Only filled polygons may have a zero-line width
|
// Only filled polygons, circles and rect may have a zero-line width
|
||||||
// This is not permitted in KiCad but some external tools generate invalid
|
// This is not permitted in KiCad for other shapes but some external tools can
|
||||||
// files.
|
// generate invalid files.
|
||||||
// However in custom pad shapes, zero-line width is allowed for filled circles
|
if( shape->GetWidth() < 0 || ( shape->GetWidth() == 0 && !aAllowZeroWidth ) )
|
||||||
if( shape->GetShape() != S_POLYGON && shape->GetWidth() == 0 &&
|
|
||||||
!( shape->GetShape() == S_CIRCLE && aAllowCirclesZeroWidth ) )
|
|
||||||
{
|
{
|
||||||
shape->SetWidth( Millimeter2iu( DEFAULT_LINE_WIDTH ) );
|
shape->SetWidth( Millimeter2iu( DEFAULT_LINE_WIDTH ) );
|
||||||
}
|
}
|
||||||
|
@ -3794,7 +3796,7 @@ D_PAD* PCB_PARSER::parseD_PAD( MODULE* aParent )
|
||||||
if( token == T_LEFT )
|
if( token == T_LEFT )
|
||||||
token = NextTok();
|
token = NextTok();
|
||||||
|
|
||||||
// Currently, I am using parseDRAWSEGMENT() to read basic shapes parameters,
|
// Currently, I am using parsePCB_SHAPE() to read basic shapes parameters,
|
||||||
// because they are the same as a PCB_SHAPE.
|
// because they are the same as a PCB_SHAPE.
|
||||||
// However it could be better to write a specific parser, to avoid possible issues
|
// However it could be better to write a specific parser, to avoid possible issues
|
||||||
// if the PCB_SHAPE parser is modified.
|
// if the PCB_SHAPE parser is modified.
|
||||||
|
@ -3822,14 +3824,15 @@ D_PAD* PCB_PARSER::parseD_PAD( MODULE* aParent )
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case T_gr_rect:
|
case T_gr_rect:
|
||||||
dummysegm = parsePCB_SHAPE( true );
|
dummysegm = parsePCB_SHAPE( true ); // rect with 0 thickness are allowed
|
||||||
|
// ( filled rects )
|
||||||
pad->AddPrimitiveRect( dummysegm->GetStart(), dummysegm->GetEnd(),
|
pad->AddPrimitiveRect( dummysegm->GetStart(), dummysegm->GetEnd(),
|
||||||
dummysegm->GetWidth() );
|
dummysegm->GetWidth() );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
||||||
case T_gr_poly:
|
case T_gr_poly:
|
||||||
dummysegm = parsePCB_SHAPE();
|
dummysegm = parsePCB_SHAPE( true );
|
||||||
pad->AddPrimitivePoly( dummysegm->BuildPolyPointsList(),
|
pad->AddPrimitivePoly( dummysegm->BuildPolyPointsList(),
|
||||||
dummysegm->GetWidth() );
|
dummysegm->GetWidth() );
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -158,10 +158,11 @@ class PCB_PARSER : public PCB_LEXER
|
||||||
void parseNETCLASS();
|
void parseNETCLASS();
|
||||||
|
|
||||||
/** Read a PCB_SHAPE description.
|
/** Read a PCB_SHAPE description.
|
||||||
* @param aAllowCirclesZeroWidth = true to allow items with 0 width
|
* @param aAllowZeroWidth = true to allow items with line width = 0
|
||||||
* Only used in custom pad shapes for filled circles.
|
* (in this case, the are filled shapes)
|
||||||
|
* Mainly used in custom pad shapes for filled circles.
|
||||||
*/
|
*/
|
||||||
PCB_SHAPE* parsePCB_SHAPE( bool aAllowCirclesZeroWidth = false );
|
PCB_SHAPE* parsePCB_SHAPE( bool aAllowZeroWidth = false );
|
||||||
PCB_TEXT* parsePCB_TEXT();
|
PCB_TEXT* parsePCB_TEXT();
|
||||||
DIMENSION* parseDIMENSION();
|
DIMENSION* parseDIMENSION();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue