X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fglsl%2Fvisitor.h;h=622a4834910d9d1f1a1f8e74db8c06af6c29a506;hb=3fe1aab63922eec99d8bf6fd4fd60bec10df173c;hp=85f9e848c39b9b45b822c63408ceb6e44a0e5bb9;hpb=2a9f8f3803e1b57e0e5325454266d4e701b38cc5;p=libs%2Fgl.git diff --git a/source/glsl/visitor.h b/source/glsl/visitor.h index 85f9e848..622a4834 100644 --- a/source/glsl/visitor.h +++ b/source/glsl/visitor.h @@ -13,13 +13,12 @@ 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 &) { } @@ -27,6 +26,7 @@ public: virtual void visit(UnaryExpression &) { } virtual void visit(BinaryExpression &) { } virtual void visit(Assignment &) { } + virtual void visit(TernaryExpression &) { } virtual void visit(FunctionCall &) { } virtual void visit(ExpressionStatement &) { } virtual void visit(Import &) { } @@ -50,20 +50,20 @@ 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 &); virtual void visit(BinaryExpression &); virtual void visit(Assignment &); + virtual void visit(TernaryExpression &); virtual void visit(FunctionCall &); virtual void visit(ExpressionStatement &); virtual void visit(InterfaceLayout &); @@ -81,13 +81,11 @@ 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; + bool recursive_remove = false; public: - NodeRemover(); - void apply(Stage &, const std::set &); private: @@ -110,12 +108,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: