X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fprogramsyntax.h;h=796c4b938f10f6f84eb1fbcdcdd0c3fd9bd6f062;hp=2f9f1fc08a50f47eb3a8fc6f4757217cb39f0b09;hb=8812fe9fc71b997246ddfdedb8a91932b679d2d3;hpb=f632bf388a58b036e265f3789c797beff5ab063a diff --git a/source/programsyntax.h b/source/programsyntax.h index 2f9f1fc0..796c4b93 100644 --- a/source/programsyntax.h +++ b/source/programsyntax.h @@ -182,12 +182,20 @@ struct Layout: Node }; std::vector qualifiers; - std::string interface; virtual Layout *clone() const { return new Layout(*this); } virtual void visit(NodeVisitor &); }; +struct InterfaceLayout: Node +{ + std::string interface; + Layout layout; + + virtual InterfaceLayout *clone() const { return new InterfaceLayout(*this); } + virtual void visit(NodeVisitor &); +}; + struct StructDeclaration: Node { std::string name; @@ -211,6 +219,7 @@ struct VariableDeclaration: Node NodePtr array_size; NodePtr init_expression; VariableDeclaration *linked_declaration; + NodePtr layout; VariableDeclaration(); @@ -300,6 +309,7 @@ struct NodeVisitor virtual void visit(ExpressionStatement &) { } virtual void visit(Import &) { } virtual void visit(Layout &) { } + virtual void visit(InterfaceLayout &) { } virtual void visit(StructDeclaration &) { } virtual void visit(VariableDeclaration &) { } virtual void visit(InterfaceBlock &) { } @@ -319,6 +329,7 @@ struct TraversingVisitor: NodeVisitor virtual void visit(BinaryExpression &); virtual void visit(FunctionCall &); virtual void visit(ExpressionStatement &); + virtual void visit(InterfaceLayout &); virtual void visit(StructDeclaration &); virtual void visit(VariableDeclaration &); virtual void visit(InterfaceBlock &);