#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <stdlib.h>
#define MAXLEN 256
#define TBLSIZE 65535
typedef enum {UNKNOWN, END, INT, ID, ADDSUB, MULDIV, ASSIGN,
LPAREN, RPAREN, ENDFILE} TokenSet;
typedef enum {MISPAREN, NOTNUMID, NOTFOUND, RUNOUT} ErrorType;
typedef struct {
char name[MAXLEN];
int val;
} Symbol;
typedef struct _Node {
char lexeme[MAXLEN];
TokenSet data;
int val;
struct _Node *left, *right;
} BTNode;
Symbol table[TBLSIZE];
extern Symbol table[TBLSIZE];
int r[8][2];
int idx = 0;
extern int getval(void);
extern int setval(char *str, int val);
extern int match (TokenSet token);
extern int evaluateTree(BTNode *root);
extern void printPrefix(BTNode *root);
extern void advance(void);
extern void freeTree(BTNode *root);
extern void statement(void);
extern void error(ErrorType errorNum);
extern BTNode* makeNode(TokenSet tok, const char *lexe);
extern BTNode* factor(void);
extern BTNode* term(void);
extern BTNode* term_tail(BTNode *left);
extern BTNode* expr(void);
extern BTNode* expr_tail(BTNode *left);
static TokenSet getToken(void);
static TokenSet lookahead = UNKNOWN;
extern char* getLexeme(void);
static char lexeme[MAXLEN];
int sbcount = 0;
/*
Something like Python
>> y = 2
>> z = 2
>> x = 3*y + 4/(2*z)
*/
/*
the only type: integer
everything is an expression
statement := END | expr END
expr := term expr_tail
expr_tail := ADDSUB term expr_tail | NIL
term := factor term_tail
term_tail := MULDIV factor term_tail | NIL
factor := INT | ADDSUB INT | ADDSUB ID | ID ASSIGN expr | ID | LPAREN expr RPAREN
*/
int main() {
while (1) {
statement();
}
return 0;
}
/*statement := ENDFILE | END | expr END*/
void statement(void) {
BTNode* retp;
if (match(ENDFILE)) {
} else if (match(END)) {
advance();
} else {
retp = expr();
if (match(END)) {
printf("%d\n", evaluateTree
(retp
)); printPrefix
(retp
); printf("\n"); freeTree(retp);
advance();
}
}
}
void advance(void) {
lookahead = getToken();
}
/* expr := term expr_tail*/
BTNode* expr(void) {
BTNode *node;
node = term();
return expr_tail(node);
}
/* expr_tail := ADDSUB term expr_tail | NIL*/
BTNode* expr_tail(BTNode *left) {
BTNode *node;
if (match(ADDSUB)) {
node = makeNode(ADDSUB, getLexeme());
advance();
node->left = left;
node->right = term();
return expr_tail(node);
}
else
return left;
}
TokenSet getToken(void) {
int i;
char c;
while ((c
= fgetc(stdin
)) == ' ' || c
== '\t'); // ©ø≤§™≈•’¶r§∏
lexeme[0] = c;
i = 1;
lexeme[i] = c;
++i;
}
lexeme[i] = '\0';
return INT;
} else if (c == '+' || c == '-') {
lexeme[0] = c;
lexeme[1] = '\0';
return ADDSUB;
} else if (c == '*' || c == '/') {
lexeme[0] = c;
lexeme[1] = '\0';
return MULDIV;
} else if (c == '\n') {
lexeme[0] = '\0';
return END;
} else if (c == '=') {
return ASSIGN;
} else if (c == '(') {
return LPAREN;
} else if (c == ')') {
return RPAREN;
} else if (isalpha(c
) || c
== '_') { lexeme[0] = c;
i = 1;
lexeme[i] = c;
++i;
}
lexeme[i] = '\0';
return ID;
} else if (c == EOF)
return ENDFILE;
else
return UNKNOWN;
}
int match(TokenSet token) {
if (lookahead == UNKNOWN) advance();
return token == lookahead;
}
char* getLexeme(void) {
return lexeme;
}
int evaluateTree(BTNode *root) {
int retval = 0, lv, rv;
if (root != NULL) {
switch (root->data) {
case ID:
if (strcmp(root
->lexeme
, "x") == 0) else if (strcmp(root
->lexeme
, "y") == 0) else if (strcmp(root
->lexeme
, "z") == 0) break;
case INT:
retval = root->val;
r[idx][0] = root->val;
r[idx][1] = -1;
printf("MOV r%d %d\n", idx
, r
[idx
][0]); idx++;
break;
case ASSIGN:
/*if (strcmp(root->right->lexeme, "x") == 0)
printf("MOV [0] r%d\n", idx);
else if (strcmp(root->right->lexeme, "y") == 0)
printf("MOV [4] r%d\n", idx);
else if (strcmp(root->right->lexeme, "z") == 0)
printf("MOV [8] r%d\n", idx);*/
case ADDSUB:
if (strcmp(root
->lexeme
, "+") == 0) { //printf("",);
}
case MULDIV:
lv = evaluateTree(root->left);
rv = evaluateTree(root->right);
if (strcmp(root
->lexeme
, "+") == 0) { retval = lv + rv;
}
else if (strcmp(root
->lexeme
, "-") == 0) { retval = lv - rv;
}
else if (strcmp(root
->lexeme
, "*") == 0) { retval = lv * rv;
}
else if (strcmp(root
->lexeme
, "/") == 0) { retval = lv / rv;
}
else if (strcmp(root
->lexeme
, "=") == 0) { retval = setval(root->left->lexeme, rv);
}
break;
default:
retval = 0;
}
}
return retval;
}
/* print a tree by pre-order. */
void printPrefix(BTNode *root) {
if (root != NULL) {
printPrefix(root->left);
printPrefix(root->right);
}
}
int getval(void) {
int i, retval, found;
if (match(INT))
retval
= atoi(getLexeme
()); else if (match(ID)) {
i = 0; found = 0; retval = 0;
while (i < sbcount && !found) {
if (strcmp(getLexeme
(), table
[i
].
name)==0) { retval = table[i].val;
found = 1;
break;
} else
i++;
}
if (!found) {
if (sbcount < TBLSIZE) {
strcpy(table
[sbcount
].
name, getLexeme
()); table[sbcount].val = 0;
sbcount++;
} else
error(RUNOUT);
}
}
return retval;
}
int setval(char *str, int val) {
int i, retval;
i = 0;
while (i < sbcount) {
if (strcmp(str
, table
[i
].
name) == 0) { table[i].val = val;
retval = val;
break;
} else
i++;
}
return retval;
}
/* create a node without any child.*/
BTNode* makeNode(TokenSet tok, const char *lexe){
BTNode
*node
= (BTNode
*) malloc(sizeof(BTNode
)); node->data = tok;
node->val = 0;
node->left = NULL;
node->right = NULL;
return node;
}
/* clean a tree.*/
void freeTree(BTNode *root) {
if (root != NULL) {
freeTree(root->left);
freeTree(root->right);
}
}
/*factor := INT | ADDSUB INT | ADDSUB ID | ID ASSIGN expr | ID | LPAREN expr RPAREN*/
BTNode* factor(void) {
BTNode* retp = NULL;
char tmpstr[MAXLEN];
if (match(INT)) {
retp = makeNode(INT, getLexeme());
retp->val = getval();
advance();
} else if (match(ID)) {
BTNode* left = makeNode(ID, getLexeme());
left->val = getval();
advance();
if (match(ASSIGN)) {
retp = makeNode(ASSIGN, getLexeme());
advance();
retp->right = expr();
retp->left = left;
} else
retp = left;
} else if (match(ADDSUB)) {
advance();
if (match(ID) || match(INT)) {
retp = makeNode(ADDSUB, tmpstr);
if (match(ID))
retp->right = makeNode(ID, getLexeme());
else
retp->right = makeNode(INT, getLexeme());
retp->right->val = getval();
retp->left = makeNode(INT, "0");
retp->left->val = 0;
advance();
} else
error(NOTNUMID);
} else if (match(LPAREN)) {
advance();
retp = expr();
if (match(RPAREN))
advance();
else
error(MISPAREN);
} else
error(NOTNUMID);
return retp;
}
/* term := factor term_tail*/
BTNode* term(void) {
BTNode *node;
node = factor();
return term_tail(node);
}
/*term_tail := MULDIV factor term_tail | NIL*/
BTNode* term_tail(BTNode *left) {
BTNode *node;
if (match(MULDIV)) {
node = makeNode(MULDIV, getLexeme());
advance();
node->left = left;
node->right = factor();
return term_tail(node);
}
else
return left;
}
void error(ErrorType errorNum) {
switch (errorNum) {
case MISPAREN:
fprintf(stderr
, "Mismatched parenthesis\n"); break;
case NOTNUMID:
fprintf(stderr
, "Number or identifier expected\n"); break;
case NOTFOUND:
fprintf(stderr
, "%s not defined\n", getLexeme
()); break;
case RUNOUT:
fprintf(stderr
, "Out of memory\n"); }
}
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <stdlib.h>

