gerbview: Corrects handling of %FSD statement

This commit is contained in:
Seth Hillbrand 2017-09-28 15:38:36 -07:00 committed by jean-pierre charras
parent 948dfe88ce
commit 5b2248fad8
10 changed files with 47 additions and 39 deletions

View File

@ -95,7 +95,8 @@ void X2_ATTRIBUTE::DbgListPrms()
* buff = the buffer containing current Gerber data (GERBER_BUFZ size) * buff = the buffer containing current Gerber data (GERBER_BUFZ size)
* text = a pointer to the first char to read in Gerber data * text = a pointer to the first char to read in Gerber data
*/ */
bool X2_ATTRIBUTE::ParseAttribCmd( FILE* aFile, char *aBuffer, int aBuffSize, char* &aText ) bool X2_ATTRIBUTE::ParseAttribCmd( FILE* aFile, char *aBuffer, int aBuffSize, char* &aText,
int& aLineNum )
{ {
bool ok = true; bool ok = true;
wxString data; wxString data;
@ -144,6 +145,7 @@ bool X2_ATTRIBUTE::ParseAttribCmd( FILE* aFile, char *aBuffer, int aBuffSize, ch
break; break;
} }
aLineNum++;
aText = aBuffer; aText = aBuffer;
} }
else else

View File

@ -96,9 +96,10 @@ public:
* @param aText = a pointer to the first char to read from Gerber data stored in aBuffer * @param aText = a pointer to the first char to read from Gerber data stored in aBuffer
* After parsing, text points the last char of the command line ('%') (X2 mode) * After parsing, text points the last char of the command line ('%') (X2 mode)
* or the end of line if the line does not contain '%' or aBuffer == NULL (X1 mode) * or the end of line if the line does not contain '%' or aBuffer == NULL (X1 mode)
* @oaram aLineNum = a point to the current line number of aFile
* @return true if no error. * @return true if no error.
*/ */
bool ParseAttribCmd( FILE* aFile, char *aBuffer, int aBuffSize, char* &aText ); bool ParseAttribCmd( FILE* aFile, char *aBuffer, int aBuffSize, char* &aText, int& aLineNum );
/** /**
* Debug function: pring using wxLogMessage le list of parameters * Debug function: pring using wxLogMessage le list of parameters

View File

@ -195,7 +195,6 @@ void GERBER_FILE_IMAGE::ResetDefaultValues()
m_Relative = false; // false = absolute Coord, m_Relative = false; // false = absolute Coord,
// true = relative Coord // true = relative Coord
m_NoTrailingZeros = false; // true: trailing zeros deleted m_NoTrailingZeros = false; // true: trailing zeros deleted
m_DecimalFormat = false; // true: use floating point notations for coordinates
m_ImageOffset.x = m_ImageOffset.y = 0; // Coord Offset, from IO command m_ImageOffset.x = m_ImageOffset.y = 0; // Coord Offset, from IO command
m_ImageRotation = 0; // Allowed 0, 90, 180, 270 (in degree) m_ImageRotation = 0; // Allowed 0, 90, 180, 270 (in degree)
m_LocalRotation = 0.0; // Layer totation from RO command (in 0.1 degree) m_LocalRotation = 0.0; // Layer totation from RO command (in 0.1 degree)
@ -220,6 +219,7 @@ void GERBER_FILE_IMAGE::ResetDefaultValues()
m_PreviousPos.x = m_PreviousPos.y = 0; // last specified coord m_PreviousPos.x = m_PreviousPos.y = 0; // last specified coord
m_IJPos.x = m_IJPos.y = 0; // current centre coord for m_IJPos.x = m_IJPos.y = 0; // current centre coord for
// plot arcs & circles // plot arcs & circles
m_LineNum = 0; // line number in file being read
m_Current_File = NULL; // Gerber file to read m_Current_File = NULL; // Gerber file to read
m_PolygonFillMode = false; m_PolygonFillMode = false;
m_PolygonFillModeState = 0; m_PolygonFillModeState = 0;

View File

@ -125,8 +125,6 @@ public:
bool m_GerbMetric; // false = Inches, true = metric bool m_GerbMetric; // false = Inches, true = metric
bool m_Relative; // false = absolute Coord, true = relative Coord bool m_Relative; // false = absolute Coord, true = relative Coord
bool m_NoTrailingZeros; // true: remove tailing zeros. bool m_NoTrailingZeros; // true: remove tailing zeros.
bool m_DecimalFormat; // true: use floating point notations for coordinates
// If true, overrides m_NoTrailingZeros parameter.
wxPoint m_ImageOffset; // Coord Offset, from IO command wxPoint m_ImageOffset; // Coord Offset, from IO command
wxSize m_FmtScale; // Fmt 2.3: m_FmtScale = 3, fmt 3.4: m_FmtScale = 4 wxSize m_FmtScale; // Fmt 2.3: m_FmtScale = 3, fmt 3.4: m_FmtScale = 4
wxSize m_FmtLen; // Nb chars per coord. ex fmt 2.3, m_FmtLen = 5 wxSize m_FmtLen; // Nb chars per coord. ex fmt 2.3, m_FmtLen = 5
@ -143,6 +141,7 @@ public:
int m_Current_Tool; // Current Tool (Dcode) number selected int m_Current_Tool; // Current Tool (Dcode) number selected
int m_Last_Pen_Command; // Current or last pen state (0..9, set by Dn option with n <10 int m_Last_Pen_Command; // Current or last pen state (0..9, set by Dn option with n <10
int m_CommandState; // state of gerber analysis command. int m_CommandState; // state of gerber analysis command.
int m_LineNum; // Line number of the gerber file while reading
wxPoint m_CurrentPos; // current specified coord for plot wxPoint m_CurrentPos; // current specified coord for plot
wxPoint m_PreviousPos; // old current specified coord for plot wxPoint m_PreviousPos; // old current specified coord for plot
wxPoint m_IJPos; // IJ coord (for arcs & circles ) wxPoint m_IJPos; // IJ coord (for arcs & circles )
@ -175,6 +174,20 @@ private:
// -1 = negative items are // -1 = negative items are
// 0 = no negative items found // 0 = no negative items found
// 1 = have negative items found // 1 = have negative items found
/**
* Function GetNextLine
* test for an end of line
* if an end of line is found:
* read a new line
* @param aBuff = buffer (size = GERBER_BUFZ) to fill with a new line
* @param aText = pointer to the last useful char in aBuff
* on return: points the beginning of the next line.
* @param aFile = the opened GERBER file to read
* @return a pointer to the beginning of the next line or NULL if end of file
*/
char* GetNextLine( char *aBuff, char* aText, FILE* aFile );
bool GetEndOfBlock( char* buff, char*& text, FILE* gerber_file );
public: public:
GERBER_FILE_IMAGE( int layer ); GERBER_FILE_IMAGE( int layer );

