xref: /netbsd-src/external/bsd/byacc/dist/test/code_calc.y (revision c2f76ff004a2cb67efe5b12d97bd3ef7fe89e18d)
1 /*	$NetBSD: code_calc.y,v 1.1.1.1 2010/12/23 23:36:27 christos Exp $	*/
2 
3 %{
4 # include <stdio.h>
5 # include <ctype.h>
6 
7 int regs[26];
8 int base;
9 
10 %}
11 
12 %start list
13 
14 %token DIGIT LETTER
15 
16 %left '|'
17 %left '&'
18 %left '+' '-'
19 %left '*' '/' '%'
20 %left UMINUS   /* supplies precedence for unary minus */
21 
22 %% /* beginning of rules section */
23 
24 list  :  /* empty */
25       |  list stat '\n'
26       |  list error '\n'
27             {  yyerrok ; }
28       ;
29 
30 stat  :  expr
31             {  printf("%d\n",$1);}
32       |  LETTER '=' expr
33             {  regs[$1] = $3; }
34       ;
35 
36 expr  :  '(' expr ')'
37             {  $$ = $2; }
38       |  expr '+' expr
39             {  $$ = $1 + $3; }
40       |  expr '-' expr
41             {  $$ = $1 - $3; }
42       |  expr '*' expr
43             {  $$ = $1 * $3; }
44       |  expr '/' expr
45             {  $$ = $1 / $3; }
46       |  expr '%' expr
47             {  $$ = $1 % $3; }
48       |  expr '&' expr
49             {  $$ = $1 & $3; }
50       |  expr '|' expr
51             {  $$ = $1 | $3; }
52       |  '-' expr %prec UMINUS
53             {  $$ = - $2; }
54       |  LETTER
55             {  $$ = regs[$1]; }
56       |  number
57       ;
58 
59 number:  DIGIT
60          {  $$ = $1; base = ($1==0) ? 8 : 10; }
61       |  number DIGIT
62          {  $$ = base * $1 + $2; }
63       ;
64 
65 %% /* start of programs */
66 
67 int
68 main (void)
69 {
70     while(!feof(stdin)) {
71 	yyparse();
72     }
73     return 0;
74 }
75 
76 static void
77 yyerror(const char *s)
78 {
79     fprintf(stderr, "%s\n", s);
80 }
81 
82 int
83 yylex(void) {
84 	/* lexical analysis routine */
85 	/* returns LETTER for a lower case letter, yylval = 0 through 25 */
86 	/* return DIGIT for a digit, yylval = 0 through 9 */
87 	/* all other characters are returned immediately */
88 
89     int c;
90 
91     while( (c=getchar()) == ' ' )   { /* skip blanks */ }
92 
93     /* c is now nonblank */
94 
95     if( islower( c )) {
96 	yylval = c - 'a';
97 	return ( LETTER );
98     }
99     if( isdigit( c )) {
100 	yylval = c - '0';
101 	return ( DIGIT );
102     }
103     return( c );
104 }
105