#define MAXLEN 256
#define TBLSIZE 65535

typedef enum {UNKNOWN, END, INT, ID, ADDSUB, MULDIV, ASSIGN,
    LPAREN, RPAREN, ENDFILE} TokenSet;
typedef enum {MISPAREN, NOTNUMID, NOTFOUND, RUNOUT} ErrorType;

typedef struct {
    char name[MAXLEN];
    int val;
} Symbol;

typedef struct _Node {
    char lexeme[MAXLEN];
    TokenSet data;
    int val;
    struct _Node *left, *right;
} BTNode;

Symbol table[TBLSIZE];
extern Symbol table[TBLSIZE];

int r[8][2];
int idx = 0;

extern int getval(void);
extern int setval(char *str, int val);
extern int match (TokenSet token);
extern int evaluateTree(BTNode *root);
extern void printPrefix(BTNode *root);
extern void advance(void);
extern void freeTree(BTNode *root);
extern void statement(void);
extern void error(ErrorType errorNum);
extern BTNode* makeNode(TokenSet tok, const char *lexe);
extern BTNode* factor(void);
extern BTNode* term(void);
extern BTNode* term_tail(BTNode *left);
extern BTNode* expr(void);
extern BTNode* expr_tail(BTNode *left);
static TokenSet getToken(void);
static TokenSet lookahead = UNKNOWN;
extern char* getLexeme(void);
static char lexeme[MAXLEN];
int sbcount = 0;
/*
 Something like Python
 >> y = 2
 >> z = 2
 >> x = 3*y + 4/(2*z)
 
 */

