More stuff! Tons of stuff!

This commit is contained in:
Markus Hauschild
2013-06-01 00:16:38 +02:00
parent 28ca85b94e
commit a778d524b1
11 changed files with 111 additions and 11 deletions

View File

@@ -60,6 +60,9 @@ SET(SCULLY_SOURCE
src/AST/ASTElement.cpp
src/AST/ASTVisitor.cpp
src/AST/Statement.cpp
src/AST/VariableDefinition.cpp
src/AST/Type.cpp
${CMAKE_CURRENT_BINARY_DIR}/grammar.cpp
)

View File

@@ -8,6 +8,9 @@
#include "Token.h"
#include "AST/ASTElement.h"
#include "AST/Statement.h"
#include "AST/VariableDefinition.h"
#include "AST/Type.h"
}
@@ -41,18 +44,18 @@ fundefs(A) ::= . { A = 0; }
fundefs(A) ::= fundefs fundef(B). { A = A + B; }
%type fundef {int}
fundef(A) ::= type(T) T_IDENTIFIER(ID) params(P) T_BEGIN statements(S) T_END. { A = T + 1 + P + S; /* ID */ }
fundef(A) ::= type(T) T_IDENTIFIER(ID) params(P) T_BEGIN statements(S) T_END. { A = 1 + 1 + P + S; /* T ID */ }
%type type {int}
type(A) ::= T_BOOL. { A = 1; }
type(A) ::= T_INT. { A = 1; }
type(A) ::= T_STRING. { A = 1; }
type(A) ::= T_VOID. { A = 1; }
%type type {Type*}
type(A) ::= T_BOOL. { A = new Type("bool"); }
type(A) ::= T_INT. { A = new Type("int"); }
type(A) ::= T_STRING. { A = new Type("string"); }
type(A) ::= T_VOID. { A = new Type("void"); }
%type params {int}
params(A) ::= . { A = 0; }
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 */ }
params(A) ::= type(T) T_IDENTIFIER(ID). { A = 1 + 1; /* T ID */ }
params(A) ::= params(B) T_COMMA type(T) T_IDENTIFIER(ID). { A = B + 1 + 1; /* T ID */ }
%type statement {int}
statement(A) ::= T_IF T_LPAREN expr(E) T_RPAREN statement(S). { A = E + S; }
@@ -84,7 +87,7 @@ expr(A) ::= T_FALSE. { A = 1; }
expr(A) ::= T_IDENTIFIER(ID) T_LPAREN values(V) T_RPAREN. { A = 1 + V; /* ID */ }
%type vardef {int}
vardef(A) ::= type(T) T_IDENTIFIER(ID). { A = T + 1; /* ID */ }
vardef(A) ::= type(T) T_IDENTIFIER(ID). { A = 1 + 1; /* T ID */ }
%type values {int}
values(A) ::= . { A = 0; }

View File

@@ -1,7 +1,7 @@
#ifndef ASTELEMENT_H
#define ASTELEMENT_H
#include "AST/ASTVisitor.h"
class ASTVisitor;
class ASTElement {
public:

View File

@@ -1,10 +1,14 @@
#ifndef ASTVISITOR_H
#define ASTVISITOR_H
#include "VariableDefinition.h"
class ASTVisitor {
public:
ASTVisitor();
virtual ~ASTVisitor();
virtual void visit(VariableDefinition* e) = 0;
};
#endif // ASTVISITOR_H

14
inc/AST/Statement.h Normal file
View File

@@ -0,0 +1,14 @@
#ifndef STATEMENT_H
#define STATEMENT_H
#include "AST/ASTElement.h"
class Statement : public ASTElement {
public:
Statement();
virtual ~Statement();
virtual void accept(ASTVisitor* visitor) = 0;
};
#endif // STATEMENT_H

16
inc/AST/Type.h Normal file
View File

@@ -0,0 +1,16 @@
#ifndef TYPE_H
#define TYPE_H
#include <string>
class Type {
public:
Type(std::string name);
~Type();
std::string getName();
private:
std::string name_;
};
#endif // TYPE_H

View File

@@ -0,0 +1,25 @@
#ifndef VARIABLEDEFINITION_H
#define VARIABLEDEFINITION_H
#include <string>
#include "AST/Statement.h"
class VariableDefinition : public Statement
{
public:
VariableDefinition(int type, std::string name);
virtual ~VariableDefinition();
virtual void accept(ASTVisitor* visitor);
// Type* getType();
int getType();
std::string getName();
private:
// Type* type_
int type_;
std::string name_;
};
#endif // VARIABLEDEFINITION_H

View File

@@ -7,4 +7,3 @@ ASTVisitor::ASTVisitor() {
ASTVisitor::~ASTVisitor() {
//
}

9
src/AST/Statement.cpp Normal file
View File

@@ -0,0 +1,9 @@
#include "AST/Statement.h"
Statement::Statement() {
//
}
Statement::~Statement() {
//
}

5
src/AST/Type.cpp Normal file
View File

@@ -0,0 +1,5 @@
#include "AST/Type.h"
Type::Type(std::string name) : name_(name) {
//
}

View File

@@ -0,0 +1,22 @@
#include "AST/VariableDefinition.h"
#include "AST/ASTVisitor.h"
VariableDefinition::VariableDefinition(int type, std::string name) : type_(type), name_(name) {
//
}
VariableDefinition::~VariableDefinition() {
//
}
void VariableDefinition::accept(ASTVisitor* visitor) {
visitor->visit(this);
}
int VariableDefinition::getType() {
return type_;
}
std::string VariableDefinition::getName() {
return name_;
}