ValueList and some cleanup
This commit is contained in:
@@ -68,6 +68,7 @@ SET(SCULLY_SOURCE
|
||||
src/AST/ParameterList.cpp
|
||||
src/AST/Statement.cpp
|
||||
src/AST/Type.cpp
|
||||
src/AST/ValueList.cpp
|
||||
src/AST/VariableDefinition.cpp
|
||||
|
||||
${CMAKE_CURRENT_BINARY_DIR}/grammar.cpp
|
||||
|
||||
@@ -16,6 +16,7 @@
|
||||
#include "AST/Statement.h"
|
||||
#include "AST/StatementList.h"
|
||||
#include "AST/Type.h"
|
||||
#include "AST/ValueList.h"
|
||||
#include "AST/VariableDefinition.h"
|
||||
|
||||
}
|
||||
@@ -95,8 +96,8 @@ expr(A) ::= T_IDENTIFIER(ID) T_LPAREN values(V) T_RPAREN. { A = 0; /* ID V */
|
||||
%type vardef {VariableDefinition*}
|
||||
vardef(A) ::= type(T) T_IDENTIFIER(ID). { A = new VariableDefinition(T, ID->getText()); }
|
||||
|
||||
%type values {int}
|
||||
values(A) ::= . { A = 0; }
|
||||
values(A) ::= expr(E). { A = 1; /* E */ }
|
||||
values(A) ::= values(B) T_COMMA expr(E). { A = B + 1; /* E */ }
|
||||
%type values {ValueList*}
|
||||
values(A) ::= . { A = new ValueList(); }
|
||||
values(A) ::= expr(E). { A = new ValueList(); A->addValue(E); }
|
||||
values(A) ::= values(B) T_COMMA expr(E). { B->addValue(E); A = B; }
|
||||
|
||||
|
||||
@@ -5,8 +5,9 @@
|
||||
#include "BinOp.h"
|
||||
#include "ConstantExpression.h"
|
||||
#include "IfStatement.h"
|
||||
#include "VariableDefinition.h"
|
||||
#include "ParameterList.h"
|
||||
#include "ValueList.h"
|
||||
#include "VariableDefinition.h"
|
||||
|
||||
class ASTVisitor {
|
||||
public:
|
||||
@@ -16,8 +17,9 @@ public:
|
||||
virtual void visit(AssignmentExpression* e) = 0;
|
||||
virtual void visit(BinOp* e) = 0;
|
||||
virtual void visit(ConstantExpression* e) = 0;
|
||||
virtual void visit(IfStatement* e) = 0;
|
||||
virtual void visit(IfStatement* e) = 0;
|
||||
virtual void visit(ParameterList* e) = 0;
|
||||
virtual void visit(ValueList* e) = 0;
|
||||
virtual void visit(VariableDefinition* e) = 0;
|
||||
};
|
||||
|
||||
|
||||
@@ -4,19 +4,18 @@
|
||||
#include "AST/Expression.h"
|
||||
#include <string>
|
||||
|
||||
class AssignmentExpression : public Expression
|
||||
{
|
||||
class AssignmentExpression : public Expression {
|
||||
public:
|
||||
AssignmentExpression(std::string id, Expression* expr);
|
||||
virtual ~AssignmentExpression();
|
||||
AssignmentExpression(std::string id, Expression* expr);
|
||||
virtual ~AssignmentExpression();
|
||||
|
||||
virtual void accept(ASTVisitor *visitor);
|
||||
virtual void accept(ASTVisitor *visitor);
|
||||
|
||||
std::string getId();
|
||||
Expression* getExpr();
|
||||
std::string getId();
|
||||
Expression* getExpr();
|
||||
private:
|
||||
std::string id_;
|
||||
Expression* expr_;
|
||||
std::string id_;
|
||||
Expression* expr_;
|
||||
};
|
||||
|
||||
#endif // ASSIGNMENTEXPRESSION_H
|
||||
|
||||
21
inc/AST/ValueList.h
Normal file
21
inc/AST/ValueList.h
Normal file
@@ -0,0 +1,21 @@
|
||||
#ifndef VALUELIST_H
|
||||
#define VALUELIST_H
|
||||
|
||||
#include "AST/ASTElement.h"
|
||||
#include "AST/Expression.h"
|
||||
#include <vector>
|
||||
|
||||
class ValueList : public ASTElement {
|
||||
public:
|
||||
ValueList();
|
||||
~ValueList();
|
||||
|
||||
virtual void accept(ASTVisitor* visitor);
|
||||
|
||||
void addValue(Expression* expr);
|
||||
std::vector<Expression*> getValues();
|
||||
private:
|
||||
std::vector<Expression*> values_;
|
||||
};
|
||||
|
||||
#endif // VALUELIST_H
|
||||
@@ -1,22 +1,22 @@
|
||||
#include "AST/AssignmentExpression.h"
|
||||
#include "AST/ASTVisitor.h"
|
||||
|
||||
AssignmentExpression::AssignmentExpression(std::string id, Expression *expr) : id_(id),expr_(expr)
|
||||
{
|
||||
//
|
||||
AssignmentExpression::AssignmentExpression(std::string id, Expression *expr) : id_(id), expr_(expr) {
|
||||
//
|
||||
}
|
||||
|
||||
AssignmentExpression::~AssignmentExpression() {
|
||||
//
|
||||
}
|
||||
|
||||
void AssignmentExpression::accept(ASTVisitor *visitor) {
|
||||
visitor->visit(this);
|
||||
visitor->visit(this);
|
||||
}
|
||||
|
||||
std::string AssignmentExpression::getId() {
|
||||
return id_;
|
||||
return id_;
|
||||
}
|
||||
|
||||
Expression* AssignmentExpression::getExpr() {
|
||||
return expr_;
|
||||
return expr_;
|
||||
}
|
||||
|
||||
22
src/AST/ValueList.cpp
Normal file
22
src/AST/ValueList.cpp
Normal file
@@ -0,0 +1,22 @@
|
||||
#include "AST/ValueList.h"
|
||||
#include "AST/ASTVisitor.h"
|
||||
|
||||
ValueList::ValueList() {
|
||||
//
|
||||
}
|
||||
|
||||
ValueList::~ValueList() {
|
||||
//
|
||||
}
|
||||
|
||||
void ValueList::accept(ASTVisitor* visitor) {
|
||||
visitor->visit(this);
|
||||
}
|
||||
|
||||
void ValueList::addValue(Expression* expr) {
|
||||
values_.push_back(expr);
|
||||
}
|
||||
|
||||
std::vector<Expression*> ValueList::getValues() {
|
||||
return values_;
|
||||
}
|
||||
Reference in New Issue
Block a user