/*
 the only type: integer
 everything is an expression
 statement   := END | expr END
 expr        := term expr_tail
 expr_tail   := ADDSUB term expr_tail | NIL
 term        := factor term_tail
 term_tail := MULDIV factor term_tail | NIL
 factor      := INT | ADDSUB INT | ADDSUB ID | ID ASSIGN expr | ID | LPAREN expr RPAREN
 */

int main() {
    printf(">> ");
    while (1) {
        statement();
    }
    return 0;
}

/*statement   := ENDFILE | END | expr END*/
void statement(void) {
    BTNode* retp;
    
    if (match(ENDFILE)) {
        exit(0);
    } else if (match(END)) {
        printf(">> ");
        advance();
    } else {
        retp = expr();
        if (match(END)) {
            
            printf("%d\n", evaluateTree(retp));
            printPrefix(retp); printf("\n");
            freeTree(retp);
            
            printf(">> ");
            advance();
        }
    }
}

void advance(void) {
    lookahead = getToken();
}

/*  expr        := term expr_tail*/
BTNode* expr(void) {
    BTNode *node;
    
    node = term();
    
    return expr_tail(node);
}
/*  expr_tail   := ADDSUB term expr_tail | NIL*/
BTNode* expr_tail(BTNode *left) {
    BTNode *node;
    
    if (match(ADDSUB)) {
        node = makeNode(ADDSUB, getLexeme());
        advance();
        
        node->left = left;
        node->right = term();
        
        return expr_tail(node);
    }
    else
        return left;
}

