diff options
-rw-r--r-- | gui/main-window.cpp | 9 | ||||
-rw-r--r-- | options/scoped.cpp | 44 | ||||
-rw-r--r-- | options/scoped.hpp | 9 |
3 files changed, 56 insertions, 6 deletions
diff --git a/gui/main-window.cpp b/gui/main-window.cpp index 1730a806..43b7158b 100644 --- a/gui/main-window.cpp +++ b/gui/main-window.cpp @@ -474,7 +474,7 @@ void MainWindow::stopTracker() if (!work) return; - //ui.game_name->setText("Not connected"); + opts::set_teardown_flag(true); // XXX hack -sh 20160926 pose_update_timer.stop(); ui.pose_display->rotateBy_real(0, 0, 0, 0, 0, 0); @@ -488,8 +488,6 @@ void MainWindow::stopTracker() if (pFilterDialog) pFilterDialog->unregister_filter(); - save_modules(); - work = nullptr; libs = SelectedLibraries(); @@ -497,10 +495,11 @@ void MainWindow::stopTracker() double p[6] = {0,0,0, 0,0,0}; display_pose(p, p); } - updateButtonState(false, false); - set_title(); + opts::set_teardown_flag(false); // XXX hack -sh 20160926 + updateButtonState(false, false); + set_title(); ui.btnStartTracker->setFocus(); } diff --git a/options/scoped.cpp b/options/scoped.cpp index e1ddbae2..b0677ad9 100644 --- a/options/scoped.cpp +++ b/options/scoped.cpp @@ -1,10 +1,52 @@ #include "scoped.hpp" +#include <QApplication> +#include <QThread> + +// for std::abort() +#include <cstdlib> + +#include <QDebug> namespace options { +std::atomic_bool opts::teardown_flag(false); + +void opts::set_teardown_flag(bool value) +{ + ensure_thread(); + + // we don't use exceptions in the whole project so no need for unwind protection + // also the calls aren't nested so no need for CAS either + teardown_flag = value; +} + +void opts::ensure_thread() +{ + // only as a bug check + + const QThread* ui_thread = qApp->thread(); + const QThread* curthread = QThread::currentThread(); + + if (ui_thread == nullptr) + abort(); + + if (ui_thread != curthread) + abort(); +} + opts::~opts() { - b->reload(); + if (!is_tracker_teardown()) + b->reload(); +#if 0 + else + qDebug() << "in teardown, not reloading" << b->name(); +#endif +} + +bool opts::is_tracker_teardown() +{ + return teardown_flag; } opts::opts(const QString &name) : b(make_bundle(name)) diff --git a/options/scoped.hpp b/options/scoped.hpp index 52ae383d..4ad51fea 100644 --- a/options/scoped.hpp +++ b/options/scoped.hpp @@ -5,6 +5,8 @@ #include "export.hpp" +#include <atomic> + namespace options { struct OPENTRACK_OPTIONS_EXPORT opts @@ -14,6 +16,13 @@ struct OPENTRACK_OPTIONS_EXPORT opts opts& operator=(const opts&) = delete; opts(const opts&) = delete; ~opts(); + + // XXX hack: the flag shouldn't be here as action at distance -sh 20160926 + static void set_teardown_flag(bool value); +private: + static std::atomic_bool teardown_flag; + static bool is_tracker_teardown(); + static void ensure_thread(); }; } |