1
0
mirror of git://projects.qi-hardware.com/cae-tools.git synced 2025-01-09 01:50:15 +02:00

cameo: split numbers into dimensions and "bare" numbers

- lang.l, lang.y (MIL2MM): moved unit conversion from lang.l to lang.y
- lang.l, lang.y: instead of returning dimensions and numbers as NUMBER,
  return as NUM_EXP_<unit> for numbers with an explicit unit, and as
  NUM_IMP_<unit> if the unit is implied
- lang.y (dimen): perform unit conversion as needed
- lang.y (number): never convert and only accept implicit dimensions
- lang.y: change all uses of NUMBER to "dimen", except for the
  multipliers in "array", where we can now use "number"
- lang.y: removed comment about "array" only working in metric mode
This commit is contained in:
Werner Almesberger 2010-12-14 19:50:53 -03:00
parent f36f7048e6
commit 68d5eff7cd
2 changed files with 47 additions and 19 deletions

View File

@ -24,9 +24,6 @@ static int lineno = 1;
static int metric = 1;
static int file_name_follows = 0;
#define MIL2MM(mil) ((mil)/1000*25.4)
%}
/* file name can contain any characters */
@ -69,17 +66,15 @@ NUM -?[0-9]+\.?[0-9]*
{NUM}mm { yylval.num = strtod(yytext, NULL);
if (file_name_follows)
BEGIN(FILENAME);
return NUMBER; }
{NUM}mil { yylval.num = MIL2MM(strtod(yytext, NULL));
return NUM_EXP_MM; }
{NUM}mil { yylval.num = strtod(yytext, NULL);
if (file_name_follows)
BEGIN(FILENAME);
return NUMBER; }
return NUM_EXP_MIL; }
{NUM} { yylval.num = strtod(yytext, NULL);
if (!metric)
yylval.num = MIL2MM(yylval.num);
if (file_name_follows)
BEGIN(FILENAME);
return NUMBER; }
return metric ? NUM_IMP_MM : NUM_IMP_MIL; }
<FILENAME>[^ \t\n]+([^\t\n]*[^ \t\n]+)? {
BEGIN(INITIAL);

View File

@ -26,6 +26,9 @@ static double xo = 0, yo = 0, zo = 0;
static struct path *paths = NULL;
#define MIL2MM(mil) ((mil)/1000*25.4)
static void add_paths(struct path *new)
{
struct path **anchor = &paths;
@ -118,10 +121,11 @@ static void align(int ref, double x, double y)
%token TOK_GERBER TOK_GNUPLOT TOK_WRITE
%token TOK_DOG
%token <num> NUMBER REF
%token <num> NUM_EXP_MIL NUM_EXP_MM NUM_IMP_MIL NUM_IMP_MM REF
%token <str> STRING
%type <str> opt_filename
%type <num> dimen number
%%
@ -130,11 +134,11 @@ all:
;
command:
TOK_ALIGN REF NUMBER NUMBER
TOK_ALIGN REF dimen dimen
{
align((int) $2, $3, $4);
}
| TOK_ALIGN REF NUMBER NUMBER NUMBER NUMBER
| TOK_ALIGN REF dimen dimen dimen dimen
{
int ref = $2;
double x, y;
@ -147,12 +151,11 @@ command:
ref_pick_xy(ref, $3, $4, $5, $6, &x, &y);
align(ref, x, y);
}
| TOK_ARRAY NUMBER NUMBER NUMBER NUMBER
| TOK_ARRAY dimen dimen number number
{
double x = $2*$4;
double y = $3*$5;
/* @@@ known bug: doesn't work if not in metric mode */
translate(x, y, 0);
}
| TOK_CLEAR
@ -177,26 +180,26 @@ command:
{
tool_comp_paths(paths, 1);
}
| TOK_TRANSLATE NUMBER NUMBER
| TOK_TRANSLATE dimen dimen
{
translate($2, $3, 0);
xo += $2;
yo += $3;
}
| TOK_Z NUMBER
| TOK_Z dimen
{
zo += $2;
}
| TOK_Z NUMBER NUMBER
| TOK_Z dimen dimen
{
zo += $3-$2;
}
| TOK_GERBER NUMBER opt_filename
| TOK_GERBER dimen opt_filename
{
add_paths(gerber_read($3, $2/2));
translate(xo, yo, 0);
}
| TOK_GNUPLOT NUMBER opt_filename
| TOK_GNUPLOT dimen opt_filename
{
add_paths(gnuplot_read($3, $2/2));
translate(xo, yo, 0);
@ -218,3 +221,33 @@ opt_filename:
$$ = $1;
}
;
dimen:
NUM_EXP_MM
{
$$ = $1;
}
| NUM_IMP_MM
{
$$ = $1;
}
| NUM_EXP_MIL
{
$$ = MIL2MM($1);
}
| NUM_IMP_MIL
{
$$ = MIL2MM($1);
}
;
number:
NUM_IMP_MIL
{
$$ = $1;
}
| NUM_IMP_MM
{
$$ = $1;
}
;