X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fprogramsyntax.h;h=9e64c4c7e86896192748cefb24e29b2333ca1787;hb=3ba81ebaaec0c271d68cc12afbea86c394c3403d;hp=14e5d8e786cb679e36c448cf5ca68b1dfe387fd3;hpb=79c49c6b6155857ed0ebe85eb07a996788a6190b;p=libs%2Fgl.git diff --git a/source/programsyntax.h b/source/programsyntax.h index 14e5d8e7..9e64c4c7 100644 --- a/source/programsyntax.h +++ b/source/programsyntax.h @@ -178,6 +178,15 @@ struct Import: Node virtual void visit(NodeVisitor &); }; +struct Precision: Node +{ + std::string precision; + std::string type; + + virtual Precision *clone() const { return new Precision(*this); } + virtual void visit(NodeVisitor &); +}; + struct Layout: Node { struct Qualifier @@ -217,6 +226,7 @@ struct VariableDeclaration: Node bool constant; std::string sampling; std::string interface; + std::string precision; std::string type; StructDeclaration *type_declaration; std::string name; @@ -298,6 +308,14 @@ struct Return: Node virtual void visit(NodeVisitor &); }; +struct Jump: Node +{ + std::string keyword; + + virtual Jump *clone() const { return new Jump(*this); } + virtual void visit(NodeVisitor &); +}; + struct NodeVisitor { virtual ~NodeVisitor() { } @@ -313,6 +331,7 @@ struct NodeVisitor virtual void visit(FunctionCall &) { } virtual void visit(ExpressionStatement &) { } virtual void visit(Import &) { } + virtual void visit(Precision &) { } virtual void visit(Layout &) { } virtual void visit(InterfaceLayout &) { } virtual void visit(StructDeclaration &) { } @@ -323,10 +342,12 @@ struct NodeVisitor virtual void visit(Iteration &) { } virtual void visit(Passthrough &) { } virtual void visit(Return &) { } + virtual void visit(Jump &) { } }; struct TraversingVisitor: NodeVisitor { + using NodeVisitor::visit; virtual void visit(Block &); virtual void visit(ParenthesizedExpression &); virtual void visit(MemberAccess &);