aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorCharles Kerr <charles.kerr@canonical.com>2014-07-31 16:48:00 -0500
committerCharles Kerr <charles.kerr@canonical.com>2014-07-31 16:48:00 -0500
commit4148750ea93e67e5d9aaa15ebc8e3c7a5a5554f1 (patch)
tree377c816b3c5401a9571573661aad8a6f09974c4c /src
parent43e0fb826aa3a5acfd8937438989231804b4c400 (diff)
downloadayatana-indicator-datetime-4148750ea93e67e5d9aaa15ebc8e3c7a5a5554f1.tar.gz
ayatana-indicator-datetime-4148750ea93e67e5d9aaa15ebc8e3c7a5a5554f1.tar.bz2
ayatana-indicator-datetime-4148750ea93e67e5d9aaa15ebc8e3c7a5a5554f1.zip
configurable haptic mode, part 1 of 3: add haptic feedback mode to the GSettings schema and to our Settings object
Diffstat (limited to 'src')
-rw-r--r--src/settings-live.cpp14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/settings-live.cpp b/src/settings-live.cpp
index 71bbd96..a8338ed 100644
--- a/src/settings-live.cpp
+++ b/src/settings-live.cpp
@@ -55,6 +55,7 @@ LiveSettings::LiveSettings():
update_alarm_sound();
update_alarm_volume();
update_alarm_duration();
+ update_alarm_haptic();
// now listen for clients to change the properties s.t. we can sync update GSettings
@@ -130,6 +131,10 @@ LiveSettings::LiveSettings():
alarm_duration.changed().connect([this](unsigned int value){
g_settings_set_uint(m_settings, SETTINGS_ALARM_DURATION_S, value);
});
+
+ alarm_haptic.changed().connect([this](const std::string& value){
+ g_settings_set_string(m_settings, SETTINGS_ALARM_HAPTIC_S, value.c_str());
+ });
}
/***
@@ -237,6 +242,13 @@ void LiveSettings::update_alarm_duration()
alarm_duration.set(g_settings_get_uint(m_settings, SETTINGS_ALARM_DURATION_S));
}
+void LiveSettings::update_alarm_haptic()
+{
+ auto val = g_settings_get_string(m_settings, SETTINGS_ALARM_HAPTIC_S);
+ alarm_haptic.set(val);
+ g_free(val);
+}
+
/***
****
***/
@@ -284,6 +296,8 @@ void LiveSettings::update_key(const std::string& key)
update_alarm_volume();
else if (key == SETTINGS_ALARM_DURATION_S)
update_alarm_duration();
+ else if (key == SETTINGS_ALARM_HAPTIC_S)
+ update_alarm_haptic();
}
/***