summaryrefslogtreecommitdiff
path: root/hscript/key.hh
diff options
context:
space:
mode:
authorA. Wilcox <AWilcox@Wilcox-Tech.com>2019-10-05 19:41:35 -0500
committerA. Wilcox <AWilcox@Wilcox-Tech.com>2019-10-05 19:41:35 -0500
commita531cdb8c1e6c47e675f6c256012e61812ce0a44 (patch)
tree2645905f4b60866f1d329217035a6dce72b5ca7f /hscript/key.hh
parent18700b31ed2bc43d5e76ee128d9d68b82dab798e (diff)
downloadhorizon-a531cdb8c1e6c47e675f6c256012e61812ce0a44.tar.gz
horizon-a531cdb8c1e6c47e675f6c256012e61812ce0a44.tar.bz2
horizon-a531cdb8c1e6c47e675f6c256012e61812ce0a44.tar.xz
horizon-a531cdb8c1e6c47e675f6c256012e61812ce0a44.zip
Initial prototype for a script parsing API
Diffstat (limited to 'hscript/key.hh')
-rw-r--r--hscript/key.hh45
1 files changed, 45 insertions, 0 deletions
diff --git a/hscript/key.hh b/hscript/key.hh
new file mode 100644
index 0000000..06d34f8
--- /dev/null
+++ b/hscript/key.hh
@@ -0,0 +1,45 @@
+/*
+ * key.hh - Definition of the base Key class
+ * libhscript, the HorizonScript library for
+ * Project Horizon
+ *
+ * Copyright (c) 2019 Adélie Linux and contributors. All rights reserved.
+ * This code is licensed under the AGPL 3.0 license, as noted in the
+ * LICENSE-code file in the root directory of this repository.
+ *
+ * SPDX-License-Identifier: AGPL-3.0-only
+ */
+
+#include <string>
+
+namespace Horizon {
+namespace Keys {
+
+/*! Base Key class, used by all Keys.
+ * A Getter method is not provided in this base Key class, because each Key may
+ * return a different type of data. For example, `network` may return `bool`.
+ */
+class Key {
+public:
+ /*! Create an instance of the Key. */
+ static Key *create();
+
+ /*! Set the data associated with the Key. */
+ void setData(std::string data);
+
+ /*! Determines if the data associated with the Key is valid. */
+ bool isValid();
+
+ /*! Determines if the Key is required to be present for the HorizonScript
+ * to be considered valid. */
+ static bool isRequired();
+
+ /*! Determines how many times this Key can be repeated.
+ * If this function returns 0, it can be repeated an unlimited number of times.
+ * If this function returns 1, it can only be present once per HorizonScript.
+ */
+ static int maxCount();
+};
+
+}
+}