Add a hotkey to show/hide sampling points.
[pulseview.git] / pv / globalsettings.cpp
index 5da89ceba030bf66df5757d4ef0a318a5dc61735..e0b7197b966c4c1f1f1841c0651f4d85823e9cd7 100644 (file)
@@ -23,8 +23,12 @@ namespace pv {
 
 const QString GlobalSettings::Key_View_AlwaysZoomToFit = "View_AlwaysZoomToFit";
 const QString GlobalSettings::Key_View_ColouredBG = "View_ColouredBG";
+const QString GlobalSettings::Key_View_StickyScrolling = "View_StickyScrolling";
+const QString GlobalSettings::Key_View_ShowSamplingPoints = "View_ShowSamplingPoints";
 
 std::multimap< QString, std::function<void(QVariant)> > GlobalSettings::callbacks_;
+bool GlobalSettings::tracking_ = false;
+std::map<QString, QVariant> GlobalSettings::tracked_changes_;
 
 GlobalSettings::GlobalSettings() :
        QSettings()
@@ -40,6 +44,11 @@ void GlobalSettings::register_change_handler(const QString key,
 
 void GlobalSettings::setValue(const QString &key, const QVariant &value)
 {
+       // Save previous value if we're tracking changes,
+       // not altering an already-existing saved setting
+       if (tracking_)
+               tracked_changes_.emplace(key, QSettings::value(key));
+
        QSettings::setValue(key, value);
 
        // Call all registered callbacks for this key
@@ -49,5 +58,26 @@ void GlobalSettings::setValue(const QString &key, const QVariant &value)
                it->second(value);
 }
 
+void GlobalSettings::start_tracking()
+{
+       tracking_ = true;
+       tracked_changes_.clear();
+}
+
+void GlobalSettings::stop_tracking()
+{
+       tracking_ = false;
+       tracked_changes_.clear();
+}
+
+void GlobalSettings::undo_tracked_changes()
+{
+       tracking_ = false;
+
+       for (auto entry : tracked_changes_)
+               setValue(entry.first, entry.second);
+
+       tracked_changes_.clear();
+}
 
 } // namespace pv