Fixed minor issues in Gerbview

This commit is contained in:
jean-pierre charras 2010-10-25 11:57:00 +02:00
parent f0364c9da6
commit a9c1c49be0
6 changed files with 33 additions and 20 deletions

View File

@ -606,6 +606,7 @@ void AM_PRIMITIVE::ConvertShapeToPolygon( GERBER_DRAW_ITEM* aParent,
} }
break; break;
case AMP_COMMENT:
case AMP_UNKNOWN: case AMP_UNKNOWN:
case AMP_EOF: case AMP_EOF:
break; break;
@ -707,6 +708,7 @@ int AM_PRIMITIVE::GetShapeDim( GERBER_DRAW_ITEM* aParent )
dim = scale( params[4].GetValue( tool ), m_GerbMetric ) / 2; // Radius dim = scale( params[4].GetValue( tool ), m_GerbMetric ) / 2; // Radius
break; break;
case AMP_COMMENT:
case AMP_UNKNOWN: case AMP_UNKNOWN:
case AMP_EOF: case AMP_EOF:
break; break;

View File

@ -44,7 +44,8 @@
* This complex shape is flashed. * This complex shape is flashed.
*/ */
enum AM_PRIMITIVE_ID { enum AM_PRIMITIVE_ID {
AMP_UNKNOWN = 0, // A value for uninitialized AM_PRIMITIVE. AMP_UNKNOWN = -1, // A value for uninitialized AM_PRIMITIVE.
AMP_COMMENT = 0, // A primitive description is not really a primitive, this is a comment
AMP_CIRCLE = 1, // Circle. (diameter and position) AMP_CIRCLE = 1, // Circle. (diameter and position)
AMP_LINE2 = 2, // Line with rectangle ends. (Width, start and end pos + rotation) AMP_LINE2 = 2, // Line with rectangle ends. (Width, start and end pos + rotation)
AMP_LINE20 = 20, // Same as AMP_LINE2 AMP_LINE20 = 20, // Same as AMP_LINE2

View File

@ -76,9 +76,6 @@ const wxChar* D_CODE::ShowApertureType( APERTURE_T aType )
case APT_CIRCLE: case APT_CIRCLE:
ret = wxT( "Round" ); break; ret = wxT( "Round" ); break;
case APT_LINE:
ret = wxT( "Line" ); break;
case APT_RECT: case APT_RECT:
ret = wxT( "Rect" ); break; ret = wxT( "Rect" ); break;
@ -114,7 +111,6 @@ int D_CODE::GetShapeDim( GERBER_DRAW_ITEM* aParent )
switch( m_Shape ) switch( m_Shape )
{ {
case APT_CIRCLE: case APT_CIRCLE:
case APT_LINE:
dim = m_Size.x; dim = m_Size.x;
break; break;
@ -300,8 +296,6 @@ void WinEDA_GerberFrame::CopyDCodesSizeToItems()
{ {
switch( dcode->m_Shape ) switch( dcode->m_Shape )
{ {
case APT_LINE: // might not appears here, but some broken
// gerber files use it
case APT_CIRCLE: /* spot round */ case APT_CIRCLE: /* spot round */
gerb_item->m_Shape = GBR_SPOT_CIRCLE; gerb_item->m_Shape = GBR_SPOT_CIRCLE;
break; break;
@ -371,11 +365,6 @@ void D_CODE::DrawFlashedShape( GERBER_DRAW_ITEM* aParent,
} }
break; break;
case APT_LINE:
// not used for flashed items
break;
case APT_RECT: case APT_RECT:
{ {
wxPoint start; wxPoint start;
@ -514,11 +503,6 @@ void D_CODE::ConvertShapeToPolygon()
addHoleToPolygon( m_PolyCorners, m_DrillShape, m_Drill, initialpos ); addHoleToPolygon( m_PolyCorners, m_DrillShape, m_Drill, initialpos );
break; break;
case APT_LINE:
// Not used for flashed shapes
break;
case APT_RECT: case APT_RECT:
currpos.x = m_Size.x / 2; currpos.x = m_Size.x / 2;
currpos.y = m_Size.y / 2; currpos.y = m_Size.y / 2;

View File

@ -43,7 +43,6 @@ class GERBER_DRAW_ITEM;
*/ */
enum APERTURE_T { enum APERTURE_T {
APT_CIRCLE = 'C', // Flashed shape: Circle with or without hole APT_CIRCLE = 'C', // Flashed shape: Circle with or without hole
APT_LINE = 'L', // tool to draw line. Not used to flash items
APT_RECT = 'R', // Flashed shape: Rectangle with or without hole APT_RECT = 'R', // Flashed shape: Rectangle with or without hole
APT_OVAL = '0', // Flashed shape: Oval with or without hole APT_OVAL = '0', // Flashed shape: Oval with or without hole
APT_POLYGON = 'P', // Flashed shape: Regular polygon (3 to 12 edges) APT_POLYGON = 'P', // Flashed shape: Regular polygon (3 to 12 edges)

View File

@ -109,7 +109,6 @@ static void fillFlashedGBRITEM( GERBER_DRAW_ITEM* aGbrItem,
aGbrItem->m_Shape = GBR_SPOT_POLY; aGbrItem->m_Shape = GBR_SPOT_POLY;
break; break;
case APT_LINE: // Should not be used.
case APT_CIRCLE: case APT_CIRCLE:
aGbrItem->m_Shape = GBR_SPOT_CIRCLE; aGbrItem->m_Shape = GBR_SPOT_CIRCLE;
aGbrItem->m_Size.y = aGbrItem->m_Size.x; aGbrItem->m_Size.y = aGbrItem->m_Size.x;

View File

@ -873,9 +873,37 @@ bool GERBER_IMAGE::ReadApertureMacro( char buff[GERBER_BUFZ],
break; // exit with text still pointing at % break; // exit with text still pointing at %
int paramCount = 0; int paramCount = 0;
int primitive_type = ReadInt( text ); int primitive_type = AMP_UNKNOWN;
// Test for a valid symbol at the beginning of a description:
// it can be: a parameter declaration like $1=$2/4
// or a digit (macro primitive selection)
// all other symbols are illegal.
if( *text == '$' ) // parameter declaration, not yet supported
{
msg.Printf( wxT( "RS274X: Aperture Macro \"%s\": Operator $ not yet supported here, line: \"%s\"" ),
GetChars( am.name ), GetChars( CONV_FROM_UTF8( buff ) ) );
ReportMessage( msg );
primitive_type = AMP_COMMENT;
}
else if( !isdigit(*text) ) // Ill. symbol
{
msg.Printf( wxT( "RS274X: Aperture Macro \"%s\": ill. symbol, line: \"%s\"" ),
GetChars( am.name ), GetChars( CONV_FROM_UTF8( buff ) ) );
ReportMessage( msg );
primitive_type = AMP_COMMENT;
}
else
primitive_type = ReadInt( text );
switch( primitive_type ) switch( primitive_type )
{ {
case 0: // lines starting by 0 are a comment
paramCount = AMP_COMMENT;
// Skip comment
while( *text && (*text != '*') )
text++;
break;
case AMP_CIRCLE: case AMP_CIRCLE:
paramCount = 4; paramCount = 4;
break; break;