X-Git-Url: https://sigrok.org/gitweb/?p=pulseview.git;a=blobdiff_plain;f=pv%2Fglobalsettings.hpp;h=51212b023ab19f2e79145d991117bf804c707904;hp=201c5e20a9fc23f95b72f0d2f0cf2b546f9cee0c;hb=eaa02ef436fb9d8217a94076e1258da47d3cd8e0;hpb=4433246b9ef4247ff469ae7307606a6d872c573f diff --git a/pv/globalsettings.hpp b/pv/globalsettings.hpp index 201c5e20..51212b02 100644 --- a/pv/globalsettings.hpp +++ b/pv/globalsettings.hpp @@ -20,7 +20,6 @@ #ifndef PULSEVIEW_GLOBALSETTINGS_HPP #define PULSEVIEW_GLOBALSETTINGS_HPP -#include #include #include @@ -29,12 +28,18 @@ #include #include -using std::function; using std::map; -using std::multimap; +using std::vector; namespace pv { +class GlobalSettingsInterface +{ +public: + virtual void on_setting_changed(const QString &key, const QVariant &value) = 0; +}; + + class GlobalSettings : public QSettings { Q_OBJECT @@ -42,22 +47,31 @@ class GlobalSettings : public QSettings public: static const QString Key_View_ZoomToFitDuringAcq; static const QString Key_View_ZoomToFitAfterAcq; + static const QString Key_View_TriggerIsZeroTime; static const QString Key_View_ColouredBG; static const QString Key_View_StickyScrolling; static const QString Key_View_ShowSamplingPoints; static const QString Key_View_ShowAnalogMinorGrid; - static const QString Key_View_ShowConversionThresholds; + static const QString Key_View_ConversionThresholdDispMode; static const QString Key_View_DefaultDivHeight; static const QString Key_View_DefaultLogicHeight; static const QString Key_Dec_InitialStateConfigurable; + static const QString Key_Log_BufferSize; + static const QString Key_Log_NotifyOfStacktrace; + + enum ConvThrDispMode { + ConvThrDispMode_None = 0, + ConvThrDispMode_Background, + ConvThrDispMode_Dots + }; public: GlobalSettings(); void set_defaults_where_needed(); - static void register_change_handler(const QString key, - function cb); + static void add_change_handler(GlobalSettingsInterface *cb); + static void remove_change_handler(GlobalSettingsInterface *cb); void setValue(const QString& key, const QVariant& value); @@ -84,7 +98,7 @@ public: static GVariant* restore_gvariant(QSettings &settings); private: - static multimap< QString, function > callbacks_; + static vector callbacks_; static bool tracking_; static map tracked_changes_;