diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/volume-warning.vala | 89 |
1 files changed, 46 insertions, 43 deletions
diff --git a/src/volume-warning.vala b/src/volume-warning.vala index 5aca45e..869020e 100644 --- a/src/volume-warning.vala +++ b/src/volume-warning.vala @@ -33,14 +33,6 @@ public class VolumeWarning : Object // true if we're playing unapproved loud multimedia over headphones public bool high_volume { get; protected set; default = false; } - // true if the active sink input has its role property set to multimedia - protected bool multimedia_active { get; set; default = false; } - - // true if the user has approved high volumes recently - protected bool high_volume_approved { get; set; default = false; } - - protected PulseAudio.Volume multimedia_volume { get; set; default = PulseAudio.Volume.MUTED; } - public enum Key { VOLUME_UP, VOLUME_DOWN @@ -51,8 +43,7 @@ public class VolumeWarning : Object on_user_response(IndicatorSound.WarnNotification.Response.CANCEL); } - public VolumeWarning (IndicatorSound.Options options) - { + public VolumeWarning (IndicatorSound.Options options) { _options = options; if (loop == null) @@ -70,6 +61,43 @@ public class VolumeWarning : Object **** ***/ + // true if the user has approved high volumes recently + protected bool high_volume_approved { get; set; default = false; } + + // true if the active sink input has its role property set to multimedia + protected bool multimedia_active { get; set; default = false; } + + // the multimedia volume + protected PulseAudio.Volume multimedia_volume { get; set; default = PulseAudio.Volume.MUTED; } + + // true if headphones are currently in use + protected bool headphones_active { get; set; default = false; } + + protected virtual async void set_pulse_multimedia_volume(PulseAudio.Volume volume) + { + var objp = _multimedia_objp; + if (objp == null) + return; + + try { + var builder = new VariantBuilder (new VariantType ("a(uu)")); + builder.add ("(uu)", 0, volume); + + yield _pconn.call ("org.PulseAudio.Ext.StreamRestore1.RestoreEntry", + objp, "org.freedesktop.DBus.Properties", "Set", + new Variant ("(ssv)", "org.PulseAudio.Ext.StreamRestore1.RestoreEntry", "Volume", builder), + null, DBusCallFlags.NONE, -1); + + debug ("Set multimedia volume to %d on path %s", (int)volume, objp); + } catch (GLib.Error e) { + warning ("unable to set volume for stream obj path %s (%s)", objp, e.message); + } + } + + /*** + **** + ***/ + /* this is static to ensure it being freed after @context (loop does not have ref counting) */ private static PulseAudio.GLibMainLoop loop; @@ -94,7 +122,6 @@ public class VolumeWarning : Object private string? _objp_role_phone = null; private uint _pa_volume_sig_count = 0; - private bool _active_port_headphones = false; private VolumeControl.ActiveOutput _active_output = VolumeControl.ActiveOutput.SPEAKERS; private IndicatorSound.Options _options; @@ -166,11 +193,11 @@ public class VolumeWarning : Object case VolumeControl.ActiveOutput.USB_HEADPHONES: case VolumeControl.ActiveOutput.HDMI_HEADPHONES: case VolumeControl.ActiveOutput.BLUETOOTH_HEADPHONES: - _active_port_headphones = true; + headphones_active = true; break; default: - _active_port_headphones = false; + headphones_active = false; break; } @@ -518,10 +545,15 @@ public class VolumeWarning : Object } private void init_high_volume() { _options.loud_changed.connect(() => update_high_volume()); + notify["multimedia-volume"].connect(() => update_high_volume()); + notify["high-volume-approved"].connect(() => update_high_volume()); update_high_volume(); } private void update_high_volume() { - var new_high_volume = calculate_high_volume(); + var new_high_volume = headphones_active + && !high_volume_approved + && multimedia_active + && _options.is_loud_pulse(multimedia_volume); if (high_volume != new_high_volume) { debug("changing high_volume from %d to %d", (int)high_volume, (int)new_high_volume); high_volume = new_high_volume; @@ -529,14 +561,6 @@ public class VolumeWarning : Object show(); } } - private bool calculate_high_volume() { - return calculate_high_volume_from_volume(multimedia_volume); - } - private bool calculate_high_volume_from_volume(PulseAudio.Volume volume) { - return _active_port_headphones - && _options.is_loud_pulse(volume) - && multimedia_active; - } /** HIGH VOLUME APPROVED PROPERTY **/ @@ -595,27 +619,6 @@ public class VolumeWarning : Object && (_high_volume_approved_at + _high_volume_approved_ttl_usec >= now); } - protected virtual async void set_pulse_multimedia_volume(PulseAudio.Volume volume) - { - var objp = _multimedia_objp; - if (objp == null) - return; - - try { - var builder = new VariantBuilder (new VariantType ("a(uu)")); - builder.add ("(uu)", 0, volume); - - yield _pconn.call ("org.PulseAudio.Ext.StreamRestore1.RestoreEntry", - objp, "org.freedesktop.DBus.Properties", "Set", - new Variant ("(ssv)", "org.PulseAudio.Ext.StreamRestore1.RestoreEntry", "Volume", builder), - null, DBusCallFlags.NONE, -1); - - debug ("Set multimedia volume to %d on path %s", (int)volume, objp); - } catch (GLib.Error e) { - warning ("unable to set volume for stream obj path %s (%s)", objp, e.message); - } - } - // NOTIFICATION private IndicatorSound.WarnNotification _notification = new IndicatorSound.WarnNotification(); |