summaryrefslogtreecommitdiffhomepage
path: root/compat/options.cpp
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2016-08-17 21:28:45 +0200
committerStanislaw Halik <sthalik@misaki.pl>2016-08-17 21:34:53 +0200
commitcb33be1c50b68d6022f344ddac923c7aac3a11d5 (patch)
tree1840e3f9829aa69f10f81804f655e97be3f2eca8 /compat/options.cpp
parent41ba8aa5329c16a797140dc23650ef45f42753a3 (diff)
move options framework into its own library
- adjust usages - add support for QList signals and metatype
Diffstat (limited to 'compat/options.cpp')
-rw-r--r--compat/options.cpp269
1 files changed, 0 insertions, 269 deletions
diff --git a/compat/options.cpp b/compat/options.cpp
deleted file mode 100644
index 33c1cf0d..00000000
--- a/compat/options.cpp
+++ /dev/null
@@ -1,269 +0,0 @@
-#include "options.hpp"
-
-namespace options
-{
-
-group::group(const QString& name) : name(name)
-{
- auto conf = ini_file();
- conf->beginGroup(name);
- for (auto& k_ : conf->childKeys())
- {
- auto tmp = k_.toUtf8();
- QString k(tmp);
- kvs[k] = conf->value(k_);
- }
- conf->endGroup();
-}
-
-void group::save() const
-{
- auto s = ini_file();
- s->beginGroup(name);
- for (auto& i : kvs)
- s->setValue(i.first, i.second);
- s->endGroup();
-}
-
-void group::put(const QString &s, const QVariant &d)
-{
- kvs[s] = d;
-}
-
-bool group::contains(const QString &s) const
-{
- return kvs.count(s) != 0;
-}
-
-QString group::ini_directory()
-{
- const auto dirs = QStandardPaths::standardLocations(QStandardPaths::DocumentsLocation);
- if (dirs.size() == 0)
- return "";
- if (QDir(dirs[0]).mkpath(OPENTRACK_ORG))
- return dirs[0] + "/" OPENTRACK_ORG;
- return "";
-}
-
-QString group::ini_filename()
-{
- QSettings settings(OPENTRACK_ORG);
- return settings.value(OPENTRACK_CONFIG_FILENAME_KEY, OPENTRACK_DEFAULT_CONFIG).toString();
-}
-
-QString group::ini_pathname()
-{
- const auto dir = ini_directory();
- if (dir == "")
- return "";
- return dir + "/" + ini_filename();
-}
-
-const QStringList group::ini_list()
-{
- const auto dirname = ini_directory();
- if (dirname == "")
- return QStringList();
- QDir settings_dir(dirname);
- QStringList list = settings_dir.entryList( QStringList { "*.ini" } , QDir::Files, QDir::Name );
- std::sort(list.begin(), list.end());
- return list;
-}
-
-const mem<QSettings> group::ini_file()
-{
- const auto pathname = ini_pathname();
- if (pathname != "")
- return std::make_shared<QSettings>(ini_pathname(), QSettings::IniFormat);
- return std::make_shared<QSettings>();
-}
-
-bool group::operator==(const group& other) const
-{
- for (const auto& kv : kvs)
- {
- const QVariant val = other.get<QVariant>(kv.first);
- if (!other.contains(kv.first) || kv.second != val)
- {
- qDebug() << "bundle" << name << "modified" << "key" << kv.first << "-" << val << "<>" << kv.second;
- return false;
- }
- }
-
- for (const auto& kv : other.kvs)
- {
- const QVariant val = get<QVariant>(kv.first);
- if (!contains(kv.first) || kv.second != val)
- {
- qDebug() << "bundle" << name << "modified" << "key" << kv.first << "-" << kv.second << "<>" << val;
- return false;
- }
- }
- return true;
-}
-
-impl_bundle::impl_bundle(const QString& group_name)
- :
- mtx(QMutex::Recursive),
- group_name(group_name),
- saved(group_name),
- transient(saved)
-{
-}
-
-void impl_bundle::reload()
-{
- {
- QMutexLocker l(&mtx);
- saved = group(group_name);
- transient = saved;
- }
- emit reloading();
-}
-
-void impl_bundle::store_kv(const QString& name, const QVariant& datum)
-{
- QMutexLocker l(&mtx);
-
- transient.put(name, datum);
-}
-
-bool impl_bundle::contains(const QString &name) const
-{
- QMutexLocker l(const_cast<QMutex*>(&mtx));
- return transient.contains(name);
-}
-
-void impl_bundle::save()
-{
- bool modified_ = false;
-
- {
- QMutexLocker l(&mtx);
- if (saved != transient)
- {
- qDebug() << "bundle" << group_name << "changed, saving";
- modified_ = true;
- saved = transient;
- saved.save();
- }
- }
-
- if (modified_)
- emit saving();
-}
-
-bool impl_bundle::modifiedp() const // XXX unused
-{
- QMutexLocker l(const_cast<QMutex*>(&mtx));
- return transient != saved;
-}
-
-base_value::base_value(pbundle b, const QString &name) :
- b(b),
- self_name(name)
-{
-}
-
-opts::~opts()
-{
- b->reload();
-}
-
-opts::opts(const QString &name) : b(bundle(name))
-{
-}
-
-detail::custom_type_initializer::custom_type_initializer()
-{
- qRegisterMetaTypeStreamOperators<slider_value>("slider_value");
- QMetaType::registerDebugStreamOperator<slider_value>();
-}
-
-detail::custom_type_initializer detail::custom_type_initializer::singleton;
-
-namespace detail {
-
-opt_bundle::opt_bundle(const QString& group_name)
- : impl_bundle(group_name)
-{
-}
-
-opt_bundle::~opt_bundle()
-{
- detail::singleton().bundle_decf(group_name);
-}
-
-void opt_singleton::bundle_decf(const opt_singleton::k& key)
-{
- QMutexLocker l(&implsgl_mtx);
-
- if (--std::get<0>(implsgl_data[key]) == 0)
- {
- qDebug() << "bundle -" << key;
-
- implsgl_data.erase(key);
- }
-}
-
-void opt_singleton::after_profile_changed_()
-{
- QMutexLocker l(&implsgl_mtx);
-
- for (auto& kv : implsgl_data)
- {
- tt& tuple = kv.second;
- std::weak_ptr<v>& bundle = std::get<1>(tuple);
-
- mem<v> bundle_ = bundle.lock();
- if (bundle_)
- {
- qDebug() << "bundle: reverting" << kv.first << "due to profile change";
- bundle_->reload();
- }
- }
-}
-
-void opt_singleton::refresh_all_bundles()
-{
- singleton().after_profile_changed_();
-}
-
-opt_singleton::opt_singleton() : implsgl_mtx(QMutex::Recursive)
-{
-}
-
-opt_singleton::~opt_singleton()
-{
- qDebug() << "exit: bundle singleton";
-}
-
-pbundle opt_singleton::bundle(const opt_singleton::k &key)
-{
- QMutexLocker l(&implsgl_mtx);
-
- if (implsgl_data.count(key) != 0)
- {
- auto shared = std::get<1>(implsgl_data[key]).lock();
- if (shared != nullptr)
- return shared;
- }
-
- qDebug() << "bundle +" << key;
-
- auto shr = std::make_shared<v>(key);
- implsgl_data[key] = tt(1, shr);
- return shr;
-}
-
-OPENTRACK_COMPAT_EXPORT opt_singleton& singleton()
-{
- static opt_singleton ret;
- return ret;
-}
-
-
-} // end options::detail
-
-} // end options
-