TokenSet getToken(void) {
    int i;
    char c;
    
    while ((c = fgetc(stdin)) == ' ' || c == '\t');  // ©ø≤§™≈•’¶r§∏
    
    if (isdigit(c)) {
        lexeme[0] = c;
        c = fgetc(stdin);
        i = 1;
        while (isdigit(c) && i < MAXLEN) {
            lexeme[i] = c;
            ++i;
            c = fgetc(stdin);
        }
        ungetc(c, stdin);
        lexeme[i] = '\0';
        return INT;
    } else if (c == '+' || c == '-') {
        lexeme[0] = c;
        lexeme[1] = '\0';
        return ADDSUB;
    } else if (c == '*' || c == '/') {
        lexeme[0] = c;
        lexeme[1] = '\0';
        return MULDIV;
    } else if (c == '\n') {
        lexeme[0] = '\0';
        return END;
    } else if (c == '=') {
        strcpy(lexeme, "=");
        return ASSIGN;
    } else if (c == '(') {
        strcpy(lexeme, "(");
        return LPAREN;
    } else if (c == ')') {
        strcpy(lexeme, ")");
        return RPAREN;
    } else if (isalpha(c) || c == '_') {
        lexeme[0] = c;
        c = fgetc(stdin);
        i = 1;
        while (isalpha(c) || isdigit(c) || c == '_') {
            lexeme[i] = c;
            ++i;
            c = fgetc(stdin);
        }
        ungetc(c, stdin);
        lexeme[i] = '\0';
        return ID;
    } else if (c == EOF)
        return ENDFILE;
    else
        return UNKNOWN;
}

int match(TokenSet token) {
    if (lookahead == UNKNOWN) advance();
    return token == lookahead;
}

char* getLexeme(void) {
    return lexeme;
}

int evaluateTree(BTNode *root) {
    int retval = 0, lv, rv;
    if (root != NULL) {
        switch (root->data) {
            case ID:
                if (strcmp(root->lexeme, "x") == 0)
                    printf("MOV r%d [0]\n", idx);
                else if (strcmp(root->lexeme, "y") == 0)
                    printf("MOV r%d [4]\n", idx);
                else if (strcmp(root->lexeme, "z") == 0)
                    printf("MOV r%d [8]\n", idx);
                break;
            case INT:
                retval = root->val;
                r[idx][0] = root->val;
                r[idx][1] = -1;
                printf("MOV r%d %d\n", idx, r[idx][0]);
                idx++;
                break;
            case ASSIGN:
                /*if (strcmp(root->right->lexeme, "x") == 0)
                 printf("MOV [0] r%d\n", idx);
                 else if (strcmp(root->right->lexeme, "y") == 0)
                 printf("MOV [4] r%d\n", idx);
                 else if (strcmp(root->right->lexeme, "z") == 0)
                 printf("MOV [8] r%d\n", idx);*/
                
            case ADDSUB:
                if (strcmp(root->lexeme, "+") == 0) {
                    //printf("",);
                }
            case MULDIV:
                lv = evaluateTree(root->left);
                rv = evaluateTree(root->right);
                if (strcmp(root->lexeme, "+") == 0) {
                    retval = lv + rv;
                    
                }
                else if (strcmp(root->lexeme, "-") == 0) {
                    retval = lv - rv;
                    
                }
                else if (strcmp(root->lexeme, "*") == 0) {
                    retval = lv * rv;
                    
                }
                else if (strcmp(root->lexeme, "/") == 0) {
                    retval = lv / rv;
                    
                }
                else if (strcmp(root->lexeme, "=") == 0) {
                    retval = setval(root->left->lexeme, rv);
                    
                }
                break;
            default:
                retval = 0;
        }
    }
    return retval;
}


