gerbview: Corrects handling of %FSD statement
This commit is contained in:
parent
948dfe88ce
commit
5b2248fad8
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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 );
|
||||||
|
|
|
@ -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 );
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 )
|
||||||
|
|
|
@ -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];
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue