summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNirbheek Chauhan <nirbheek@gentoo.org>2009-09-12 11:38:19 +0000
committerNirbheek Chauhan <nirbheek@gentoo.org>2009-09-12 11:38:19 +0000
commitb264040ea7ac79098a5118c0beb7edd7267739d2 (patch)
tree2500e0ad3246082268b42dfee3c262cffa7ce484 /gnome-extra
parentamd64 stable (diff)
downloadgentoo-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/ChangeLog10
-rw-r--r--gnome-extra/gnome-media/files/gnome-media-2.26.0-connection-failed-pulseaudio.patch321
-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