aboutsummaryrefslogtreecommitdiff
path: root/src/volume-warning.vala
diff options
context:
space:
mode:
Diffstat (limited to 'src/volume-warning.vala')
-rw-r--r--src/volume-warning.vala28
1 files changed, 15 insertions, 13 deletions
diff --git a/src/volume-warning.vala b/src/volume-warning.vala
index 49ed3a8..d475570 100644
--- a/src/volume-warning.vala
+++ b/src/volume-warning.vala
@@ -105,27 +105,29 @@ public abstract class VolumeWarning : Object
**/
private void init_high_volume () {
- _options.loud_changed.connect(() => update_high_volume());
this.notify["multimedia-volume"].connect(() => update_high_volume());
this.notify["multimedia-active"].connect(() => update_high_volume());
this.notify["headphones-active"].connect(() => update_high_volume());
this.notify["high-volume-approved"].connect(() => update_high_volume());
+ _options.notify["loud-volume"].connect(() => update_high_volume());
+ _options.notify["loud-warning-enabled"].connect(() => update_high_volume());
update_high_volume();
}
private void update_high_volume () {
- PulseAudio.Volume mm_vol = multimedia_volume;
- var approved = high_volume_approved;
- var hp_active = headphones_active;
- var mm_active = multimedia_active;
- GLib.message("calculating high volume... headphones_active %d high_volume_approved %d multimedia_active %d multimedia_volume %d is_invalid %d, is_loud %d", (int)hp_active, (int)approved, (int)mm_active, (int)mm_vol, (int)(mm_vol == PulseAudio.Volume.INVALID), (int)_options.is_loud_pulse(mm_vol));
- var new_high_volume = hp_active && !approved && mm_active && (mm_vol != PulseAudio.Volume.INVALID) && _options.is_loud_pulse(mm_vol);
- GLib.message("so the new high_volume is %d, was %d", (int)new_high_volume, (int)high_volume);
- if (high_volume != new_high_volume) {
- debug("changing high_volume from %d to %d", (int)high_volume, (int)new_high_volume);
- if (new_high_volume && !active)
+
+ var newval = _options.loud_warning_enabled
+ && headphones_active
+ && multimedia_active
+ && !high_volume_approved
+ && (multimedia_volume != PulseAudio.Volume.INVALID)
+ && (multimedia_volume >= _options.loud_volume);
+
+ if (high_volume != newval) {
+ debug("changing high_volume from %d to %d", (int)high_volume, (int)newval);
+ if (newval && !active)
show();
- high_volume = new_high_volume;
+ high_volume = newval;
}
}
@@ -202,7 +204,7 @@ public abstract class VolumeWarning : Object
this.active = true;
// lower the volume to just under the warning level
- sound_system_set_multimedia_volume (_options.loud_volume()-1);
+ sound_system_set_multimedia_volume (_options.loud_volume-1);
}
private void on_user_response(IndicatorSound.WarnNotification.Response response) {