summaryrefslogtreecommitdiff
path: root/src/feature.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/feature.h
parent8dca991045a9f0563e6b654b1b946e5d778e8fd2 (diff)
parentc4a1d855f11d076d30e98f799315446da021514a (diff)
Merge branch 'master' of github.com:openscad/openscad
Diffstat (limited to 'src/feature.h')
-rw-r--r--src/feature.h44
1 files changed, 44 insertions, 0 deletions
diff --git a/src/feature.h b/src/feature.h
new file mode 100644
index 0000000..20b4f16
--- /dev/null
+++ b/src/feature.h
@@ -0,0 +1,44 @@
+#ifndef FEATURE_H_
+#define FEATURE_H_
+
+#include <stdio.h>
+#include <iostream>
+#include <string>
+#include <map>
+#include <vector>
+
+class Feature
+{
+public:
+ typedef std::vector<Feature *> list_t;
+ typedef list_t::iterator iterator;
+
+ static const Feature ExperimentalConcatFunction;
+
+ const std::string& get_name() const;
+ const std::string& get_description() const;
+
+ bool is_enabled() const;
+ void enable(bool status);
+
+ static iterator begin();
+ static iterator end();
+
+ static void dump_features();
+ static void enable_feature(const std::string &feature_name, bool status = true);
+
+private:
+ bool enabled;
+
+ const std::string name;
+ const std::string description;
+
+ typedef std::map<std::string, Feature *> map_t;
+ static map_t feature_map;
+ static list_t feature_list;
+
+ Feature(const std::string &name, const std::string &description);
+ virtual ~Feature();
+};
+
+#endif
contact: Jan Huwald // Impressum