summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--hscript/script.cc76
-rw-r--r--hscript/script.hh22
2 files changed, 98 insertions, 0 deletions
diff --git a/hscript/script.cc b/hscript/script.cc
index 10dfe6b..0bc6b8a 100644
--- a/hscript/script.cc
+++ b/hscript/script.cc
@@ -317,4 +317,80 @@ const Script *Script::load(std::istream &sstream,
#undef PARSER_ERROR
}
+/* LCOV_EXCL_START */
+const Keys::Key *Script::getOneValue(std::string name) const {
+ if(name == "network") {
+ return this->internal->network.get();
+ } else if(name == "hostname") {
+ return this->internal->hostname.get();
+ } else if(name == "arch") {
+ return this->internal->arch.get();
+ } else if(name == "rootpw") {
+ return this->internal->rootpw.get();
+ } else if(name == "language") {
+ return this->internal->lang.get();
+ } else if(name == "keymap") {
+ return this->internal->keymap.get();
+ } else if(name == "firmware") {
+#ifdef NON_LIBRE_FIRMWARE
+ return this->internal->firmware.get();
+#else /* !NON_LIBRE_FIRMWARE */
+ return nullptr;
+#endif /* NON_LIBRE_FIRMWARE */
+ } else if(name == "timezone") {
+ return this->internal->tzone.get();
+ }
+
+ assert("Unknown key given to getOneValue." == nullptr);
+ return nullptr;
+}
+
+const std::vector<Keys::Key *> Script::getValues(std::string name) const {
+ std::vector<Keys::Key *> values;
+
+ if(name == "netaddress") {
+ for(auto &addr : this->internal->addresses) values.push_back(addr.get());
+ } else if(name == "nameserver") {
+ for(auto &ns : this->internal->nses) values.push_back(ns.get());
+ } else if(name == "netssid") {
+ for(auto &ssid : this->internal->ssids) values.push_back(ssid.get());
+ } else if(name == "pkginstall") {
+ /* XXX */
+ } else if(name == "repository") {
+ for(auto &repo : this->internal->repos) values.push_back(repo.get());
+ } else if(name == "signing_key") {
+ for(auto &key : this->internal->repo_keys) values.push_back(key.get());
+ } else if(name == "username" || name == "useralias" || name == "userpw" ||
+ name == "usericon" || name == "usergroups") {
+ /* XXX */
+ } else if(name == "diskid") {
+ for(auto &id : this->internal->diskids) values.push_back(id.get());
+ } else if(name == "disklabel") {
+ for(auto &label : this->internal->disklabels) values.push_back(label.get());
+ } else if(name == "partition") {
+ for(auto &part : this->internal->partitions) values.push_back(part.get());
+ } else if(name == "lvm_pv") {
+ for(auto &pv : this->internal->lvm_pvs) values.push_back(pv.get());
+ } else if(name == "lvm_vg") {
+ for(auto &vg : this->internal->lvm_vgs) values.push_back(vg.get());
+ } else if(name == "lvm_lv") {
+ for(auto &lv : this->internal->lvm_lvs) values.push_back(lv.get());
+ } else if(name == "encrypt") {
+ /* XXX */
+ } else if(name == "fs") {
+ for(auto &fs : this->internal->fses) values.push_back(fs.get());
+ } else if(name == "mount") {
+ for(auto &mnt : this->internal->mounts) values.push_back(mnt.get());
+ } else {
+ assert("Unknown key given to getValues." == nullptr);
+ }
+
+ return values;
+}
+/* LCOV_EXCL_STOP */
+
+ScriptOptions Script::options() const {
+ return this->opts;
+}
+
}
diff --git a/hscript/script.hh b/hscript/script.hh
index 9fd186a..8cf6c2a 100644
--- a/hscript/script.hh
+++ b/hscript/script.hh
@@ -20,6 +20,12 @@
namespace Horizon {
+namespace Keys {
+
+class Key;
+
+}
+
/**** Script option flags ****/
enum ScriptOptionFlags {
@@ -74,6 +80,22 @@ public:
/*! Executes the HorizonScript. */
bool execute() const;
+ /*! Retrieve the value of a specified key in this HorizonScript.
+ * @param name The name of the key to retrieve.
+ * @return The key object, if one exists. nullptr if the key has not been
+ * specified.
+ */
+ const Keys::Key *getOneValue(std::string name) const;
+
+ /*! Retrieve all values for a specified key in this HorizonScript.
+ * @param name The name of the key to retrieve.
+ * @return A std::vector of the key objects. The vector may be empty if
+ * no values exist for the specified key.
+ */
+ const std::vector<Keys::Key *> getValues(std::string name) const;
+
+ /*! Retrieve the options set for this HorizonScript object. */
+ ScriptOptions options() const;
private:
struct ScriptPrivate;
/*! Internal data. */