diff options
author | Nirbheek Chauhan <nirbheek@gentoo.org> | 2009-09-12 11:38:19 +0000 |
---|---|---|
committer | Nirbheek Chauhan <nirbheek@gentoo.org> | 2009-09-12 11:38:19 +0000 |
commit | b264040ea7ac79098a5118c0beb7edd7267739d2 (patch) | |
tree | 2500e0ad3246082268b42dfee3c262cffa7ce484 /gnome-extra | |
parent | amd64 stable (diff) | |
download | gentoo-2-b264040ea7ac79098a5118c0beb7edd7267739d2.tar.gz gentoo-2-b264040ea7ac79098a5118c0beb7edd7267739d2.tar.bz2 gentoo-2-b264040ea7ac79098a5118c0beb7edd7267739d2.zip |
First half of fix for bug 274819 (second half will go to gnome-settings-daemon) -- restarting pulseaudio breaks volume applet
(Portage version: 2.2_rc40/cvs/Linux i686)
Diffstat (limited to 'gnome-extra')
-rw-r--r-- | gnome-extra/gnome-media/ChangeLog | 10 | ||||
-rw-r--r-- | gnome-extra/gnome-media/files/gnome-media-2.26.0-connection-failed-pulseaudio.patch | 321 | ||||
-rw-r--r-- | gnome-extra/gnome-media/gnome-media-2.26.0-r1.ebuild (renamed from gnome-extra/gnome-media/gnome-media-2.26.0.ebuild) | 6 |
3 files changed, 335 insertions, 2 deletions
diff --git a/gnome-extra/gnome-media/ChangeLog b/gnome-extra/gnome-media/ChangeLog index 4902cf9a435a..662a96f727bb 100644 --- a/gnome-extra/gnome-media/ChangeLog +++ b/gnome-extra/gnome-media/ChangeLog @@ -1,6 +1,14 @@ # ChangeLog for gnome-extra/gnome-media # Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/gnome-extra/gnome-media/ChangeLog,v 1.199 2009/08/23 21:48:12 eva Exp $ +# $Header: /var/cvsroot/gentoo-x86/gnome-extra/gnome-media/ChangeLog,v 1.200 2009/09/12 11:38:18 nirbheek Exp $ + +*gnome-media-2.26.0-r1 (12 Sep 2009) + + 12 Sep 2009; Nirbheek Chauhan <nirbheek@gentoo.org> + -gnome-media-2.26.0.ebuild, +gnome-media-2.26.0-r1.ebuild, + +files/gnome-media-2.26.0-connection-failed-pulseaudio.patch: + First half of fix for bug 274819 (second half will go to + gnome-settings-daemon) -- restarting pulseaudio breaks volume applet 23 Aug 2009; Gilles Dartiguelongue <eva@gentoo.org> gnome-media-2.26.0.ebuild: diff --git a/gnome-extra/gnome-media/files/gnome-media-2.26.0-connection-failed-pulseaudio.patch b/gnome-extra/gnome-media/files/gnome-media-2.26.0-connection-failed-pulseaudio.patch new file mode 100644 index 000000000000..f49d2c4b6732 --- /dev/null +++ b/gnome-extra/gnome-media/files/gnome-media-2.26.0-connection-failed-pulseaudio.patch @@ -0,0 +1,321 @@ +This is taken from upstreams's git repository and is half the fix for bug 274819 +The other half is to be applied to gnome-settings-daemon (which handles the +keybindings) + +--- +From 445e8ff0b2675fe7907b700ebd4c5e9b4251ab73 Mon Sep 17 00:00:00 2001 +From: Marc-André Lureau <marcandre.lureau@gmail.com> +Date: Sun, 14 Jun 2009 20:25:14 +0000 +Subject: Bug 564311 – "Connection failed" when PA drops off + +--- +diff --git a/gnome-volume-control/src/dialog-main.c b/gnome-volume-control/src/dialog-main.c +index dddc281..dd24472 100644 +--- a/gnome-volume-control/src/dialog-main.c ++++ b/gnome-volume-control/src/dialog-main.c +@@ -85,6 +85,9 @@ on_control_ready (GvcMixerControl *control, + warning_dialog = NULL; + } + ++ if (dialog) ++ return; ++ + dialog = GTK_WIDGET (gvc_mixer_dialog_new (control)); + g_signal_connect (dialog, + "response", +@@ -115,7 +118,7 @@ warning_dialog_answered (GtkDialog *d, + static gboolean + dialog_popup_timeout (gpointer data) + { +- warning_dialog = gtk_message_dialog_new (NULL, ++ warning_dialog = gtk_message_dialog_new (GTK_WINDOW(dialog), + 0, + GTK_MESSAGE_INFO, + GTK_BUTTONS_CANCEL, +@@ -130,6 +133,18 @@ dialog_popup_timeout (gpointer data) + return FALSE; + } + ++static void ++on_control_connecting (GvcMixerControl *control, ++ UniqueApp *app) ++{ ++ if (popup_id != 0) ++ return; ++ ++ popup_id = g_timeout_add_seconds (DIALOG_POPUP_TIMEOUT, ++ dialog_popup_timeout, ++ NULL); ++} ++ + int + main (int argc, char **argv) + { +@@ -177,15 +192,15 @@ main (int argc, char **argv) + + control = gvc_mixer_control_new (); + g_signal_connect (control, ++ "connecting", ++ G_CALLBACK (on_control_connecting), ++ app); ++ g_signal_connect (control, + "ready", + G_CALLBACK (on_control_ready), + app); + gvc_mixer_control_open (control); + +- popup_id = g_timeout_add_seconds (DIALOG_POPUP_TIMEOUT, +- dialog_popup_timeout, +- NULL); +- + gtk_main (); + + if (control != NULL) { +diff --git a/gnome-volume-control/src/gvc-applet.c b/gnome-volume-control/src/gvc-applet.c +index e11818b..82e3765 100644 +--- a/gnome-volume-control/src/gvc-applet.c ++++ b/gnome-volume-control/src/gvc-applet.c +@@ -167,6 +167,13 @@ on_control_ready (GvcMixerControl *control, + } + + static void ++on_control_connecting (GvcMixerControl *control, ++ GvcApplet *applet) ++{ ++ g_debug ("Connecting.."); ++} ++ ++static void + on_control_default_sink_changed (GvcMixerControl *control, + guint id, + GvcApplet *applet) +@@ -216,6 +223,10 @@ gvc_applet_constructor (GType type, + G_CALLBACK (on_control_ready), + self); + g_signal_connect (self->priv->control, ++ "connecting", ++ G_CALLBACK (on_control_connecting), ++ self); ++ g_signal_connect (self->priv->control, + "default-sink-changed", + G_CALLBACK (on_control_default_sink_changed), + self); +diff --git a/gnome-volume-control/src/gvc-mixer-control.c b/gnome-volume-control/src/gvc-mixer-control.c +index b642467..92b0286 100644 +--- a/gnome-volume-control/src/gvc-mixer-control.c ++++ b/gnome-volume-control/src/gvc-mixer-control.c +@@ -48,6 +48,7 @@ struct GvcMixerControlPrivate + pa_mainloop_api *pa_api; + pa_context *pa_context; + int n_outstanding; ++ guint reconnect_id; + + gboolean default_sink_is_set; + guint default_sink_id; +@@ -70,6 +71,7 @@ struct GvcMixerControlPrivate + }; + + enum { ++ CONNECTING, + READY, + STREAM_ADDED, + STREAM_REMOVED, +@@ -381,12 +383,14 @@ _set_default_source (GvcMixerControl *control, + { + guint new_id; + +- new_id = 0; +- +- if (stream != NULL) { +- new_id = gvc_mixer_stream_get_id (stream); ++ if (stream == NULL) { ++ control->priv->default_source_id = 0; ++ control->priv->default_source_is_set = FALSE; ++ return; + } + ++ new_id = gvc_mixer_stream_get_id (stream); ++ + if (control->priv->default_source_id != new_id) { + control->priv->default_source_id = new_id; + control->priv->default_source_is_set = TRUE; +@@ -403,12 +407,14 @@ _set_default_sink (GvcMixerControl *control, + { + guint new_id; + +- new_id = 0; +- +- if (stream != NULL) { +- new_id = gvc_mixer_stream_get_id (stream); ++ if (stream == NULL) { ++ control->priv->default_sink_id = 0; ++ control->priv->default_sink_is_set = FALSE; ++ return; + } + ++ new_id = gvc_mixer_stream_get_id (stream); ++ + if (control->priv->default_sink_id != new_id) { + control->priv->default_sink_id = new_id; + control->priv->default_sink_is_set = TRUE; +@@ -1451,6 +1457,78 @@ gvc_mixer_control_ready (GvcMixerControl *control) + } + + static void ++gvc_mixer_new_pa_context (GvcMixerControl *self) ++{ ++ pa_proplist *proplist; ++ ++ g_return_if_fail (self); ++ g_return_if_fail (!self->priv->pa_context); ++ ++ /* FIXME: read these from an object property */ ++ proplist = pa_proplist_new (); ++ pa_proplist_sets (proplist, ++ PA_PROP_APPLICATION_NAME, ++ _("GNOME Volume Control")); ++ pa_proplist_sets (proplist, ++ PA_PROP_APPLICATION_ID, ++ "org.gnome.VolumeControl"); ++ pa_proplist_sets (proplist, ++ PA_PROP_APPLICATION_ICON_NAME, ++ "multimedia-volume-control"); ++ pa_proplist_sets (proplist, ++ PA_PROP_APPLICATION_VERSION, ++ PACKAGE_VERSION); ++ ++ self->priv->pa_context = pa_context_new_with_proplist (self->priv->pa_api, NULL, proplist); ++ ++ pa_proplist_free (proplist); ++ g_assert (self->priv->pa_context); ++} ++ ++static void ++remove_all_streams (GvcMixerControl *control, GHashTable *hash_table) ++{ ++ GHashTableIter iter; ++ gpointer key, value; ++ ++ g_hash_table_iter_init (&iter, hash_table); ++ while (g_hash_table_iter_next (&iter, &key, &value)) { ++ remove_stream (control, value); ++ g_hash_table_iter_remove (&iter); ++ } ++} ++ ++static gboolean ++idle_reconnect (gpointer data) ++{ ++ GvcMixerControl *control = GVC_MIXER_CONTROL (data); ++ GHashTableIter iter; ++ gpointer key, value; ++ ++ g_return_val_if_fail (control, FALSE); ++ ++ if (control->priv->pa_context) { ++ pa_context_unref (control->priv->pa_context); ++ control->priv->pa_context = NULL; ++ gvc_mixer_new_pa_context (control); ++ } ++ ++ remove_all_streams (control, control->priv->sinks); ++ remove_all_streams (control, control->priv->sources); ++ remove_all_streams (control, control->priv->sink_inputs); ++ remove_all_streams (control, control->priv->source_outputs); ++ ++ g_hash_table_iter_init (&iter, control->priv->clients); ++ while (g_hash_table_iter_next (&iter, &key, &value)) ++ g_hash_table_iter_remove (&iter); ++ ++ gvc_mixer_control_open (control); /* cannot fail */ ++ ++ control->priv->reconnect_id = 0; ++ return FALSE; ++} ++ ++static void + _pa_context_state_cb (pa_context *context, + void *userdata) + { +@@ -1468,7 +1546,9 @@ _pa_context_state_cb (pa_context *context, + break; + + case PA_CONTEXT_FAILED: +- g_warning ("Connection failed"); ++ g_warning ("Connection failed, reconnecting..."); ++ if (control->priv->reconnect_id == 0) ++ control->priv->reconnect_id = g_idle_add (idle_reconnect, control); + break; + + case PA_CONTEXT_TERMINATED: +@@ -1491,7 +1571,8 @@ gvc_mixer_control_open (GvcMixerControl *control) + _pa_context_state_cb, + control); + +- res = pa_context_connect (control->priv->pa_context, NULL, (pa_context_flags_t) 0, NULL); ++ g_signal_emit (G_OBJECT (control), signals[CONNECTING], 0); ++ res = pa_context_connect (control->priv->pa_context, NULL, (pa_context_flags_t) PA_CONTEXT_NOFAIL, NULL); + if (res < 0) { + g_warning ("Failed to connect context: %s", + pa_strerror (pa_context_errno (control->priv->pa_context))); +@@ -1570,30 +1651,12 @@ gvc_mixer_control_constructor (GType type, + { + GObject *object; + GvcMixerControl *self; +- pa_proplist *proplist; + + object = G_OBJECT_CLASS (gvc_mixer_control_parent_class)->constructor (type, n_construct_properties, construct_params); + + self = GVC_MIXER_CONTROL (object); + +- /* FIXME: read these from an object property */ +- proplist = pa_proplist_new (); +- pa_proplist_sets (proplist, +- PA_PROP_APPLICATION_NAME, +- _("GNOME Volume Control")); +- pa_proplist_sets (proplist, +- PA_PROP_APPLICATION_ID, +- "org.gnome.VolumeControl"); +- pa_proplist_sets (proplist, +- PA_PROP_APPLICATION_ICON_NAME, +- "multimedia-volume-control"); +- pa_proplist_sets (proplist, +- PA_PROP_APPLICATION_VERSION, +- PACKAGE_VERSION); +- +- self->priv->pa_context = pa_context_new_with_proplist (self->priv->pa_api, NULL, proplist); +- g_assert (self->priv->pa_context); +- pa_proplist_free (proplist); ++ gvc_mixer_new_pa_context (self); + + return object; + } +@@ -1607,6 +1670,14 @@ gvc_mixer_control_class_init (GvcMixerControlClass *klass) + object_class->dispose = gvc_mixer_control_dispose; + object_class->finalize = gvc_mixer_control_finalize; + ++ signals [CONNECTING] = ++ g_signal_new ("connecting", ++ G_TYPE_FROM_CLASS (klass), ++ G_SIGNAL_RUN_LAST, ++ G_STRUCT_OFFSET (GvcMixerControlClass, connecting), ++ NULL, NULL, ++ g_cclosure_marshal_VOID__VOID, ++ G_TYPE_NONE, 0); + signals [READY] = + g_signal_new ("ready", + G_TYPE_FROM_CLASS (klass), +diff --git a/gnome-volume-control/src/gvc-mixer-control.h b/gnome-volume-control/src/gvc-mixer-control.h +index 33e745a..3de9e62 100644 +--- a/gnome-volume-control/src/gvc-mixer-control.h ++++ b/gnome-volume-control/src/gvc-mixer-control.h +@@ -46,6 +46,7 @@ typedef struct + { + GObjectClass parent_class; + ++ void (*connecting) (GvcMixerControl *control); + void (*ready) (GvcMixerControl *control); + void (*stream_added) (GvcMixerControl *control, + guint id); +-- +cgit v0.8.2 diff --git a/gnome-extra/gnome-media/gnome-media-2.26.0.ebuild b/gnome-extra/gnome-media/gnome-media-2.26.0-r1.ebuild index 3bcfb5bc310d..285e12cbc498 100644 --- a/gnome-extra/gnome-media/gnome-media-2.26.0.ebuild +++ b/gnome-extra/gnome-media/gnome-media-2.26.0-r1.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2009 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/gnome-extra/gnome-media/gnome-media-2.26.0.ebuild,v 1.5 2009/08/23 21:48:12 eva Exp $ +# $Header: /var/cvsroot/gentoo-x86/gnome-extra/gnome-media/gnome-media-2.26.0-r1.ebuild,v 1.1 2009/09/12 11:38:18 nirbheek Exp $ EAPI="2" @@ -73,6 +73,10 @@ src_prepare() { if use gnomecd; then epatch "${FILESDIR}/${P}-missing-cddbslave-cflags.patch" fi + + # Half-fix bug 274819 -- applet does not work when PA restarts (not needed with 2.28) + epatch "${FILESDIR}/${P}-connection-failed-pulseaudio.patch" + # Fix automagic canberra support epatch "${FILESDIR}/${P}-automagic-canberra.patch" eautoreconf |