View File

@ -307,7 +307,8 @@ bool EXCELLON_IMAGE::LoadFile( const wxString & aFullFileName )
// Add our file attribute, to identify the drill file // Add our file attribute, to identify the drill file
X2_ATTRIBUTE dummy; X2_ATTRIBUTE dummy;
char* text = (char*)file_attribute; char* text = (char*)file_attribute;
dummy.ParseAttribCmd( m_Current_File, NULL, 0, text ); int dummyline = 0;
dummy.ParseAttribCmd( m_Current_File, NULL, 0, text, dummyline );
delete m_FileFunction; delete m_FileFunction;
m_FileFunction = new X2_ATTRIBUTE_FILEFUNCTION( dummy ); m_FileFunction = new X2_ATTRIBUTE_FILEFUNCTION( dummy );

View File

@ -39,9 +39,6 @@
#include <plot_auxiliary_data.h> #include <plot_auxiliary_data.h>
#include <html_messagebox.h> #include <html_messagebox.h>
extern int ReadInt( char*& text, bool aSkipSeparator = true );
extern double ReadDouble( char*& text, bool aSkipSeparator = true );
extern bool GetEndOfBlock( char* buff, char*& text, FILE* gerber_file );
/** /**
* this class read and parse a Gerber job file to extract useful info * this class read and parse a Gerber job file to extract useful info

View File

@ -128,6 +128,7 @@ bool GERBER_FILE_IMAGE::LoadGerberFile( const wxString& aFullFileName )
if( fgets( line, sizeof(line), m_Current_File ) == NULL ) if( fgets( line, sizeof(line), m_Current_File ) == NULL )
break; break;
m_LineNum++;
text = StrPurge( line ); text = StrPurge( line );
while( text && *text ) while( text && *text )

View File

@ -73,7 +73,7 @@ wxPoint GERBER_FILE_IMAGE::ReadXYCoord( char*& Text )
{ {
wxPoint pos; wxPoint pos;
int type_coord = 0, current_coord, nbdigits; int type_coord = 0, current_coord, nbdigits;
bool is_float = m_DecimalFormat; bool is_float = false;
char* text; char* text;
char line[256]; char line[256];

View File

@ -484,7 +484,7 @@ bool GERBER_FILE_IMAGE::Execute_G_Command( char*& text, int G_command )
{ {
text += 7; text += 7;
X2_ATTRIBUTE dummy; X2_ATTRIBUTE dummy;
dummy.ParseAttribCmd( m_Current_File, NULL, 0, text ); dummy.ParseAttribCmd( m_Current_File, NULL, 0, text, m_LineNum );
if( dummy.IsFileFunction() ) if( dummy.IsFileFunction() )
{ {
delete m_FileFunction; delete m_FileFunction;

View File

@ -37,7 +37,6 @@
extern int ReadInt( char*& text, bool aSkipSeparator = true ); extern int ReadInt( char*& text, bool aSkipSeparator = true );
extern double ReadDouble( char*& text, bool aSkipSeparator = true ); extern double ReadDouble( char*& text, bool aSkipSeparator = true );
extern bool GetEndOfBlock( char* buff, char*& text, FILE* gerber_file );
#define CODE( x, y ) ( ( (x) << 8 ) + (y) ) #define CODE( x, y ) ( ( (x) << 8 ) + (y) )
@ -233,7 +232,7 @@ bool GERBER_FILE_IMAGE::ReadRS274XCommand( char* buff, char*& text )
ok = false; ok = false;
break; break;
} }
m_LineNum++;
text = buff; text = buff;
} }
@ -273,14 +272,21 @@ bool GERBER_FILE_IMAGE::ExecuteRS274XCommand( int command, char* buff, char*& te
text++; text++;
break; break;
case 'D': // Non-standard option for all zeros (leading + tailing)
msg.Printf( _( "RS274X: Invalid GERBER format command '%c' at line %d: \"%s\"" ),
'D', m_LineNum, buff );
AddMessageToList( msg );
msg.Printf( _("GERBER file \"%s\" may not display as intended." ),
m_FileName.ToAscii() );
AddMessageToList( msg );
// Fallthrough
case 'L': // No Leading 0 case 'L': // No Leading 0
m_DecimalFormat = false;
m_NoTrailingZeros = false; m_NoTrailingZeros = false;
text++; text++;
break; break;
case 'T': // No trailing 0 case 'T': // No trailing 0
m_DecimalFormat = false;
m_NoTrailingZeros = true; m_NoTrailingZeros = true;
text++; text++;
break; break;
@ -305,16 +311,12 @@ bool GERBER_FILE_IMAGE::ExecuteRS274XCommand( int command, char* buff, char*& te
seq_len = seq_char - '0'; seq_len = seq_char - '0';
break; break;
case 'D':
case 'M': // Sequence code (followed by one digit: the sequence len) case 'M': // Sequence code (followed by one digit: the sequence len)
// (sometimes found after the X,Y sequence) // (sometimes found after the X,Y sequence)
// Obscure option // Obscure option
code = *text++; code = *text++;
if( ( *text >= '0' ) && ( *text<= '9' ) ) if( ( *text >= '0' ) && ( *text<= '9' ) )
text++; // skip the digit text++; // skip the digit
else if( code == 'D' )
// Decimal format: sometimes found, but not really documented
m_DecimalFormat = true;
break; break;
case 'X': case 'X':
@ -411,7 +413,7 @@ bool GERBER_FILE_IMAGE::ExecuteRS274XCommand( int command, char* buff, char*& te
m_IsX2_file = true; m_IsX2_file = true;
{ {
X2_ATTRIBUTE dummy; X2_ATTRIBUTE dummy;
dummy.ParseAttribCmd( m_Current_File, buff, GERBER_BUFZ, text ); dummy.ParseAttribCmd( m_Current_File, buff, GERBER_BUFZ, text, m_LineNum );
if( dummy.IsFileFunction() ) if( dummy.IsFileFunction() )
{ {
@ -432,7 +434,7 @@ bool GERBER_FILE_IMAGE::ExecuteRS274XCommand( int command, char* buff, char*& te
case APERTURE_ATTRIBUTE: // Command %TA ... Not yet supported case APERTURE_ATTRIBUTE: // Command %TA ... Not yet supported
{ {
X2_ATTRIBUTE dummy; X2_ATTRIBUTE dummy;
dummy.ParseAttribCmd( m_Current_File, buff, GERBER_BUFZ, text ); dummy.ParseAttribCmd( m_Current_File, buff, GERBER_BUFZ, text, m_LineNum );
if( dummy.GetAttribute() == ".AperFunction" ) if( dummy.GetAttribute() == ".AperFunction" )
{ {
@ -449,7 +451,7 @@ bool GERBER_FILE_IMAGE::ExecuteRS274XCommand( int command, char* buff, char*& te
{ {
X2_ATTRIBUTE dummy; X2_ATTRIBUTE dummy;
dummy.ParseAttribCmd( m_Current_File, buff, GERBER_BUFZ, text ); dummy.ParseAttribCmd( m_Current_File, buff, GERBER_BUFZ, text, m_LineNum );
if( dummy.GetAttribute() == ".N" ) if( dummy.GetAttribute() == ".N" )
{ {
@ -473,7 +475,7 @@ bool GERBER_FILE_IMAGE::ExecuteRS274XCommand( int command, char* buff, char*& te
case REMOVE_APERTURE_ATTRIBUTE: // Command %TD ... case REMOVE_APERTURE_ATTRIBUTE: // Command %TD ...
{ {
X2_ATTRIBUTE dummy; X2_ATTRIBUTE dummy;
dummy.ParseAttribCmd( m_Current_File, buff, GERBER_BUFZ, text ); dummy.ParseAttribCmd( m_Current_File, buff, GERBER_BUFZ, text, m_LineNum );
RemoveAttribute( dummy ); RemoveAttribute( dummy );
} }
break; break;
@ -902,7 +904,7 @@ bool GERBER_FILE_IMAGE::ExecuteRS274XCommand( int command, char* buff, char*& te
} }
bool GetEndOfBlock( char* buff, char*& text, FILE* gerber_file ) bool GERBER_FILE_IMAGE::GetEndOfBlock( char* buff, char*& text, FILE* gerber_file )
{ {
for( ; ; ) for( ; ; )
{ {
@ -920,6 +922,7 @@ bool GetEndOfBlock( char* buff, char*& text, FILE* gerber_file )
if( fgets( buff, GERBER_BUFZ, gerber_file ) == NULL ) if( fgets( buff, GERBER_BUFZ, gerber_file ) == NULL )
break; break;
m_LineNum++;
text = buff; text = buff;
} }
@ -927,18 +930,7 @@ bool GetEndOfBlock( char* buff, char*& text, FILE* gerber_file )
} }
/** char* GERBER_FILE_IMAGE::GetNextLine( char *aBuff, char* aText, FILE* aFile )
* Function GetNextLine
* test for an end of line
* if an end of line is found:
* read a new line
* @param aBuff = buffer (size = GERBER_BUFZ) to fill with a new line
* @param aText = pointer to the last useful char in aBuff
* on return: points the beginning of the next line.
* @param aFile = the opened GERBER file to read
* @return a pointer to the beginning of the next line or NULL if end of file
*/
static char* GetNextLine( char *aBuff, char* aText, FILE* aFile )
{ {
for( ; ; ) for( ; ; )
{ {
@ -953,6 +945,8 @@ static char* GetNextLine( char *aBuff, char* aText, FILE* aFile )
case 0: // End of text found in aBuff: Read a new string case 0: // End of text found in aBuff: Read a new string
if( fgets( aBuff, GERBER_BUFZ, aFile ) == NULL ) if( fgets( aBuff, GERBER_BUFZ, aFile ) == NULL )
return NULL; return NULL;
m_LineNum++;
aText = aBuff; aText = aBuff;
return aText; return aText;
@ -1078,9 +1072,8 @@ bool GERBER_FILE_IMAGE::ReadApertureMacro( char *buff,
break; break;
default: default:
// @todo, there needs to be a way of reporting the line number msg.Printf( wxT( "RS274X: Aperture Macro \"%s\": Invalid primitive id code %d, line %d: \"%s\"" ),
msg.Printf( wxT( "RS274X: Aperture Macro \"%s\": Invalid primitive id code %d, line: \"%s\"" ), GetChars( am.name ), primitive_type, m_LineNum, GetChars( FROM_UTF8( buff ) ) );
GetChars( am.name ), primitive_type, GetChars( FROM_UTF8( buff ) ) );
AddMessageToList( msg ); AddMessageToList( msg );
return false; return false;
} }