diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/media-player-list.vala | 73 | ||||
-rw-r--r-- | src/service.vala | 25 |
2 files changed, 76 insertions, 22 deletions
diff --git a/src/media-player-list.vala b/src/media-player-list.vala index 0c0a212..3fa08f3 100644 --- a/src/media-player-list.vala +++ b/src/media-player-list.vala @@ -37,26 +37,73 @@ public class MediaPlayerList { } } - public signal void player_added (MediaPlayer player); - - HashTable<string, MediaPlayer> _players; - Mpris2Watcher mpris_watcher; - - void player_appeared (string desktop_id, string dbus_name, bool use_playlists) { - var appinfo = new DesktopAppInfo (desktop_id + ".desktop"); - if (appinfo == null) { - warning ("unable to find application '%s'", desktop_id); - return; - } - + /** + * Adds the player associated with @desktop_id. Does nothing if such a player already exists. + */ + public MediaPlayer? insert (string desktop_id) { + message ("inserting %s", desktop_id); MediaPlayer? player = this._players.lookup (desktop_id); + if (player == null) { + message (" Really."); + var appinfo = new DesktopAppInfo (desktop_id + ".desktop"); + if (appinfo == null) { + warning ("unable to find application '%s'", desktop_id); + return null; + } + player = new MediaPlayer (appinfo); this._players.insert (player.id, player); this.player_added (player); } - player.attach (dbus_name); + return player; + } + + /** + * Removes the player associated with @desktop_id, unless it is currently running. + */ + public void remove (string desktop_id) { + MediaPlayer? player = this._players.lookup (desktop_id); + + if (player != null && !player.is_running) { + this._players.remove (desktop_id); + this.player_removed (player); + } + } + + /** + * Synchronizes the player list with @desktop_ids. After this call, this list will only contain the players + * in @desktop_ids. Players that were running but are not in @desktop_ids will remain in the list. + */ + public void sync (string[] desktop_ids) { + + /* hash desktop_ids for faster lookup */ + var hash = new HashTable<string, unowned string> (str_hash, str_equal); + foreach (var id in desktop_ids) + hash.add (id); + + /* remove players that are not desktop_ids */ + foreach (var id in this._players.get_keys ()) { + if (!hash.contains (id)) + this.remove (id); + } + + /* insert all players (insert() takes care of not adding a player twice */ + foreach (var id in desktop_ids) + this.insert (id); + } + + public signal void player_added (MediaPlayer player); + public signal void player_removed (MediaPlayer player); + + HashTable<string, MediaPlayer> _players; + Mpris2Watcher mpris_watcher; + + void player_appeared (string desktop_id, string dbus_name, bool use_playlists) { + var player = this.insert (desktop_id); + if (player != null) + player.attach (dbus_name); } void player_disappeared (string dbus_name) { diff --git a/src/service.vala b/src/service.vala index 4ea4a95..8f5280e 100644 --- a/src/service.vala +++ b/src/service.vala @@ -1,10 +1,24 @@ public class IndicatorSound.Service { public Service () { + this.settings = new Settings ("com.canonical.indicator.sound"); + this.volume_control = new VolumeControl (); this.players = new MediaPlayerList (); - this.players.player_added.connect (player_added); + this.players.player_added.connect (this.player_added); + + this.actions = new SimpleActionGroup (); + this.actions.add_entries (action_entries, this); + this.actions.add_action (this.create_mute_action ()); + this.actions.add_action (this.create_volume_action ()); + + this.menu = create_base_menu (); + + this.players.sync (settings.get_strv ("preferred-media-players")); + this.settings.changed["preferred-media-players"].connect ( () => { + this.players.sync (settings.get_strv ("preferred-media-players")); + }); } public int run () { @@ -30,6 +44,7 @@ public class IndicatorSound.Service { MainLoop loop; SimpleActionGroup actions; Menu menu; + Settings settings; VolumeControl volume_control; MediaPlayerList players; uint player_action_update_id; @@ -97,14 +112,6 @@ public class IndicatorSound.Service { } void bus_acquired (DBusConnection connection, string name) { - this.actions = new SimpleActionGroup (); - this.actions.add_entries (action_entries, this); - - this.actions.add_action (this.create_mute_action ()); - this.actions.add_action (this.create_volume_action ()); - - this.menu = create_base_menu (); - try { connection.export_action_group ("/com/canonical/indicator/sound", this.actions); connection.export_menu_model ("/com/canonical/indicator/sound/desktop", this.menu); |