/* print a tree by pre-order. */
void printPrefix(BTNode *root) {
    if (root != NULL) {
        printf("%s ", root->lexeme);
        printPrefix(root->left);
        printPrefix(root->right);
    }
}

int getval(void) {
    int i, retval, found;
    
    if (match(INT))
        retval = atoi(getLexeme());
    else if (match(ID)) {
        i = 0; found = 0; retval = 0;
        while (i < sbcount && !found) {
            if (strcmp(getLexeme(), table[i].name)==0) {
                retval = table[i].val;
                found = 1;
                break;
            } else
                i++;
        }
        if (!found) {
            if (sbcount < TBLSIZE) {
                strcpy(table[sbcount].name, getLexeme());
                table[sbcount].val = 0;
                sbcount++;
            } else
                error(RUNOUT);
        }
    }
    return retval;
}

int setval(char *str, int val) {
    int i, retval;
    i = 0;
    while (i < sbcount) {
        if (strcmp(str, table[i].name) == 0) {
            table[i].val = val;
            retval = val;
            break;
        } else
            i++;
    }
    return retval;
}
/* create a node without any child.*/
BTNode* makeNode(TokenSet tok, const char *lexe){
    BTNode *node = (BTNode*) malloc(sizeof(BTNode));
    strcpy(node->lexeme, lexe);
    node->data = tok;
    node->val = 0;
    node->left = NULL;
    node->right = NULL;
    return node;
}
/* clean a tree.*/
void freeTree(BTNode *root) {
    if (root != NULL) {
        freeTree(root->left);
        freeTree(root->right);
        free(root);
    }
}
/*factor := INT | ADDSUB INT | ADDSUB ID | ID ASSIGN expr | ID | LPAREN expr RPAREN*/
BTNode* factor(void) {
    BTNode* retp = NULL;
    char tmpstr[MAXLEN];
    
    if (match(INT)) {
        retp = makeNode(INT, getLexeme());
        retp->val = getval();
        advance();
    } else if (match(ID)) {
        BTNode* left = makeNode(ID, getLexeme());
        left->val = getval();
        strcpy(tmpstr, getLexeme());
        advance();
        if (match(ASSIGN)) {
            retp = makeNode(ASSIGN, getLexeme());
            advance();
            retp->right = expr();
            retp->left = left;
        } else
            retp = left;
    } else if (match(ADDSUB)) {
        strcpy(tmpstr, getLexeme());
        advance();
        if (match(ID) || match(INT)) {
            retp = makeNode(ADDSUB, tmpstr);
            if (match(ID))
                retp->right = makeNode(ID, getLexeme());
            else
                retp->right = makeNode(INT, getLexeme());
            retp->right->val = getval();
            retp->left = makeNode(INT, "0");
            retp->left->val = 0;
            advance();
        } else
            error(NOTNUMID);
    } else if (match(LPAREN)) {
        advance();
        retp = expr();
        if (match(RPAREN))
            advance();
        else
            error(MISPAREN);
    } else
        error(NOTNUMID);
    return retp;
}
/*  term        := factor term_tail*/
BTNode* term(void) {
    BTNode *node;
    node = factor();
    
    return term_tail(node);
}
/*term_tail := MULDIV factor term_tail | NIL*/
BTNode* term_tail(BTNode *left) {
    BTNode *node;
    
    if (match(MULDIV)) {
        node = makeNode(MULDIV, getLexeme());
        advance();
        
        node->left = left;
        node->right = factor();
        
        return term_tail(node);
    }
    else
        return left;
}

void error(ErrorType errorNum) {
    switch (errorNum) {
        case MISPAREN:
            fprintf(stderr, "Mismatched parenthesis\n");
            break;
        case NOTNUMID:
            fprintf(stderr, "Number or identifier expected\n");
            break;
        case NOTFOUND:
            fprintf(stderr, "%s not defined\n", getLexeme());
            break;
        case RUNOUT:
            fprintf(stderr, "Out of memory\n");
    }
    exit(0);
}
