2013-05-31 19:13:55 +02:00
|
|
|
%include {
|
|
|
|
|
|
2013-05-31 21:35:44 +02:00
|
|
|
#include <cstdio>
|
2013-05-31 19:13:55 +02:00
|
|
|
#include <iostream>
|
|
|
|
|
#include <string>
|
|
|
|
|
#include <assert.h>
|
|
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
#include "Token.h"
|
|
|
|
|
|
|
|
|
|
#include "AST/ASTElement.h"
|
|
|
|
|
|
2013-05-31 19:13:55 +02:00
|
|
|
}
|
|
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%name scullyParser
|
|
|
|
|
|
|
|
|
|
%token_type {Token*}
|
2013-05-31 19:13:55 +02:00
|
|
|
|
2013-05-31 22:20:31 +02:00
|
|
|
// whitespace and comments
|
|
|
|
|
%type T_WHITESPACE {int}
|
|
|
|
|
|
2013-05-31 21:04:20 +02:00
|
|
|
%right T_ASSIGN.
|
|
|
|
|
%left T_EQUALS.
|
|
|
|
|
%left T_LESS.
|
|
|
|
|
%left T_PLUS T_MINUS.
|
|
|
|
|
%left T_TIMES T_DIV.
|
2013-05-31 19:13:55 +02:00
|
|
|
|
|
|
|
|
%syntax_error {
|
2013-05-31 23:51:44 +02:00
|
|
|
std::cerr << "Syntax error!" << std::endl;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
%parse_failure {
|
|
|
|
|
std::cerr << "Parser Failed!" << std::endl;
|
2013-05-31 19:13:55 +02:00
|
|
|
}
|
|
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%type program {int}
|
|
|
|
|
program ::= fundefs(F). { std::cout << F << std::endl; }
|
|
|
|
|
program ::= expr(E). { std::cout << E << std::endl; }
|
2013-05-31 21:04:20 +02:00
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%type fundefs {int}
|
2013-05-31 21:35:44 +02:00
|
|
|
fundefs(A) ::= . { A = 0; }
|
|
|
|
|
fundefs(A) ::= fundefs fundef(B). { A = A + B; }
|
2013-05-31 21:04:20 +02:00
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%type fundef {int}
|
|
|
|
|
fundef(A) ::= type(T) T_IDENTIFIER(ID) params(P) T_BEGIN statements(S) T_END. { A = T + 1 + P + S; /* ID */ }
|
2013-05-31 21:04:20 +02:00
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%type type {int}
|
2013-05-31 21:04:20 +02:00
|
|
|
type(A) ::= T_BOOL. { A = 1; }
|
|
|
|
|
type(A) ::= T_INT. { A = 1; }
|
|
|
|
|
type(A) ::= T_STRING. { A = 1; }
|
|
|
|
|
type(A) ::= T_VOID. { A = 1; }
|
|
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%type params {int}
|
2013-05-31 21:04:20 +02:00
|
|
|
params(A) ::= . { A = 0; }
|
2013-05-31 23:51:44 +02:00
|
|
|
params(A) ::= type(T) T_IDENTIFIER(ID). { A = T + 1; /* ID */ }
|
|
|
|
|
params(A) ::= params(B) T_COMMA type(T) T_IDENTIFIER(ID). { A = B + T + 1; /* ID */ }
|
2013-05-31 21:04:20 +02:00
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%type statement {int}
|
2013-05-31 21:04:20 +02:00
|
|
|
statement(A) ::= T_IF T_LPAREN expr(E) T_RPAREN statement(S). { A = E + S; }
|
2013-05-31 23:51:44 +02:00
|
|
|
statement(A) ::= T_RIF T_LPAREN T_CINT(P) T_RPAREN statement(S). { A = 1 + S; /* P */ }
|
2013-05-31 21:04:20 +02:00
|
|
|
statement(A) ::= T_FOR T_LPAREN expr(INIT) T_SEMICOLON expr(COND) T_SEMICOLON expr(STEP) T_RPAREN statement(S).
|
|
|
|
|
{ A = INIT + COND + STEP + S; }
|
|
|
|
|
statement(A) ::= T_RFOR T_LPAREN expr(INIT) T_SEMICOLON T_CINT(P) T_SEMICOLON expr(STEP) T_RPAREN statement(S).
|
2013-05-31 23:51:44 +02:00
|
|
|
{ A = INIT + 1 + STEP + S; /* P */ }
|
2013-05-31 21:04:20 +02:00
|
|
|
statement(A) ::= T_RETURN expr(E) T_SEMICOLON. { A = E; }
|
|
|
|
|
statement(A) ::= T_BEGIN statements(S) T_END. { A = S; }
|
|
|
|
|
statement(A) ::= vardef(V) T_SEMICOLON. { A = V; }
|
|
|
|
|
statement(A) ::= expr(E) T_SEMICOLON. { A = E; }
|
|
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%type statements {int}
|
2013-05-31 21:04:20 +02:00
|
|
|
statements(A) ::= . { A = 0; }
|
|
|
|
|
statements(A) ::= statements(B) statement(C). { A = B + C; }
|
|
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%type expr {int}
|
|
|
|
|
expr(A) ::= T_IDENTIFIER(ID) T_ASSIGN expr(E). { A = 1 + E; /* ID */ }
|
2013-05-31 21:04:20 +02:00
|
|
|
expr(A) ::= expr(B) T_EQUALS expr(C). { A = B + C; }
|
|
|
|
|
expr(A) ::= expr(B) T_LESS expr(C). { A = B + C; }
|
|
|
|
|
expr(A) ::= expr(B) T_PLUS expr(C). { A = B + C; }
|
|
|
|
|
expr(A) ::= expr(B) T_MINUS expr(C). { A = B + C; }
|
|
|
|
|
expr(A) ::= expr(B) T_TIMES expr(C). { A = B + C; }
|
|
|
|
|
expr(A) ::= expr(B) T_DIV expr(C). { A = B + C; }
|
|
|
|
|
expr(A) ::= T_CINT. { A = 1; }
|
|
|
|
|
expr(A) ::= T_TRUE. { A = 1; }
|
|
|
|
|
expr(A) ::= T_FALSE. { A = 1; }
|
2013-05-31 23:51:44 +02:00
|
|
|
expr(A) ::= T_IDENTIFIER(ID) T_LPAREN values(V) T_RPAREN. { A = 1 + V; /* ID */ }
|
2013-05-31 21:04:20 +02:00
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%type vardef {int}
|
|
|
|
|
vardef(A) ::= type(T) T_IDENTIFIER(ID). { A = T + 1; /* ID */ }
|
2013-05-31 21:04:20 +02:00
|
|
|
|
2013-05-31 23:51:44 +02:00
|
|
|
%type values {int}
|
2013-05-31 21:04:20 +02:00
|
|
|
values(A) ::= . { A = 0; }
|
|
|
|
|
values(A) ::= expr(E). { A = E; }
|
|
|
|
|
values(A) ::= values(B) T_COMMA expr(E). { A = B + E; }
|
2013-05-31 19:13:55 +02:00
|
|
|
|