X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fglsl%2Fvisitor.h;h=2503a15e79e33c67c233574270b527ecd9a50e26;hp=3b558bd195c5cf6a9f0e68d57127d1d8159aa9b0;hb=HEAD;hpb=3a1fe833ea04df75449706f1d773f6e65521a392 diff --git a/source/glsl/visitor.h b/source/glsl/visitor.h index 3b558bd1..2503a15e 100644 --- a/source/glsl/visitor.h +++ b/source/glsl/visitor.h @@ -13,15 +13,13 @@ namespace SL { class NodeVisitor { protected: - NodeVisitor() { } + NodeVisitor() = default; public: - virtual ~NodeVisitor() { } + virtual ~NodeVisitor() = default; virtual void visit(Block &) { } virtual void visit(Literal &) { } - virtual void visit(ParenthesizedExpression &) { } virtual void visit(VariableReference &) { } - virtual void visit(InterfaceBlockReference &) { } virtual void visit(MemberAccess &) { } virtual void visit(Swizzle &) { } virtual void visit(UnaryExpression &) { } @@ -38,7 +36,6 @@ public: virtual void visit(ImageTypeDeclaration &) { } virtual void visit(StructDeclaration &) { } virtual void visit(VariableDeclaration &) { } - virtual void visit(InterfaceBlock &) { } virtual void visit(FunctionDeclaration &) { } virtual void visit(Conditional &) { } virtual void visit(Iteration &) { } @@ -51,15 +48,14 @@ public: class TraversingVisitor: public NodeVisitor { protected: - Block *current_block; + Block *current_block = 0; - TraversingVisitor(): current_block(0) { } + TraversingVisitor() = default; public: virtual void enter(Block &) { } virtual void visit(Block &); virtual void visit(RefPtr &); - virtual void visit(ParenthesizedExpression &); virtual void visit(MemberAccess &); virtual void visit(Swizzle &); virtual void visit(UnaryExpression &); @@ -71,7 +67,6 @@ public: virtual void visit(InterfaceLayout &); virtual void visit(StructDeclaration &); virtual void visit(VariableDeclaration &); - virtual void visit(InterfaceBlock &); virtual void visit(FunctionDeclaration &); virtual void visit(Conditional &); virtual void visit(Iteration &); @@ -83,13 +78,10 @@ public: class NodeRemover: private TraversingVisitor { private: - Stage *stage; - const std::set *to_remove; - bool recursive_remove; + Stage *stage = 0; + const std::set *to_remove = 0; public: - NodeRemover(); - void apply(Stage &, const std::set &); private: @@ -100,9 +92,8 @@ private: void visit(TypeDeclaration &); virtual void visit(BasicTypeDeclaration &t) { visit(static_cast(t)); } virtual void visit(ImageTypeDeclaration &t) { visit(static_cast(t)); } - virtual void visit(StructDeclaration &t) { visit(static_cast(t)); } + virtual void visit(StructDeclaration &); virtual void visit(VariableDeclaration &); - virtual void visit(InterfaceBlock &); virtual void visit(FunctionDeclaration &); virtual void visit(Iteration &); }; @@ -112,12 +103,10 @@ on the same hierarchly level as the target node are reordered. */ class NodeReorderer: private TraversingVisitor { private: - Node *reorder_before; - const std::set *to_reorder; + Node *reorder_before = 0; + const std::set *to_reorder = 0; public: - NodeReorderer(); - void apply(Stage &, Node &, const std::set &); private: