/* music-player-bridge.c generated by valac 0.11.2, the Vala compiler * generated from music-player-bridge.vala, do not modify */ /* Copyright 2010 Canonical Ltd. Authors: Conor Curran This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License version 3, as published by the Free Software Foundation. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranties of MERCHANTABILITY, SATISFACTORY QUALITY, or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include #include #include #include #include #include #include #include #include #include #include #define TYPE_MUSIC_PLAYER_BRIDGE (music_player_bridge_get_type ()) #define MUSIC_PLAYER_BRIDGE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_MUSIC_PLAYER_BRIDGE, MusicPlayerBridge)) #define MUSIC_PLAYER_BRIDGE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_MUSIC_PLAYER_BRIDGE, MusicPlayerBridgeClass)) #define IS_MUSIC_PLAYER_BRIDGE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_MUSIC_PLAYER_BRIDGE)) #define IS_MUSIC_PLAYER_BRIDGE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_MUSIC_PLAYER_BRIDGE)) #define MUSIC_PLAYER_BRIDGE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_MUSIC_PLAYER_BRIDGE, MusicPlayerBridgeClass)) typedef struct _MusicPlayerBridge MusicPlayerBridge; typedef struct _MusicPlayerBridgeClass MusicPlayerBridgeClass; typedef struct _MusicPlayerBridgePrivate MusicPlayerBridgePrivate; #define TYPE_SETTINGS_MANAGER (settings_manager_get_type ()) #define SETTINGS_MANAGER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_SETTINGS_MANAGER, SettingsManager)) #define SETTINGS_MANAGER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_SETTINGS_MANAGER, SettingsManagerClass)) #define IS_SETTINGS_MANAGER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_SETTINGS_MANAGER)) #define IS_SETTINGS_MANAGER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_SETTINGS_MANAGER)) #define SETTINGS_MANAGER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_SETTINGS_MANAGER, SettingsManagerClass)) typedef struct _SettingsManager SettingsManager; typedef struct _SettingsManagerClass SettingsManagerClass; #define TYPE_PLAYER_CONTROLLER (player_controller_get_type ()) #define PLAYER_CONTROLLER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_PLAYER_CONTROLLER, PlayerController)) #define PLAYER_CONTROLLER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_PLAYER_CONTROLLER, PlayerControllerClass)) #define IS_PLAYER_CONTROLLER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_PLAYER_CONTROLLER)) #define IS_PLAYER_CONTROLLER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_PLAYER_CONTROLLER)) #define PLAYER_CONTROLLER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_PLAYER_CONTROLLER, PlayerControllerClass)) typedef struct _PlayerController PlayerController; typedef struct _PlayerControllerClass PlayerControllerClass; #define TYPE_MPRIS2_WATCHER (mpris2_watcher_get_type ()) #define MPRIS2_WATCHER(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_MPRIS2_WATCHER, Mpris2Watcher)) #define MPRIS2_WATCHER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_MPRIS2_WATCHER, Mpris2WatcherClass)) #define IS_MPRIS2_WATCHER(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_MPRIS2_WATCHER)) #define IS_MPRIS2_WATCHER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_MPRIS2_WATCHER)) #define MPRIS2_WATCHER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_MPRIS2_WATCHER, Mpris2WatcherClass)) typedef struct _Mpris2Watcher Mpris2Watcher; typedef struct _Mpris2WatcherClass Mpris2WatcherClass; #define _g_object_unref0(var) ((var == NULL) ? NULL : (var = (g_object_unref (var), NULL))) #define _g_free0(var) (var = (g_free (var), NULL)) #define PLAYER_CONTROLLER_TYPE_STATE (player_controller_state_get_type ()) #define _g_key_file_free0(var) ((var == NULL) ? NULL : (var = (g_key_file_free (var), NULL))) #define _g_error_free0(var) ((var == NULL) ? NULL : (var = (g_error_free (var), NULL))) struct _MusicPlayerBridge { GObject parent_instance; MusicPlayerBridgePrivate * priv; }; struct _MusicPlayerBridgeClass { GObjectClass parent_class; }; struct _MusicPlayerBridgePrivate { SettingsManager* settings_manager; DbusmenuMenuitem* root_menu; GeeHashMap* registered_clients; Mpris2Watcher* watcher; GSettings* settings; }; typedef enum { PLAYER_CONTROLLER_STATE_OFFLINE, PLAYER_CONTROLLER_STATE_INSTANTIATING, PLAYER_CONTROLLER_STATE_READY, PLAYER_CONTROLLER_STATE_CONNECTED, PLAYER_CONTROLLER_STATE_DISCONNECTED } PlayerControllerstate; static gpointer music_player_bridge_parent_class = NULL; GType music_player_bridge_get_type (void) G_GNUC_CONST; GType settings_manager_get_type (void) G_GNUC_CONST; GType player_controller_get_type (void) G_GNUC_CONST; GType mpris2_watcher_get_type (void) G_GNUC_CONST; #define MUSIC_PLAYER_BRIDGE_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), TYPE_MUSIC_PLAYER_BRIDGE, MusicPlayerBridgePrivate)) enum { MUSIC_PLAYER_BRIDGE_DUMMY_PROPERTY }; #define MUSIC_PLAYER_BRIDGE_DESKTOP_PREFIX "/usr/share/applications/" MusicPlayerBridge* music_player_bridge_new (void); MusicPlayerBridge* music_player_bridge_construct (GType object_type); static void music_player_bridge_on_blacklist_update (MusicPlayerBridge* self, gchar** blacklist, int blacklist_length1); static void music_player_bridge_try_to_add_inactive_familiar_clients (MusicPlayerBridge* self); gchar** settings_manager_fetch_interested (SettingsManager* self, int* result_length1); static GAppInfo* music_player_bridge_create_app_info (const gchar* path); static gchar* music_player_bridge_determine_key (gchar* path); static gchar* music_player_bridge_fetch_icon_name (const gchar* desktop_path); static gint music_player_bridge_calculate_menu_position (MusicPlayerBridge* self); GType player_controller_state_get_type (void) G_GNUC_CONST; PlayerController* player_controller_new (DbusmenuMenuitem* root, GAppInfo* app, const gchar* dbus_name, const gchar* icon_name, gint offset, PlayerControllerstate initial_state); PlayerController* player_controller_construct (GType object_type, DbusmenuMenuitem* root, GAppInfo* app, const gchar* dbus_name, const gchar* icon_name, gint offset, PlayerControllerstate initial_state); #define PLAYER_CONTROLLER_WIDGET_QUANTITY 4 void music_player_bridge_client_has_become_available (MusicPlayerBridge* self, const gchar* desktop, const gchar* dbus_name); gboolean settings_manager_add_interested (SettingsManager* self, const gchar* app_desktop_name); void player_controller_update_state (PlayerController* self, PlayerControllerstate new_state); void player_controller_activate (PlayerController* self, const gchar* dbus_name); void music_player_bridge_client_has_vanished (MusicPlayerBridge* self, const gchar* mpris_root_interface); void player_controller_hibernate (PlayerController* self); void music_player_bridge_set_root_menu_item (MusicPlayerBridge* self, DbusmenuMenuitem* menu); Mpris2Watcher* mpris2_watcher_new (void); Mpris2Watcher* mpris2_watcher_construct (GType object_type); static void _music_player_bridge_client_has_become_available_mpris2_watcher_client_appeared (Mpris2Watcher* _sender, const gchar* desktop_file_name, const gchar* dbus_name, gpointer self); static void _music_player_bridge_client_has_vanished_mpris2_watcher_client_disappeared (Mpris2Watcher* _sender, const gchar* dbus_name, gpointer self); static GObject * music_player_bridge_constructor (GType type, guint n_construct_properties, GObjectConstructParam * construct_properties); SettingsManager* settings_manager_new (void); SettingsManager* settings_manager_construct (GType object_type); static void _music_player_bridge_on_blacklist_update_settings_manager_blacklist_updates (SettingsManager* _sender, gchar** new_blacklist, int new_blacklist_length1, gpointer self); static void music_player_bridge_finalize (GObject* obj); static void _vala_array_destroy (gpointer array, gint array_length, GDestroyNotify destroy_func); static void _vala_array_free (gpointer array, gint array_length, GDestroyNotify destroy_func); static gint _vala_array_length (gpointer array); MusicPlayerBridge* music_player_bridge_construct (GType object_type) { MusicPlayerBridge * self = NULL; self = (MusicPlayerBridge*) g_object_new (object_type, NULL); return self; } MusicPlayerBridge* music_player_bridge_new (void) { return music_player_bridge_construct (TYPE_MUSIC_PLAYER_BRIDGE); } static void music_player_bridge_on_blacklist_update (MusicPlayerBridge* self, gchar** blacklist, int blacklist_length1) { g_return_if_fail (self != NULL); g_debug ("music-player-bridge.vala:45: some blacklist update"); } static void music_player_bridge_try_to_add_inactive_familiar_clients (MusicPlayerBridge* self) { gint _tmp0_; gchar** _tmp1_ = NULL; g_return_if_fail (self != NULL); _tmp1_ = settings_manager_fetch_interested (self->priv->settings_manager, &_tmp0_); { gchar** desktop_collection; int desktop_collection_length1; int desktop_it; desktop_collection = _tmp1_; desktop_collection_length1 = _tmp0_; for (desktop_it = 0; desktop_it < _tmp0_; desktop_it = desktop_it + 1) { gchar* _tmp2_; gchar* desktop; _tmp2_ = g_strdup (desktop_collection[desktop_it]); desktop = _tmp2_; { gchar* _tmp3_ = NULL; gchar* _tmp4_; gchar* _tmp5_ = NULL; gchar* _tmp6_; gchar* path; GAppInfo* _tmp7_ = NULL; GAppInfo* app_info; gchar* _tmp8_; gchar* _tmp9_ = NULL; gchar* mpris_key; gchar* _tmp10_ = NULL; gchar* _tmp11_; gint _tmp12_; PlayerController* _tmp13_ = NULL; PlayerController* _tmp14_; PlayerController* ctrl; g_debug ("music-player-bridge.vala:51: interested client found : %s", desktop); _tmp3_ = g_strconcat (desktop, ".desktop", NULL); _tmp4_ = _tmp3_; _tmp5_ = g_strconcat (MUSIC_PLAYER_BRIDGE_DESKTOP_PREFIX, _tmp4_, NULL); path = (_tmp6_ = _tmp5_, _g_free0 (_tmp4_), _tmp6_); _tmp7_ = music_player_bridge_create_app_info (path); app_info = _tmp7_; if (app_info == NULL) { g_warning ("music-player-bridge.vala:55: Could not create app_info for path %s \n" \ " Getting out of here ", path); _g_object_unref0 (app_info); _g_free0 (path); _g_free0 (desktop); continue; } _tmp8_ = g_strdup (path); _tmp9_ = music_player_bridge_determine_key (_tmp8_); mpris_key = _tmp9_; _tmp10_ = music_player_bridge_fetch_icon_name (path); _tmp11_ = _tmp10_; _tmp12_ = music_player_bridge_calculate_menu_position (self); _tmp13_ = player_controller_new (self->priv->root_menu, app_info, NULL, _tmp11_, _tmp12_, PLAYER_CONTROLLER_STATE_OFFLINE); ctrl = (_tmp14_ = _tmp13_, _g_free0 (_tmp11_), _tmp14_); gee_abstract_map_set ((GeeAbstractMap*) self->priv->registered_clients, mpris_key, ctrl); _g_object_unref0 (ctrl); _g_free0 (mpris_key); _g_object_unref0 (app_info); _g_free0 (path); _g_free0 (desktop); } } desktop_collection = (_vala_array_free (desktop_collection, desktop_collection_length1, (GDestroyNotify) g_free), NULL); } } static gint music_player_bridge_calculate_menu_position (MusicPlayerBridge* self) { gint result = 0; gint _tmp0_; g_return_val_if_fail (self != NULL, 0); _tmp0_ = gee_map_get_size ((GeeMap*) self->priv->registered_clients); if (_tmp0_ == 0) { result = 2; return result; } else { gint _tmp1_; _tmp1_ = gee_map_get_size ((GeeMap*) self->priv->registered_clients); result = 2 + (_tmp1_ * PLAYER_CONTROLLER_WIDGET_QUANTITY); return result; } } void music_player_bridge_client_has_become_available (MusicPlayerBridge* self, const gchar* desktop, const gchar* dbus_name) { gboolean _tmp0_ = FALSE; gchar* _tmp1_ = NULL; gchar* _tmp2_; gchar* _tmp3_ = NULL; gchar* _tmp4_; gchar* path; GAppInfo* _tmp5_ = NULL; GAppInfo* app_info; gchar* _tmp6_; gchar* _tmp7_ = NULL; gchar* mpris_key; gboolean _tmp8_; g_return_if_fail (self != NULL); g_return_if_fail (desktop != NULL); g_return_if_fail (dbus_name != NULL); if (desktop == NULL) { _tmp0_ = TRUE; } else { _tmp0_ = g_strcmp0 (desktop, "") == 0; } if (_tmp0_) { g_warning ("music-player-bridge.vala:82: Client %s attempting to register without " \ "desktop entry being set on the mpris root", dbus_name); return; } g_debug ("music-player-bridge.vala:86: client_has_become_available %s", desktop); _tmp1_ = g_strconcat (desktop, ".desktop", NULL); _tmp2_ = _tmp1_; _tmp3_ = g_strconcat (MUSIC_PLAYER_BRIDGE_DESKTOP_PREFIX, _tmp2_, NULL); path = (_tmp4_ = _tmp3_, _g_free0 (_tmp2_), _tmp4_); _tmp5_ = music_player_bridge_create_app_info (path); app_info = _tmp5_; if (app_info == NULL) { g_warning ("music-player-bridge.vala:90: Could not create app_info for path %s \n" \ " Getting out of here ", path); _g_object_unref0 (app_info); _g_free0 (path); return; } _tmp6_ = g_strdup (path); _tmp7_ = music_player_bridge_determine_key (_tmp6_); mpris_key = _tmp7_; _tmp8_ = gee_abstract_map_has_key ((GeeAbstractMap*) self->priv->registered_clients, mpris_key); if (_tmp8_ == FALSE) { gchar* _tmp9_ = NULL; gchar* _tmp10_; gint _tmp11_; PlayerController* _tmp12_ = NULL; PlayerController* _tmp13_; PlayerController* ctrl; g_debug ("music-player-bridge.vala:97: New client has registered that we have no" \ "t seen before: %s", dbus_name); _tmp9_ = music_player_bridge_fetch_icon_name (path); _tmp10_ = _tmp9_; _tmp11_ = music_player_bridge_calculate_menu_position (self); _tmp12_ = player_controller_new (self->priv->root_menu, app_info, dbus_name, _tmp10_, _tmp11_, PLAYER_CONTROLLER_STATE_READY); ctrl = (_tmp13_ = _tmp12_, _g_free0 (_tmp10_), _tmp13_); gee_abstract_map_set ((GeeAbstractMap*) self->priv->registered_clients, mpris_key, ctrl); g_debug ("music-player-bridge.vala:105: Have not seen this %s before, new contro" \ "ller created.", desktop); settings_manager_add_interested (self->priv->settings_manager, desktop); g_debug ("music-player-bridge.vala:107: application added to the interested list"); _g_object_unref0 (ctrl); } else { gpointer _tmp14_ = NULL; PlayerController* _tmp15_; gpointer _tmp16_ = NULL; PlayerController* _tmp17_; _tmp14_ = gee_abstract_map_get ((GeeAbstractMap*) self->priv->registered_clients, mpris_key); _tmp15_ = (PlayerController*) _tmp14_; player_controller_update_state (_tmp15_, PLAYER_CONTROLLER_STATE_READY); _g_object_unref0 (_tmp15_); _tmp16_ = gee_abstract_map_get ((GeeAbstractMap*) self->priv->registered_clients, mpris_key); _tmp17_ = (PlayerController*) _tmp16_; player_controller_activate (_tmp17_, dbus_name); _g_object_unref0 (_tmp17_); g_debug ("music-player-bridge.vala:112: Application has already registered - awa" \ "ken the hibernation: %s \n", dbus_name); } _g_free0 (mpris_key); _g_object_unref0 (app_info); _g_free0 (path); } void music_player_bridge_client_has_vanished (MusicPlayerBridge* self, const gchar* mpris_root_interface) { g_return_if_fail (self != NULL); g_return_if_fail (mpris_root_interface != NULL); g_debug ("music-player-bridge.vala:118: MusicPlayerBridge -> on_server_removed w" \ "ith value %s", mpris_root_interface); if (self->priv->root_menu != NULL) { gchar* _tmp0_; gchar* _tmp1_ = NULL; gchar* mpris_key; g_debug ("music-player-bridge.vala:120: attempt to remove %s", mpris_root_interface); _tmp0_ = g_strdup (mpris_root_interface); _tmp1_ = music_player_bridge_determine_key (_tmp0_); mpris_key = _tmp1_; if (mpris_key != NULL) { gpointer _tmp2_ = NULL; PlayerController* _tmp3_; _tmp2_ = gee_abstract_map_get ((GeeAbstractMap*) self->priv->registered_clients, mpris_key); _tmp3_ = (PlayerController*) _tmp2_; player_controller_hibernate (_tmp3_); _g_object_unref0 (_tmp3_); g_debug ("music-player-bridge.vala:124: Successively offlined client %s", mpris_key); } _g_free0 (mpris_key); } } static gpointer _g_object_ref0 (gpointer self) { return self ? g_object_ref (self) : NULL; } static void _music_player_bridge_client_has_become_available_mpris2_watcher_client_appeared (Mpris2Watcher* _sender, const gchar* desktop_file_name, const gchar* dbus_name, gpointer self) { music_player_bridge_client_has_become_available (self, desktop_file_name, dbus_name); } static void _music_player_bridge_client_has_vanished_mpris2_watcher_client_disappeared (Mpris2Watcher* _sender, const gchar* dbus_name, gpointer self) { music_player_bridge_client_has_vanished (self, dbus_name); } void music_player_bridge_set_root_menu_item (MusicPlayerBridge* self, DbusmenuMenuitem* menu) { DbusmenuMenuitem* _tmp0_; DbusmenuMenuitem* _tmp1_; Mpris2Watcher* _tmp2_ = NULL; Mpris2Watcher* _tmp3_; g_return_if_fail (self != NULL); g_return_if_fail (menu != NULL); _tmp0_ = _g_object_ref0 (menu); _tmp1_ = _tmp0_; _g_object_unref0 (self->priv->root_menu); self->priv->root_menu = _tmp1_; _tmp2_ = mpris2_watcher_new (); _tmp3_ = _tmp2_; _g_object_unref0 (self->priv->watcher); self->priv->watcher = _tmp3_; g_signal_connect_object (self->priv->watcher, "client-appeared", (GCallback) _music_player_bridge_client_has_become_available_mpris2_watcher_client_appeared, self, 0); g_signal_connect_object (self->priv->watcher, "client-disappeared", (GCallback) _music_player_bridge_client_has_vanished_mpris2_watcher_client_disappeared, self, 0); music_player_bridge_try_to_add_inactive_familiar_clients (self); } static GAppInfo* music_player_bridge_create_app_info (const gchar* path) { GAppInfo* result = NULL; GDesktopAppInfo* _tmp0_ = NULL; GDesktopAppInfo* info; gboolean _tmp1_ = FALSE; GDesktopAppInfo* _tmp2_; GAppInfo* _tmp3_; GAppInfo* app_info; g_return_val_if_fail (path != NULL, NULL); _tmp0_ = g_desktop_app_info_new_from_filename (path); info = _tmp0_; if (path == NULL) { _tmp1_ = TRUE; } else { _tmp1_ = info == NULL; } if (_tmp1_) { g_warning ("music-player-bridge.vala:142: Could not create a desktopappinfo instan" \ "ce from app: %s", path); result = NULL; _g_object_unref0 (info); return result; } _tmp3_ = _g_object_ref0 ((_tmp2_ = info, G_IS_APP_INFO (_tmp2_) ? ((GAppInfo*) _tmp2_) : NULL)); app_info = _tmp3_; result = app_info; _g_object_unref0 (info); return result; } static gchar* music_player_bridge_fetch_icon_name (const gchar* desktop_path) { gchar* result = NULL; GKeyFile* _tmp0_ = NULL; GKeyFile* desktop_keyfile; gchar* _tmp1_ = NULL; gchar* _tmp2_; GError * _inner_error_ = NULL; g_return_val_if_fail (desktop_path != NULL, NULL); _tmp0_ = g_key_file_new (); desktop_keyfile = _tmp0_; g_key_file_load_from_file (desktop_keyfile, desktop_path, G_KEY_FILE_NONE, &_inner_error_); if (_inner_error_ != NULL) { if (_inner_error_->domain == G_FILE_ERROR) { goto __catch0_g_file_error; } if (_inner_error_->domain == G_KEY_FILE_ERROR) { goto __catch0_g_key_file_error; } _g_key_file_free0 (desktop_keyfile); g_critical ("file %s: line %d: unexpected error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); g_clear_error (&_inner_error_); return NULL; } goto __finally0; __catch0_g_file_error: { GError * _error_; _error_ = _inner_error_; _inner_error_ = NULL; g_warning ("music-player-bridge.vala:156: Error loading keyfile - FileError"); result = NULL; _g_error_free0 (_error_); _g_key_file_free0 (desktop_keyfile); return result; } goto __finally0; __catch0_g_key_file_error: { GError * _error_; _error_ = _inner_error_; _inner_error_ = NULL; g_warning ("music-player-bridge.vala:160: Error loading keyfile - KeyFileError"); result = NULL; _g_error_free0 (_error_); _g_key_file_free0 (desktop_keyfile); return result; } __finally0: if (_inner_error_ != NULL) { _g_key_file_free0 (desktop_keyfile); g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); g_clear_error (&_inner_error_); return NULL; } _tmp1_ = g_key_file_get_string (desktop_keyfile, G_KEY_FILE_DESKTOP_GROUP, G_KEY_FILE_DESKTOP_KEY_ICON, &_inner_error_); _tmp2_ = _tmp1_; if (_inner_error_ != NULL) { if (_inner_error_->domain == G_KEY_FILE_ERROR) { goto __catch1_g_key_file_error; } _g_key_file_free0 (desktop_keyfile); g_critical ("file %s: line %d: unexpected error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); g_clear_error (&_inner_error_); return NULL; } result = _tmp2_; _g_key_file_free0 (desktop_keyfile); return result; goto __finally1; __catch1_g_key_file_error: { GError * _error_; _error_ = _inner_error_; _inner_error_ = NULL; g_warning ("music-player-bridge.vala:169: Error trying to fetch the icon name from" \ " the keyfile"); result = NULL; _g_error_free0 (_error_); _g_key_file_free0 (desktop_keyfile); return result; } __finally1: _g_key_file_free0 (desktop_keyfile); g_critical ("file %s: line %d: uncaught error: %s (%s, %d)", __FILE__, __LINE__, _inner_error_->message, g_quark_to_string (_inner_error_->domain), _inner_error_->code); g_clear_error (&_inner_error_); return NULL; } static gchar* music_player_bridge_determine_key (gchar* path) { gchar* result = NULL; gchar** _tmp0_; gchar** _tmp1_ = NULL; gint tokens_length1; gint _tokens_size_; gchar** _tmp2_; gchar** tokens; gchar* _tmp6_; gchar* filename; gchar** _tmp7_; gchar** _tmp8_ = NULL; gchar** _tmp9_; gint _tmp9__length1; gchar* _tmp10_; gchar* _tmp11_; gchar* _result_; gchar** _tmp12_; gchar** _tmp13_ = NULL; gint temp_length1; gint _temp_size_; gchar** _tmp14_; gchar** temp; g_return_val_if_fail (path != NULL, NULL); _tmp1_ = _tmp0_ = g_strsplit (path, "/", 0); _tmp2_ = _tmp1_; tokens_length1 = _vala_array_length (_tmp0_); _tokens_size_ = tokens_length1; tokens = _tmp2_; if (tokens_length1 < 2) { gchar** _tmp3_; gchar** _tmp4_ = NULL; gchar** _tmp5_; _tmp4_ = _tmp3_ = g_strsplit (path, ".", 0); _tmp5_ = _tmp4_; tokens = (_vala_array_free (tokens, tokens_length1, (GDestroyNotify) g_free), NULL); tokens_length1 = _vala_array_length (_tmp3_); _tokens_size_ = tokens_length1; tokens = _tmp5_; if (tokens_length1 < 2) { result = NULL; tokens = (_vala_array_free (tokens, tokens_length1, (GDestroyNotify) g_free), NULL); _g_free0 (path); return result; } } _tmp6_ = g_strdup (tokens[tokens_length1 - 1]); filename = _tmp6_; _tmp8_ = _tmp7_ = g_strsplit (filename, ".", 0); _tmp9_ = _tmp8_; _tmp9__length1 = _vala_array_length (_tmp7_); _tmp10_ = g_strdup (_tmp9_[0]); _result_ = (_tmp11_ = _tmp10_, _tmp9_ = (_vala_array_free (_tmp9_, _tmp9__length1, (GDestroyNotify) g_free), NULL), _tmp11_); _tmp13_ = _tmp12_ = g_strsplit (_result_, "-", 0); _tmp14_ = _tmp13_; temp_length1 = _vala_array_length (_tmp12_); _temp_size_ = temp_length1; temp = _tmp14_; if (temp_length1 > 1) { gchar* _tmp15_; gchar* _tmp16_; _tmp15_ = g_strdup (temp[0]); _tmp16_ = _tmp15_; _g_free0 (_result_); _result_ = _tmp16_; } g_debug ("music-player-bridge.vala:197: determine key result = %s", _result_); result = _result_; temp = (_vala_array_free (temp, temp_length1, (GDestroyNotify) g_free), NULL); _g_free0 (filename); tokens = (_vala_array_free (tokens, tokens_length1, (GDestroyNotify) g_free), NULL); _g_free0 (path); return result; } static void _music_player_bridge_on_blacklist_update_settings_manager_blacklist_updates (SettingsManager* _sender, gchar** new_blacklist, int new_blacklist_length1, gpointer self) { music_player_bridge_on_blacklist_update (self, new_blacklist, new_blacklist_length1); } static GObject * music_player_bridge_constructor (GType type, guint n_construct_properties, GObjectConstructParam * construct_properties) { GObject * obj; GObjectClass * parent_class; MusicPlayerBridge * self; GeeHashMap* _tmp0_ = NULL; GeeHashMap* _tmp1_; SettingsManager* _tmp2_ = NULL; SettingsManager* _tmp3_; parent_class = G_OBJECT_CLASS (music_player_bridge_parent_class); obj = parent_class->constructor (type, n_construct_properties, construct_properties); self = MUSIC_PLAYER_BRIDGE (obj); _tmp0_ = gee_hash_map_new (G_TYPE_STRING, (GBoxedCopyFunc) g_strdup, g_free, TYPE_PLAYER_CONTROLLER, (GBoxedCopyFunc) g_object_ref, g_object_unref, NULL, NULL, NULL); _tmp1_ = _tmp0_; _g_object_unref0 (self->priv->registered_clients); self->priv->registered_clients = _tmp1_; _tmp2_ = settings_manager_new (); _tmp3_ = _tmp2_; _g_object_unref0 (self->priv->settings_manager); self->priv->settings_manager = _tmp3_; g_signal_connect_object (self->priv->settings_manager, "blacklist-updates", (GCallback) _music_player_bridge_on_blacklist_update_settings_manager_blacklist_updates, self, 0); return obj; } static void music_player_bridge_class_init (MusicPlayerBridgeClass * klass) { music_player_bridge_parent_class = g_type_class_peek_parent (klass); g_type_class_add_private (klass, sizeof (MusicPlayerBridgePrivate)); G_OBJECT_CLASS (klass)->constructor = music_player_bridge_constructor; G_OBJECT_CLASS (klass)->finalize = music_player_bridge_finalize; } static void music_player_bridge_instance_init (MusicPlayerBridge * self) { self->priv = MUSIC_PLAYER_BRIDGE_GET_PRIVATE (self); } static void music_player_bridge_finalize (GObject* obj) { MusicPlayerBridge * self; self = MUSIC_PLAYER_BRIDGE (obj); _g_object_unref0 (self->priv->settings_manager); _g_object_unref0 (self->priv->root_menu); _g_object_unref0 (self->priv->registered_clients); _g_object_unref0 (self->priv->watcher); _g_object_unref0 (self->priv->settings); G_OBJECT_CLASS (music_player_bridge_parent_class)->finalize (obj); } GType music_player_bridge_get_type (void) { static volatile gsize music_player_bridge_type_id__volatile = 0; if (g_once_init_enter (&music_player_bridge_type_id__volatile)) { static const GTypeInfo g_define_type_info = { sizeof (MusicPlayerBridgeClass), (GBaseInitFunc) NULL, (GBaseFinalizeFunc) NULL, (GClassInitFunc) music_player_bridge_class_init, (GClassFinalizeFunc) NULL, NULL, sizeof (MusicPlayerBridge), 0, (GInstanceInitFunc) music_player_bridge_instance_init, NULL }; GType music_player_bridge_type_id; music_player_bridge_type_id = g_type_register_static (G_TYPE_OBJECT, "MusicPlayerBridge", &g_define_type_info, 0); g_once_init_leave (&music_player_bridge_type_id__volatile, music_player_bridge_type_id); } return music_player_bridge_type_id__volatile; } static void _vala_array_destroy (gpointer array, gint array_length, GDestroyNotify destroy_func) { if ((array != NULL) && (destroy_func != NULL)) { int i; for (i = 0; i < array_length; i = i + 1) { if (((gpointer*) array)[i] != NULL) { destroy_func (((gpointer*) array)[i]); } } } } static void _vala_array_free (gpointer array, gint array_length, GDestroyNotify destroy_func) { _vala_array_destroy (array, array_length, destroy_func); g_free (array); } static gint _vala_array_length (gpointer array) { int length; length = 0; if (array) { while (((gpointer*) array)[length]) { length++; } } return length; }