summaryrefslogtreecommitdiff
path: root/src/function.h
diff options
context:
space:
mode:
authorMarius Kintel <marius@kintel.net>2014-01-03 18:58:13 (GMT)
committerMarius Kintel <marius@kintel.net>2014-01-03 18:58:13 (GMT)
commit064247ae5e3975c3e9f529f4a4c4a0546892d96f (patch)
treeb2a11e24e73a26fc4f6551982a1677d261dea9e5 /src/function.h
parent8dca991045a9f0563e6b654b1b946e5d778e8fd2 (diff)
parentc4a1d855f11d076d30e98f799315446da021514a (diff)
Merge branch 'master' of github.com:openscad/openscad
Diffstat (limited to 'src/function.h')
-rw-r--r--src/function.h9
1 files changed, 9 insertions, 0 deletions
diff --git a/src/function.h b/src/function.h
index a1fde3c..2491809 100644
--- a/src/function.h
+++ b/src/function.h
@@ -3,13 +3,21 @@
#include "value.h"
#include "typedefs.h"
+#include "feature.h"
+
#include <string>
#include <vector>
+
class AbstractFunction
{
+private:
+ const Feature *feature;
public:
+ AbstractFunction() : feature(NULL) {}
+ AbstractFunction(const Feature& feature) : feature(&feature) {}
virtual ~AbstractFunction();
+ virtual bool is_enabled() const { return (feature == NULL) || feature->is_enabled(); };
virtual Value evaluate(const class Context *ctx, const class EvalContext *evalctx) const;
virtual std::string dump(const std::string &indent, const std::string &name) const;
};
@@ -21,6 +29,7 @@ public:
eval_func_t eval_func;
BuiltinFunction(eval_func_t f) : eval_func(f) { }
+ BuiltinFunction(eval_func_t f, const Feature& feature) : AbstractFunction(feature), eval_func(f) { }
virtual ~BuiltinFunction();
virtual Value evaluate(const Context *ctx, const EvalContext *evalctx) const;
contact: Jan Huwald // Impressum