aboutsummaryrefslogtreecommitdiff
path: root/works/life/compile-principle-experiment/4/syn.y
blob: ebe113f454b131c2cea3390394d6bd8111e8a99e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
%{
#include "main.h"
#include <stdio.h>
#define	code2(c1,c2)	code(c1); code(c2)
#define	code3(c1,c2,c3)	code(c1); code(c2); code(c3)
%}
%union {
	Symbol	*sym;	/* symbol table pointer */
	double val;
	Inst	*inst;	/* machine instruction */
}
%token	<sym>	NUMBER VAR BLTIN UNDEF
%right	'='
%left	'+' '-'
%left	'*' '/'
%left	UNARYMINUS
%right	'^'	/* exponentiation */
%%
list:	  /* nothing */
	| list '\n'
	| list asgn '\n'  { code2(mypop, STOP); return 1; }
	| list expr '\n'  { code2(print, STOP); return 1; }
	| list error '\n' { yyerrok; }
	;
asgn:	  VAR '=' expr	{ code3(varpush,(Inst)$1,assign); }
	;
expr:	  NUMBER	{ code2(constpush, (Inst)$1); }
	| VAR		{ code3(varpush, (Inst)$1, eval); }
	| asgn
	| BLTIN '(' expr ')' { code2(bltin, (Inst)$1->value.ptr); }
	| '(' expr ')'
	| expr '+' expr	{ code(add); }
	| expr '-' expr	{ code(sub); }
	| expr '*' expr	{ code(mul); }
	| expr '/' expr	{ code(mydiv); }
	| expr '^' expr	{ code(power); }
	| '-' expr  %prec UNARYMINUS  { code(negate); }
	;
%%