aboutsummaryrefslogtreecommitdiff
path: root/15/main.y
blob: 40b7ba2e2e37e0f902485b00560e0d81e2e9559c (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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
%{
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<ctype.h>

void apply(char);
void load_num(char);
void load_var(char *);
void store_var(char *);

int yyerror(char *);
int yylex();
int reg_count=0;

char cur_str[100];

struct instruction {
    char op1;
    char op2;
    char opr;
};
%}

%token IDENT NUM NL
%type expr
%left '+'
%left '*''/'
%left '-'
%%

start: statement NL start
     | NL

statement: IDENT {
            strcpy(cur_str, yytext);
         } '=' expr {
            printf("ST %s, R%d\n", cur_str, reg_count-1);
         }
         ;

expr: expr '+' expr {apply('+');}
    | expr '-' expr {apply('-');}
    | expr '*' expr {apply('*');}
    | NUM {
        printf("LD R%d, #%c\n", reg_count++, atoi(yytext));
    }
    | IDENT {
        printf("LD R%d, %s\n", reg_count++, yytext);
    }
    ;

%%

void apply(char opr) {
    switch(opr) {
        case '+': 
            printf("ADD ");
            break;
        case '-': 
            printf("SUB ");
            break;
        case '*': printf("MUL ");
    }
    printf("R%d, R%d, R%d\n", reg_count-2, reg_count-2, reg_count-1);
}

void load_num(char num) {
    printf("LD R%d, #%c\n", reg_count++, num);
}

void load_var(char *var) {
    printf("LD R%d, %s\n", reg_count++, var);
}

void store_var(char* var) {
    printf("ST %s, R%d\n", var, reg_count-1);
}

int yyerror(char *s) {
    printf("ERROR: %s",s);
    exit(0);
}

int main() {
    yyparse();
}