]> git.tdb.fi Git - libs/gl.git/blobdiff - source/glsl/visitor.h
Refactor the way of applying visitors to stages
[libs/gl.git] / source / glsl / visitor.h
index 582628bbedc49ecfe695c9eacd7909d861bfa071..e1c45b5c89de152976cfd94549c018f8e7607116 100644 (file)
@@ -66,22 +66,7 @@ public:
        virtual void visit(Return &);
 };
 
-class StageVisitor: public TraversingVisitor
-{
-public:
-       typedef void ResultType;
-
-protected:
-       Stage *stage;
-
-       StageVisitor();
-
-public:
-       virtual void apply(Stage &);
-       void get_result() const { }
-};
-
-class BlockModifier: public StageVisitor
+class BlockModifier: public TraversingVisitor
 {
 protected:
        bool remove_node;
@@ -93,35 +78,35 @@ protected:
        void apply_and_increment(Block &, NodeList<Statement>::iterator &);
 
 public:
-       using StageVisitor::visit;
+       using TraversingVisitor::visit;
        virtual void visit(Block &);
 };
 
 template<typename T>
-class NodeGatherer: public StageVisitor
+class NodeGatherer: public TraversingVisitor
 {
-public:
-       typedef std::vector<T *> ResultType;
-
 private:
        std::vector<T *> nodes;
 
 public:
-       const ResultType &get_result() const { return nodes; }
-       using StageVisitor::visit;
+       const std::vector<T *> &apply(Stage &s) { visit(s.content); return nodes; }
+
+       using TraversingVisitor::visit;
        virtual void visit(T &n) { nodes.push_back(&n); }
 };
 
-class NodeRemover: public StageVisitor
+class NodeRemover: public TraversingVisitor
 {
 private:
+       Stage *stage;
        std::set<Node *> to_remove;
 
 public:
-       NodeRemover() { }
        NodeRemover(const std::set<Node *> &);
 
-       using StageVisitor::visit;
+       void apply(Stage &);
+
+       using TraversingVisitor::visit;
        virtual void visit(Block &);
        virtual void visit(VariableDeclaration &);
        virtual void visit(Iteration &);