|
@@ -3,6 +3,7 @@
|
|
|
|
|
|
#include <QQueue>
|
|
|
#include <QString>
|
|
|
+#include <QVector>
|
|
|
#include <memory>
|
|
|
#include <variant>
|
|
|
#include <vector>
|
|
@@ -40,6 +41,16 @@ static constexpr const char* DATETIME = "DateTime";
|
|
|
static constexpr const char* BOOLEAN = "Boolean";
|
|
|
} // namespace Type
|
|
|
|
|
|
+namespace VariantIndex {
|
|
|
+static const uint8_t BOOLEAN = 0;
|
|
|
+static const uint8_t INTEGER = 1;
|
|
|
+static const uint8_t QSTRING = 2;
|
|
|
+static const uint8_t STRVEC = 3;
|
|
|
+static const uint8_t FILEVEC = 4;
|
|
|
+} // namespace VariantIndex
|
|
|
+
|
|
|
+inline bool isIndex(uint8_t v, uint8_t i) { return v == i; }
|
|
|
+
|
|
|
/**
|
|
|
* Forward Declarations
|
|
|
*/
|
|
@@ -50,18 +61,23 @@ class Task;
|
|
|
* Aliases
|
|
|
*/
|
|
|
using ArgumentType = const char*;
|
|
|
-using TypeVariant = std::variant<QString, bool, std::vector<std::string>, std::vector<KFileData>>;
|
|
|
+using TypeVariant = std::variant<bool, int, QString, QVector<QString>, std::vector<KFileData>>;
|
|
|
using TaskIterator = std::vector<std::unique_ptr<TaskArgumentBase>>::iterator;
|
|
|
using TaskArguments = std::vector<std::unique_ptr<TaskArgumentBase>>;
|
|
|
using TaskQueue = QQueue<Task>;
|
|
|
+using ArgumentValues = QVector<const QString>;
|
|
|
|
|
|
/**
|
|
|
* The interface expected on our Task Arguments
|
|
|
*/
|
|
|
class TaskArgumentBase {
|
|
|
public:
|
|
|
- virtual QString text() const = 0;
|
|
|
virtual void setValue(TypeVariant v) = 0;
|
|
|
+ virtual TypeVariant getValue() = 0;
|
|
|
+ virtual const QString text() = 0;
|
|
|
+ virtual void clear() = 0;
|
|
|
+ virtual const QString getStringValue() = 0;
|
|
|
+ virtual bool isContainer() = 0;
|
|
|
};
|
|
|
|
|
|
/**
|
|
@@ -70,7 +86,7 @@ class TaskArgumentBase {
|
|
|
* A templated class providing a generic way for handling arguments whose types can be one from the set defined
|
|
|
* by our TypeVariant alias
|
|
|
*/
|
|
|
-template <typename T>
|
|
|
+template <typename T = TypeVariant>
|
|
|
class TaskArgument : TaskArgumentBase {
|
|
|
public:
|
|
|
TaskArgument(QString n, ArgumentType t, T _value) {
|
|
@@ -89,7 +105,7 @@ class TaskArgument : TaskArgumentBase {
|
|
|
* text
|
|
|
* @returns {QString} The name of the argument
|
|
|
*/
|
|
|
- virtual QString text() const { return name; }
|
|
|
+ virtual const QString text() { return name; }
|
|
|
|
|
|
/**
|
|
|
* setValue
|
|
@@ -97,10 +113,40 @@ class TaskArgument : TaskArgumentBase {
|
|
|
*/
|
|
|
virtual void setValue(TypeVariant new_value) override { value = new_value; }
|
|
|
|
|
|
+ virtual const QString getStringValue() override {
|
|
|
+ if (isIndex(value.index(), VariantIndex::QSTRING)) {
|
|
|
+ return value;
|
|
|
+ } else if (isIndex(value.index(), VariantIndex::BOOLEAN)) {
|
|
|
+ return QString::number(value);
|
|
|
+ } else if (isIndex(value.index(), VariantIndex::INTEGER)) {
|
|
|
+ return QString::number(value);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ virtual TypeVariant getValue() override { return std::get<value.index()>(value); }
|
|
|
+
|
|
|
+ virtual void clear() override {
|
|
|
+ if (isIndex(value.index(), VariantIndex::STRVEC)) {
|
|
|
+ std::get<VariantIndex::STRVEC>(value).clear();
|
|
|
+ } else if (isIndex(value.index(), VariantIndex::FILEVEC)) {
|
|
|
+ std::get<VariantIndex::FILEVEC>(value).clear();
|
|
|
+ } else if (isIndex(value.index(), VariantIndex::QSTRING)) {
|
|
|
+ std::get<VariantIndex::QSTRING>(value).clear();
|
|
|
+ } else if (isIndex(value.index(), VariantIndex::INTEGER)) {
|
|
|
+ std::get<VariantIndex::INTEGER>(value) = 0;
|
|
|
+ } else if (isIndex(value.index(), VariantIndex::BOOLEAN)) {
|
|
|
+ std::get<VariantIndex::STRVEC>(value) = false;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ virtual bool isContainer() override {
|
|
|
+ return (isIndex(value.index(), VariantIndex::STRVEC) || isIndex(value.index(), VariantIndex::FILEVEC));
|
|
|
+ }
|
|
|
+
|
|
|
private:
|
|
|
QString name;
|
|
|
ArgumentType type;
|
|
|
- T value;
|
|
|
+ TypeVariant value;
|
|
|
};
|
|
|
|
|
|
/**
|
|
@@ -108,8 +154,12 @@ class TaskArgument : TaskArgumentBase {
|
|
|
*/
|
|
|
class Task {
|
|
|
public:
|
|
|
- virtual void defineTaskArguments() = 0;
|
|
|
+ virtual void setArgument(QString name, TypeVariant arg) = 0;
|
|
|
virtual const TaskArguments getTaskArguments() = 0;
|
|
|
+ virtual TypeVariant getTaskArgument(QString name) = 0;
|
|
|
+ virtual ArgumentValues getArgumentValues() = 0;
|
|
|
+ virtual void defineTaskArguments() = 0;
|
|
|
+ virtual void setDefaultValues() = 0;
|
|
|
virtual bool isReady() = 0;
|
|
|
virtual void clear() = 0;
|
|
|
virtual ~Task(){};
|