diff options
author | Marius Kintel <marius@kintel.net> | 2011-09-11 05:37:14 (GMT) |
---|---|---|
committer | Marius Kintel <marius@kintel.net> | 2011-09-11 05:37:14 (GMT) |
commit | 9afeded46c0e9023002dc04ba6131adcb39762b1 (patch) | |
tree | 0096a12ce36a5b39aa18d7ec5da45c05eb3d42dd /src/PolySetEvaluator.h | |
parent | b087e68e5430c3dde6adfe452becbaba0f680196 (diff) | |
parent | dc7eeb30d06a928a30ee47a765be3e5a61288d35 (diff) |
Merge branch 'polyset-cleanup' into visitor
Diffstat (limited to 'src/PolySetEvaluator.h')
-rw-r--r-- | src/PolySetEvaluator.h | 36 |
1 files changed, 20 insertions, 16 deletions
diff --git a/src/PolySetEvaluator.h b/src/PolySetEvaluator.h index 70ec7ed..6319e55 100644 --- a/src/PolySetEvaluator.h +++ b/src/PolySetEvaluator.h @@ -3,39 +3,43 @@ #include "myqhash.h" #include "node.h" +#include "Tree.h" #include <QCache> +#include "memory.h" class PolySetEvaluator { public: - enum EvaluateMode { EVALUATE_CGAL, EVALUATE_OPENCSG }; - PolySetEvaluator() : cache(100) {} - + PolySetEvaluator(const Tree &tree) : tree(tree) {} virtual ~PolySetEvaluator() {} - virtual PolySet *evaluatePolySet(const class ProjectionNode &, AbstractPolyNode::render_mode_e) = 0; - virtual PolySet *evaluatePolySet(const class DxfLinearExtrudeNode &, AbstractPolyNode::render_mode_e) = 0; - virtual PolySet *evaluatePolySet(const class DxfRotateExtrudeNode &, AbstractPolyNode::render_mode_e) = 0; - virtual PolySet *evaluatePolySet(const class CgaladvNode &, AbstractPolyNode::render_mode_e) = 0; - virtual PolySet *evaluatePolySet(const class RenderNode &, AbstractPolyNode::render_mode_e) = 0; + const Tree &getTree() const { return this->tree; } - void clearCache() { - this->cache.clear(); - } + virtual shared_ptr<PolySet> getPolySet(const class AbstractNode &, bool cache); + virtual PolySet *evaluatePolySet(const class ProjectionNode &) { return NULL; } + virtual PolySet *evaluatePolySet(const class DxfLinearExtrudeNode &) { return NULL; } + virtual PolySet *evaluatePolySet(const class DxfRotateExtrudeNode &) { return NULL; } + virtual PolySet *evaluatePolySet(const class CgaladvNode &) { return NULL; } + virtual PolySet *evaluatePolySet(const class RenderNode &) { return NULL; } + + static void clearCache() { + cache.clear(); + } + void printCache(); protected: struct cache_entry { - class PolySet *ps; + shared_ptr<class PolySet> ps; QString msg; - cache_entry(PolySet *ps); - ~cache_entry(); + cache_entry(const shared_ptr<PolySet> &ps); + ~cache_entry() { } }; - QCache<std::string, cache_entry> cache; + static QCache<std::string, cache_entry> cache; private: - static PolySetEvaluator *global_evaluator; + const Tree &tree; }; #endif |