mirror of
git://projects.qi-hardware.com/cae-tools.git
synced 2025-01-09 02:00:14 +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:
parent
f36f7048e6
commit
68d5eff7cd
13
cameo/lang.l
13
cameo/lang.l
@ -24,9 +24,6 @@ static int lineno = 1;
|
|||||||
static int metric = 1;
|
static int metric = 1;
|
||||||
static int file_name_follows = 0;
|
static int file_name_follows = 0;
|
||||||
|
|
||||||
|
|
||||||
#define MIL2MM(mil) ((mil)/1000*25.4)
|
|
||||||
|
|
||||||
%}
|
%}
|
||||||
|
|
||||||
/* file name can contain any characters */
|
/* file name can contain any characters */
|
||||||
@ -69,17 +66,15 @@ NUM -?[0-9]+\.?[0-9]*
|
|||||||
{NUM}mm { yylval.num = strtod(yytext, NULL);
|
{NUM}mm { yylval.num = strtod(yytext, NULL);
|
||||||
if (file_name_follows)
|
if (file_name_follows)
|
||||||
BEGIN(FILENAME);
|
BEGIN(FILENAME);
|
||||||
return NUMBER; }
|
return NUM_EXP_MM; }
|
||||||
{NUM}mil { yylval.num = MIL2MM(strtod(yytext, NULL));
|
{NUM}mil { yylval.num = strtod(yytext, NULL);
|
||||||
if (file_name_follows)
|
if (file_name_follows)
|
||||||
BEGIN(FILENAME);
|
BEGIN(FILENAME);
|
||||||
return NUMBER; }
|
return NUM_EXP_MIL; }
|
||||||
{NUM} { yylval.num = strtod(yytext, NULL);
|
{NUM} { yylval.num = strtod(yytext, NULL);
|
||||||
if (!metric)
|
|
||||||
yylval.num = MIL2MM(yylval.num);
|
|
||||||
if (file_name_follows)
|
if (file_name_follows)
|
||||||
BEGIN(FILENAME);
|
BEGIN(FILENAME);
|
||||||
return NUMBER; }
|
return metric ? NUM_IMP_MM : NUM_IMP_MIL; }
|
||||||
|
|
||||||
<FILENAME>[^ \t\n]+([^\t\n]*[^ \t\n]+)? {
|
<FILENAME>[^ \t\n]+([^\t\n]*[^ \t\n]+)? {
|
||||||
BEGIN(INITIAL);
|
BEGIN(INITIAL);
|
||||||
|
53
cameo/lang.y
53
cameo/lang.y
@ -26,6 +26,9 @@ static double xo = 0, yo = 0, zo = 0;
|
|||||||
static struct path *paths = NULL;
|
static struct path *paths = NULL;
|
||||||
|
|
||||||
|
|
||||||
|
#define MIL2MM(mil) ((mil)/1000*25.4)
|
||||||
|
|
||||||
|
|
||||||
static void add_paths(struct path *new)
|
static void add_paths(struct path *new)
|
||||||
{
|
{
|
||||||
struct path **anchor = &paths;
|
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_GERBER TOK_GNUPLOT TOK_WRITE
|
||||||
%token TOK_DOG
|
%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
|
%token <str> STRING
|
||||||
|
|
||||||
%type <str> opt_filename
|
%type <str> opt_filename
|
||||||
|
%type <num> dimen number
|
||||||
|
|
||||||
%%
|
%%
|
||||||
|
|
||||||
@ -130,11 +134,11 @@ all:
|
|||||||
;
|
;
|
||||||
|
|
||||||
command:
|
command:
|
||||||
TOK_ALIGN REF NUMBER NUMBER
|
TOK_ALIGN REF dimen dimen
|
||||||
{
|
{
|
||||||
align((int) $2, $3, $4);
|
align((int) $2, $3, $4);
|
||||||
}
|
}
|
||||||
| TOK_ALIGN REF NUMBER NUMBER NUMBER NUMBER
|
| TOK_ALIGN REF dimen dimen dimen dimen
|
||||||
{
|
{
|
||||||
int ref = $2;
|
int ref = $2;
|
||||||
double x, y;
|
double x, y;
|
||||||
@ -147,12 +151,11 @@ command:
|
|||||||
ref_pick_xy(ref, $3, $4, $5, $6, &x, &y);
|
ref_pick_xy(ref, $3, $4, $5, $6, &x, &y);
|
||||||
align(ref, x, y);
|
align(ref, x, y);
|
||||||
}
|
}
|
||||||
| TOK_ARRAY NUMBER NUMBER NUMBER NUMBER
|
| TOK_ARRAY dimen dimen number number
|
||||||
{
|
{
|
||||||
double x = $2*$4;
|
double x = $2*$4;
|
||||||
double y = $3*$5;
|
double y = $3*$5;
|
||||||
|
|
||||||
/* @@@ known bug: doesn't work if not in metric mode */
|
|
||||||
translate(x, y, 0);
|
translate(x, y, 0);
|
||||||
}
|
}
|
||||||
| TOK_CLEAR
|
| TOK_CLEAR
|
||||||
@ -177,26 +180,26 @@ command:
|
|||||||
{
|
{
|
||||||
tool_comp_paths(paths, 1);
|
tool_comp_paths(paths, 1);
|
||||||
}
|
}
|
||||||
| TOK_TRANSLATE NUMBER NUMBER
|
| TOK_TRANSLATE dimen dimen
|
||||||
{
|
{
|
||||||
translate($2, $3, 0);
|
translate($2, $3, 0);
|
||||||
xo += $2;
|
xo += $2;
|
||||||
yo += $3;
|
yo += $3;
|
||||||
}
|
}
|
||||||
| TOK_Z NUMBER
|
| TOK_Z dimen
|
||||||
{
|
{
|
||||||
zo += $2;
|
zo += $2;
|
||||||
}
|
}
|
||||||
| TOK_Z NUMBER NUMBER
|
| TOK_Z dimen dimen
|
||||||
{
|
{
|
||||||
zo += $3-$2;
|
zo += $3-$2;
|
||||||
}
|
}
|
||||||
| TOK_GERBER NUMBER opt_filename
|
| TOK_GERBER dimen opt_filename
|
||||||
{
|
{
|
||||||
add_paths(gerber_read($3, $2/2));
|
add_paths(gerber_read($3, $2/2));
|
||||||
translate(xo, yo, 0);
|
translate(xo, yo, 0);
|
||||||
}
|
}
|
||||||
| TOK_GNUPLOT NUMBER opt_filename
|
| TOK_GNUPLOT dimen opt_filename
|
||||||
{
|
{
|
||||||
add_paths(gnuplot_read($3, $2/2));
|
add_paths(gnuplot_read($3, $2/2));
|
||||||
translate(xo, yo, 0);
|
translate(xo, yo, 0);
|
||||||
@ -218,3 +221,33 @@ opt_filename:
|
|||||||
$$ = $1;
|
$$ = $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;
|
||||||
|
}
|
||||||
|
;
|
||||||
|
Loading…
Reference in New Issue
Block a user