aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--debian/changelog8
-rw-r--r--src/volume-control-pulse.vala36
2 files changed, 27 insertions, 17 deletions
diff --git a/debian/changelog b/debian/changelog
index 47627b2..dff996c 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -1,3 +1,11 @@
+indicator-sound (12.10.2+15.04.20150421-0ubuntu1) vivid; urgency=medium
+
+ [ Ted Gould ]
+ * Always record the volume whether we do something with it or not (LP:
+ #1446703) (LP: #1446703)
+
+ -- CI Train Bot <ci-train-bot@canonical.com> Tue, 21 Apr 2015 23:46:48 +0000
+
indicator-sound (12.10.2+15.04.20150413-0ubuntu1) vivid; urgency=medium
[ CI Train Bot ]
diff --git a/src/volume-control-pulse.vala b/src/volume-control-pulse.vala
index 050318b..3d4d113 100644
--- a/src/volume-control-pulse.vala
+++ b/src/volume-control-pulse.vala
@@ -616,25 +616,27 @@ public class VolumeControlPulse : VolumeControl
return _volume;
}
set {
- if (value.volume != _volume.volume) {
- debug("Setting volume to %f for profile %d because %d", value.volume, _active_sink_input, value.reason);
-
- var old_high_volume = this.high_volume;
- _volume = value;
-
- /* Make sure we're connected to Pulse and pulse didn't give us the change */
- if (context.get_state () == Context.State.READY &&
- _volume.reason != VolumeControl.VolumeReasons.PULSE_CHANGE)
- if (_pulse_use_stream_restore)
- set_volume_active_role.begin ();
- else
- context.get_server_info (server_info_cb_for_set_volume);
+ var volume_changed = (value.volume != _volume.volume);
+ debug("Setting volume to %f for profile %d because %d", value.volume, _active_sink_input, value.reason);
+
+ var old_high_volume = this.high_volume;
+ _volume = value;
+
+ /* Make sure we're connected to Pulse and pulse didn't give us the change */
+ if (context.get_state () == Context.State.READY &&
+ _volume.reason != VolumeControl.VolumeReasons.PULSE_CHANGE &&
+ volume_changed)
+ if (_pulse_use_stream_restore)
+ set_volume_active_role.begin ();
+ else
+ context.get_server_info (server_info_cb_for_set_volume);
- if (this.high_volume != old_high_volume)
- this.notify_property("high-volume");
+ if (this.high_volume != old_high_volume)
+ this.notify_property("high-volume");
- if (volume.reason != VolumeControl.VolumeReasons.ACCOUNTS_SERVICE_SET)
- start_local_volume_timer();
+ if (volume.reason != VolumeControl.VolumeReasons.ACCOUNTS_SERVICE_SET
+ && volume_changed) {
+ start_local_volume_timer();
}
}
}