From d13f6df5ec3566c8e6a999427fd302f74c4754ec Mon Sep 17 00:00:00 2001 From: Simon Rettberg Date: Tue, 9 Jul 2019 11:34:34 +0200 Subject: asfdöklgjsdflgkjt --- src/virtualizer.cpp | 31 +++++++++++++++++++++++++++++++ src/virtualizer.h | 30 ++++++++++++++++++++++++++++++ 2 files changed, 61 insertions(+) create mode 100644 src/virtualizer.cpp create mode 100644 src/virtualizer.h diff --git a/src/virtualizer.cpp b/src/virtualizer.cpp new file mode 100644 index 0000000..521f885 --- /dev/null +++ b/src/virtualizer.cpp @@ -0,0 +1,31 @@ +#include "virtualizer.h" +#include "config.h" + +#include +#include + +static QMap virtMap; + +static bool query(const QString &id) { + static const QString runVirt = Config::get(Config::RUNSCRIPT); + QProcess proc; + proc.start(runVirt, QStringList() << QStringLiteral("--query") << id); + // XXX: This should really only take about a millisecond, but it could be made async too + // and then once the result arrives, redraw the TreeView. Since the result is cached + // per virtualizer, it doesn't seem worth the effort right now. + return proc.waitForFinished(1000) && proc.exitCode() == 0; +} + +Virtualizer::Virtualizer(const QString &id) + : id(id), isAvailable(query(id)) { + +} + +const Virtualizer* Virtualizer::get(const QString &id) { + if (virtMap.contains(id)) { + return virtMap[id]; + } + Virtualizer *v = new Virtualizer(id); + virtMap.insert(id, v); + return v; +} diff --git a/src/virtualizer.h b/src/virtualizer.h new file mode 100644 index 0000000..7b3fc76 --- /dev/null +++ b/src/virtualizer.h @@ -0,0 +1,30 @@ +#ifndef _VIRTUALIZER_H_ +#define _VIRTUALIZER_H_ + +#include + +class Virtualizer +{ + +public: + /** + * Get instance representing given virtualizer. + * Never returns null. + */ + static const Virtualizer* get(const QString &id); + + /** + * The ID if the virtualizer + */ + const QString id; + /** + * Does a plugin exist for this virtualizer type? + */ + const bool isAvailable; + +private: + explicit Virtualizer(const QString &id); + +}; + +#endif -- cgit v1.2.3-55-g7522