X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fglsl%2Fvisitor.h;fp=source%2Fglsl%2Fvisitor.h;h=9ca910becaa38656c15382ca3f8be0a97f499ba4;hb=ab5f2e6f1ddd35f8f117460530d76c0ba0c9bc87;hp=8bfcac0fd490b85bb2db1c32dfca371a4e786363;hpb=947bb7477205c038aa1804b84452cddd2108550a;p=libs%2Fgl.git diff --git a/source/glsl/visitor.h b/source/glsl/visitor.h index 8bfcac0f..9ca910be 100644 --- a/source/glsl/visitor.h +++ b/source/glsl/visitor.h @@ -66,22 +66,6 @@ public: virtual void visit(Return &); }; -class BlockModifier: public TraversingVisitor -{ -protected: - bool remove_node; - std::vector > insert_nodes; - - BlockModifier(); - - void flatten_block(Block &); - void apply_and_increment(Block &, NodeList::iterator &); - -public: - using TraversingVisitor::visit; - virtual void visit(Block &); -}; - template class NodeGatherer: private TraversingVisitor { @@ -101,6 +85,9 @@ class NodeRemover: private TraversingVisitor private: Stage *stage; const std::set *to_remove; + std::vector blocks; + bool anonymous; + bool recursive_remove; public: NodeRemover(); @@ -108,9 +95,13 @@ public: void apply(Stage &, const std::set &); private: + void remove_variable(std::map &, VariableDeclaration &); + using TraversingVisitor::visit; virtual void visit(Block &); + virtual void visit(StructDeclaration &); virtual void visit(VariableDeclaration &); + virtual void visit(InterfaceBlock &); virtual void visit(Iteration &); };