Merge branch 'master' of git.tuxzone.org:woc2013

This commit is contained in:
Florian Sattler
2013-06-01 18:57:55 +02:00
7 changed files with 22 additions and 19 deletions

View File

@@ -80,9 +80,9 @@ statement(A) ::= T_IF T_LPAREN expr(E) T_RPAREN statement(S).
{ A = new IfStatement(E, S); } { A = new IfStatement(E, S); }
statement(A) ::= T_RIF T_LPAREN expr(P) T_RPAREN statement(S). statement(A) ::= T_RIF T_LPAREN expr(P) T_RPAREN statement(S).
{ A = new RandomIfStatement(P, S); } { A = new RandomIfStatement(P, S); }
statement(A) ::= T_FOR T_LPAREN expr(INIT) T_SEMICOLON expr(COND) T_SEMICOLON expr(STEP) T_RPAREN statement(S). statement(A) ::= T_FOR T_LPAREN statement(INIT) T_SEMICOLON expr(COND) T_SEMICOLON statement(STEP) T_RPAREN statement(S).
{ A = new ForStatement(INIT, COND, STEP, S); } { A = new ForStatement(INIT, COND, STEP, S); }
statement(A) ::= T_RFOR T_LPAREN expr(INIT) T_SEMICOLON expr(P) T_SEMICOLON expr(STEP) T_RPAREN statement(S). statement(A) ::= T_RFOR T_LPAREN statement(INIT) T_SEMICOLON expr(P) T_SEMICOLON statement(STEP) T_RPAREN statement(S).
{ A = new RandomForStatement(INIT, P, STEP, S); } { A = new RandomForStatement(INIT, P, STEP, S); }
statement(A) ::= T_RETURN expr(E) T_SEMICOLON. { A = new ReturnStatement(E); } statement(A) ::= T_RETURN expr(E) T_SEMICOLON. { A = new ReturnStatement(E); }
statement(A) ::= T_BEGIN statements(S) T_END. { A = new Scope(S); } statement(A) ::= T_BEGIN statements(S) T_END. { A = new Scope(S); }

View File

@@ -6,19 +6,19 @@
class ForStatement : public Statement { class ForStatement : public Statement {
public: public:
ForStatement(Expression* init, Expression* cond, Expression* step, Statement* stmt); ForStatement(Statement* init, Expression* cond, Statement* step, Statement* stmt);
virtual ~ForStatement(); virtual ~ForStatement();
virtual void accept(ASTVisitor* visitor); virtual void accept(ASTVisitor* visitor);
Expression* getInit(); Statement *getInit();
Expression* getCond(); Expression* getCond();
Expression* getStep(); Statement* getStep();
Statement* getStmt(); Statement* getStmt();
private: private:
Expression* init_; Statement* init_;
Expression* cond_; Expression* cond_;
Expression* step_; Statement* step_;
Statement* stmt_; Statement* stmt_;
}; };

View File

@@ -7,19 +7,19 @@
class RandomForStatement : public Statement class RandomForStatement : public Statement
{ {
public: public:
RandomForStatement(Expression* init, Expression* prob, Expression* step, Statement* stmt); RandomForStatement(Statement *init, Expression* prob, Statement *step, Statement* stmt);
virtual ~RandomForStatement(); virtual ~RandomForStatement();
virtual void accept(ASTVisitor *visitor); virtual void accept(ASTVisitor *visitor);
Expression* getInit(); Statement* getInit();
Expression* getProb(); Expression* getProb();
Expression* getStep(); Statement *getStep();
Statement* getStmt(); Statement* getStmt();
private: private:
Expression* init_; Statement* init_;
Expression* prob_; Expression* prob_;
Expression* step_; Statement* step_;
Statement* stmt_; Statement* stmt_;
}; };

View File

@@ -46,6 +46,9 @@ void CodeGenVisitor::visit(BinOpExpression* e) {
case BinOp::EQUALS: case BinOp::EQUALS:
value_ = builder_->CreateICmpEQ(lhs, rhs, "eqtmp"); value_ = builder_->CreateICmpEQ(lhs, rhs, "eqtmp");
break; break;
case BinOp::LESS:
value_ = builder_->CreateICmpSLT(lhs, rhs, "eqtmp");
break;
default: default:
// TODO error // TODO error
break; break;

View File

@@ -1,7 +1,7 @@
#include "AST/ForStatement.h" #include "AST/ForStatement.h"
#include "AST/ASTVisitor.h" #include "AST/ASTVisitor.h"
ForStatement::ForStatement(Expression *init, Expression *cond, Expression *step, Statement *stmt) : init_(init), cond_(cond), step_(step), stmt_(stmt) { ForStatement::ForStatement(Statement *init, Expression *cond, Statement *step, Statement *stmt) : init_(init), cond_(cond), step_(step), stmt_(stmt) {
// //
} }
@@ -13,7 +13,7 @@ void ForStatement::accept(ASTVisitor* visitor) {
visitor->visit(this); visitor->visit(this);
} }
Expression* ForStatement::getInit() { Statement* ForStatement::getInit() {
return init_; return init_;
} }
@@ -21,7 +21,7 @@ Expression* ForStatement::getCond() {
return cond_; return cond_;
} }
Expression* ForStatement::getStep() { Statement* ForStatement::getStep() {
return step_; return step_;
} }

View File

@@ -1,7 +1,7 @@
#include "AST/RandomForStatement.h" #include "AST/RandomForStatement.h"
#include "AST/ASTVisitor.h" #include "AST/ASTVisitor.h"
RandomForStatement::RandomForStatement(Expression *init, Expression *prob, Expression *step, Statement *stmt) : init_(init),prob_(prob),step_(step),stmt_(stmt) RandomForStatement::RandomForStatement(Statement *init, Expression *prob, Statement *step, Statement *stmt) : init_(init),prob_(prob),step_(step),stmt_(stmt)
{ {
// //
} }
@@ -14,7 +14,7 @@ void RandomForStatement::accept(ASTVisitor *visitor) {
visitor->visit(this); visitor->visit(this);
} }
Expression* RandomForStatement::getInit() { Statement *RandomForStatement::getInit() {
return init_; return init_;
} }
@@ -22,7 +22,7 @@ Expression* RandomForStatement::getProb() {
return prob_; return prob_;
} }
Expression* RandomForStatement::getStep() { Statement* RandomForStatement::getStep() {
return step_; return step_;
} }

View File

@@ -127,7 +127,7 @@ int main() {
lexertl::lookup (state_machine, results); lexertl::lookup (state_machine, results);
std::string s(results.start, results.end); std::string s(results.start, results.end);
if (results.id != T_WHITESPACE) { if (results.id != T_WHITESPACE) {
std::cout << "Id: " << results.id << ", Token: " << s << std::endl; //std::cout << "Id: " << results.id << ", Token: " << s << std::endl;
scullyParser(parser, results.id, new Token(s), cv); scullyParser(parser, results.id, new Token(s), cv);
} }
} while (results.id != 0); } while (results.id != 0);