summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPacho Ramos <pacho@gentoo.org>2011-03-07 14:31:25 +0000
committerPacho Ramos <pacho@gentoo.org>2011-03-07 14:31:25 +0000
commiteada1f09cceeda71f64f639ca5974daa1b4a7687 (patch)
tree27aaddc8f2a5fdc299f9dd149f59022cccde46c2 /gnome-extra/gnome-screensaver
parentVersion bumped. (diff)
downloadhistorical-eada1f09cceeda71f64f639ca5974daa1b4a7687.tar.gz
historical-eada1f09cceeda71f64f639ca5974daa1b4a7687.tar.bz2
historical-eada1f09cceeda71f64f639ca5974daa1b4a7687.zip
Revision bump with some fixes: The dialog uses libxklavier directly, so link against it (upstream bug #634949); fix QA warning (upstream bug #637676 by David J Cozatt); fix fading on nvidia setups (upstream bugs #610294 and #618932); don't run twice (upstream bug #642462), don't user name owner proxies for SessionManager (upstream bug #611207).
Package-Manager: portage-2.1.9.42/cvs/Linux x86_64
Diffstat (limited to 'gnome-extra/gnome-screensaver')
-rw-r--r--gnome-extra/gnome-screensaver/ChangeLog18
-rw-r--r--gnome-extra/gnome-screensaver/Manifest19
-rw-r--r--gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-libxklavier-configure.patch22
-rw-r--r--gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-name-manager.patch203
-rw-r--r--gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-nvidia-fade.patch44
-rw-r--r--gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-nvidia-fade2.patch65
-rw-r--r--gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-popsquares-header.patch13
-rw-r--r--gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-prevent-twice.patch64
-rw-r--r--gnome-extra/gnome-screensaver/gnome-screensaver-2.30.2-r1.ebuild144
9 files changed, 590 insertions, 2 deletions
diff --git a/gnome-extra/gnome-screensaver/ChangeLog b/gnome-extra/gnome-screensaver/ChangeLog
index 4d071024b07b..11d40ebf058a 100644
--- a/gnome-extra/gnome-screensaver/ChangeLog
+++ b/gnome-extra/gnome-screensaver/ChangeLog
@@ -1,6 +1,22 @@
# ChangeLog for gnome-extra/gnome-screensaver
# Copyright 1999-2011 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/gnome-extra/gnome-screensaver/ChangeLog,v 1.133 2011/03/07 09:27:50 nirbheek Exp $
+# $Header: /var/cvsroot/gentoo-x86/gnome-extra/gnome-screensaver/ChangeLog,v 1.134 2011/03/07 14:31:25 pacho Exp $
+
+*gnome-screensaver-2.30.2-r1 (07 Mar 2011)
+
+ 07 Mar 2011; Pacho Ramos <pacho@gentoo.org>
+ +gnome-screensaver-2.30.2-r1.ebuild,
+ +files/gnome-screensaver-2.30.2-libxklavier-configure.patch,
+ +files/gnome-screensaver-2.30.2-name-manager.patch,
+ +files/gnome-screensaver-2.30.2-nvidia-fade.patch,
+ +files/gnome-screensaver-2.30.2-nvidia-fade2.patch,
+ +files/gnome-screensaver-2.30.2-popsquares-header.patch,
+ +files/gnome-screensaver-2.30.2-prevent-twice.patch:
+ Revision bump with some fixes: The dialog uses libxklavier directly, so link
+ against it (upstream bug #634949); fix QA warning (upstream bug #637676 by
+ David J Cozatt); fix fading on nvidia setups (upstream bugs #610294 and
+ #618932); don't run twice (upstream bug #642462), don't user name owner
+ proxies for SessionManager (upstream bug #611207).
07 Mar 2011; Nirbheek Chauhan <nirbheek@gentoo.org>
gnome-screensaver-2.30.2.ebuild,
diff --git a/gnome-extra/gnome-screensaver/Manifest b/gnome-extra/gnome-screensaver/Manifest
index 3656acaf1800..6926fff70671 100644
--- a/gnome-extra/gnome-screensaver/Manifest
+++ b/gnome-extra/gnome-screensaver/Manifest
@@ -1,10 +1,27 @@
+-----BEGIN PGP SIGNED MESSAGE-----
+Hash: SHA1
+
AUX gentoologo-floaters.desktop 414 RMD160 5a34dd8a7b083c1d94e4298c4644d23c7b7f5130 SHA1 a7a38434fd010a1b34d9f9951576752e9691a2b5 SHA256 d8ae7a179c24167d70bb7712eda48807f10b09bce0f32b7f521af21654b641f9
AUX gnome-screensaver-2.30.2-libnotify-0.7.patch 708 RMD160 be33bce94e652cecc5e11ec7d25205e9b8e2ffbf SHA1 c0d1e45306d3dc81266dd4c8269920258b79e3e0 SHA256 09bd31d89527e489b0b21e5cd4f432522205b573db57729a86046d7e85e53656
+AUX gnome-screensaver-2.30.2-libxklavier-configure.patch 1058 RMD160 be44d2e1d0b4030e2d4218161b2cf0d8ae42f378 SHA1 271cc097c1c2dc04b89b2882188b0102d384e815 SHA256 5049c105315841c034e96dd99c9410cefde0bcf827a6430b8c93318ddc2aadf0
+AUX gnome-screensaver-2.30.2-name-manager.patch 9104 RMD160 1593fdff597e575f41e2d218b302e17d2ccaa451 SHA1 52dde2cd2c65d071eb03ca67489fc930a32beabe SHA256 12b19edd2fe2b93963e5496244f2c2a429db1f65a8dcfe90fb8f7801e57279d3
+AUX gnome-screensaver-2.30.2-nvidia-fade.patch 1745 RMD160 f334375d782b782e776205d1adaf2c8833cb1462 SHA1 2c71b90573ab127d6347d632f1c5505322a9f726 SHA256 1f4331c5a1aff5883668058955b5e199fc65f15792a43e8c6fcc2ab64195fa89
+AUX gnome-screensaver-2.30.2-nvidia-fade2.patch 2352 RMD160 3212ddbd246618742e62b9e8e19307d8753575a5 SHA1 c073fa084b3ec5f649390f1c0e7878cb848d03f4 SHA256 40921fbb02460854914fb1e47fea2b8192267f3e933c52ffd9c8ddedb94766f3
+AUX gnome-screensaver-2.30.2-popsquares-header.patch 312 RMD160 9e10ce6258a519dc58fbd73e5712d6f8abd1c309 SHA1 97154fc3a0f49c4e4013ac65f892ed0da7f5bd9d SHA256 e6b7f6bab6f48c60892e53865732e65b36230a0e6e81d8c3fcb6fe66b8e7d775
+AUX gnome-screensaver-2.30.2-prevent-twice.patch 2300 RMD160 d06e4753af978a8c343139f13f5cf119f3b3e5fc SHA1 1e1d4b91a7aa3773c26d81f1452f3a605320775b SHA256 5149e9eb3d7eae968748a0eb37abd021098f22fd4b350e032e468ec574429bb8
AUX xss-conversion-2.txt 1026 RMD160 5a1810d1f41999907ff39adf0e6396d1d6f5c5d7 SHA1 477743e8fd025cff16c1b2ed538a57ce9550a9cf SHA256 f1bcc5e85d45e53e6170d0cdf25dd3d10020aeef545cf2fdea5e3b4b30ec86c8
DIST gentoo-logo.svg 13764 RMD160 62b740f670377486eb1350c4f180d9f0ab63948c SHA1 a81d7fb4be541547be78d648bbeb0d3c51f1a41e SHA256 ad81a212991cd24faaddbc260c806c805fd7a67f65b24655908a8971fa10794e
DIST gnome-screensaver-2.30.0.tar.bz2 4803639 RMD160 672ccfec0c57fac4585d299977b9142a7acc1c8d SHA1 4ceb44d17d8c6ff132e6785e7e7c6f48d7039e1d SHA256 f653d3e4a872d435bce9d74ea8d14e54090c4c803521d5fe940e948c1dccc060
DIST gnome-screensaver-2.30.2.tar.bz2 4814653 RMD160 1b13722f3bebca709b9f44c45e995d07ed6c2044 SHA1 f9d7c0df0efaa6916099ca56078da8b36f4c4935 SHA256 dd52ef278b23ec5abe5974548c2d576eeaeb5294c85e9f2efd6231ecc9ca09fa
EBUILD gnome-screensaver-2.30.0.ebuild 3566 RMD160 014805247ba7553b005644ad03d67eda7649d8a4 SHA1 a4577d7c4ec32abc86ee93efa3acc0d5f4b49119 SHA256 e1b811eb28f1f13ba3743d35c9b28f2bfc15bcb9de3e655f92359a7ddc7d7574
+EBUILD gnome-screensaver-2.30.2-r1.ebuild 4389 RMD160 a8124f24875eec6c0e8895e7f1b063a27231009d SHA1 1abe1cad6fe466359a7eea037f824b0593e3dd37 SHA256 965c86742a6fe5150d76a4bfad71a897c44569086341192d893af2476bdf96b1
EBUILD gnome-screensaver-2.30.2.ebuild 3695 RMD160 a05ae00460ea42b432d22c92f4fcc4a784ba0046 SHA1 30f15492e88d74491889c0b3fdfa951b5f336fc9 SHA256 07c472186809d3f58d74ba1c1760d585d7899f470356dc95e895dc9665b102c6
-MISC ChangeLog 21251 RMD160 7a9b27f71ddd2814e2d0c0528eb3920b8be6b16f SHA1 b97da1048b71a95217d959007a701e401e90015f SHA256 9b7e6c62b64da09f2df7aca97649c3b686c496b5884ca3ff58884662224ecfa0
+MISC ChangeLog 22073 RMD160 8d79b2db293b5b6234e8e27fa63996eacaa39e18 SHA1 aba0a357acb9553a22ba7111f7f29b430021649c SHA256 66daf8ea55816c1de23b1f2be61b94dfa2b0b6d45db2986c8f82924ac0308862
MISC metadata.xml 371 RMD160 dfd5191336607cf3a6693f63252b562406e1a356 SHA1 b44c1782c057b3258bb13f9e5cfe1bc5235edac1 SHA256 082f57713bdf91aa34c880c0172500802e78dde1c461d88478e957691f4b7699
+-----BEGIN PGP SIGNATURE-----
+Version: GnuPG v2.0.17 (GNU/Linux)
+
+iEYEARECAAYFAk107EIACgkQCaWpQKGI+9TyQQCfaD+h1rAukBtWYfgapgtWtqlD
+UC0An0U/WFt8+n0Y1VvbYu3EyHe/GS1P
+=zyP/
+-----END PGP SIGNATURE-----
diff --git a/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-libxklavier-configure.patch b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-libxklavier-configure.patch
new file mode 100644
index 000000000000..3c8d1ffed7bc
--- /dev/null
+++ b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-libxklavier-configure.patch
@@ -0,0 +1,22 @@
+From 1b4c2717763275375967f2279e065a65852967cb Mon Sep 17 00:00:00 2001
+From: Robert Ancell <robert.ancell@canonical.com>
+Date: Tue, 16 Nov 2010 22:01:41 +0000
+Subject: The dialog uses libxklavier directly, so link against it
+
+https://bugzilla.gnome.org/show_bug.cgi?id=634949
+---
+diff --git a/configure.ac b/configure.ac
+index a2379f2..a80b92a 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -643,7 +643,7 @@ have_libgnomekbdui=no
+ AC_ARG_WITH(kbd-layout-indicator,[ --without-kbd-layout-indicator disable keyboard layout indicator],
+ [with_kbd_layout_indicator="$withval"],[with_kbd_layout_indicator=yes])
+ if test x$with_kbd_layout_indicator != xno; then
+- PKG_CHECK_MODULES(LIBGNOMEKBDUI, libgnomekbdui >= $LIBGNOMEKBDUI_REQUIRED_VERSION, have_libgnomekbdui=yes, have_libgnomekbdui=no)
++ PKG_CHECK_MODULES(LIBGNOMEKBDUI, libgnomekbdui >= $LIBGNOMEKBDUI_REQUIRED_VERSION libxklavier, have_libgnomekbdui=yes, have_libgnomekbdui=no)
+ fi
+ if test "x$have_libgnomekbdui" = "xyes"; then
+ AC_SUBST(LIBGNOMEKBDUI_CFLAGS)
+--
+cgit v0.8.3.4
diff --git a/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-name-manager.patch b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-name-manager.patch
new file mode 100644
index 000000000000..febffb52594b
--- /dev/null
+++ b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-name-manager.patch
@@ -0,0 +1,203 @@
+From d0b09165b8fb4af6a59308665f38438aa657aae2 Mon Sep 17 00:00:00 2001
+From: Ross Burton <ross@linux.intel.com>
+Date: Fri, 26 Feb 2010 18:15:39 +0000
+Subject: Don't user name owner proxies for SessionManager
+
+Using proxies based on the name owner will fail if the name owner changes, for
+example if gnome-session is started after the screensaver or if gnome-session is
+restarted.
+
+https://bugzilla.gnome.org/show_bug.cgi?id=611207
+---
+diff --git a/src/gs-watcher-x11.c b/src/gs-watcher-x11.c
+index 7145448..ec63552 100644
+--- a/src/gs-watcher-x11.c
++++ b/src/gs-watcher-x11.c
+@@ -388,112 +388,94 @@ on_presence_status_text_changed (DBusGProxy *presence_proxy,
+ set_status_text (watcher, status_text);
+ }
+
+-static gboolean
++static void
+ connect_presence_watcher (GSWatcher *watcher)
+ {
+- DBusGConnection *bus;
+- GError *error;
+- gboolean ret;
+-
+- ret = FALSE;
++ DBusGConnection *bus;
++ GError *error;
++ DBusGProxy *proxy;
++ guint status;
++ const char *status_text;
++ GValue value = { 0, };
+
+ error = NULL;
+ bus = dbus_g_bus_get (DBUS_BUS_SESSION, &error);
+ if (bus == NULL) {
+ g_warning ("Unable to get session bus: %s", error->message);
+ g_error_free (error);
+- goto done;
++ return;
+ }
+
++ watcher->priv->presence_proxy = dbus_g_proxy_new_for_name (bus,
++ "org.gnome.SessionManager",
++ "/org/gnome/SessionManager/Presence",
++ "org.gnome.SessionManager.Presence");
++
++ dbus_g_proxy_add_signal (watcher->priv->presence_proxy,
++ "StatusChanged",
++ G_TYPE_UINT,
++ G_TYPE_INVALID);
++ dbus_g_proxy_connect_signal (watcher->priv->presence_proxy,
++ "StatusChanged",
++ G_CALLBACK (on_presence_status_changed),
++ watcher,
++ NULL);
++ dbus_g_proxy_add_signal (watcher->priv->presence_proxy,
++ "StatusTextChanged",
++ G_TYPE_STRING,
++ G_TYPE_INVALID);
++ dbus_g_proxy_connect_signal (watcher->priv->presence_proxy,
++ "StatusTextChanged",
++ G_CALLBACK (on_presence_status_text_changed),
++ watcher,
++ NULL);
++
++ proxy = dbus_g_proxy_new_from_proxy (watcher->priv->presence_proxy,
++ "org.freedesktop.DBus.Properties",
++ "/org/gnome/SessionManager/Presence");
++
++ status = 0;
++ status_text = NULL;
++
+ error = NULL;
+- watcher->priv->presence_proxy = dbus_g_proxy_new_for_name_owner (bus,
+- "org.gnome.SessionManager",
+- "/org/gnome/SessionManager/Presence",
+- "org.gnome.SessionManager.Presence",
+- &error);
+- if (watcher->priv->presence_proxy != NULL) {
+- DBusGProxy *proxy;
+-
+- dbus_g_proxy_add_signal (watcher->priv->presence_proxy,
+- "StatusChanged",
+- G_TYPE_UINT,
+- G_TYPE_INVALID);
+- dbus_g_proxy_connect_signal (watcher->priv->presence_proxy,
+- "StatusChanged",
+- G_CALLBACK (on_presence_status_changed),
+- watcher,
+- NULL);
+- dbus_g_proxy_add_signal (watcher->priv->presence_proxy,
+- "StatusTextChanged",
+- G_TYPE_STRING,
+- G_TYPE_INVALID);
+- dbus_g_proxy_connect_signal (watcher->priv->presence_proxy,
+- "StatusTextChanged",
+- G_CALLBACK (on_presence_status_text_changed),
+- watcher,
+- NULL);
+-
+- proxy = dbus_g_proxy_new_from_proxy (watcher->priv->presence_proxy,
+- "org.freedesktop.DBus.Properties",
+- "/org/gnome/SessionManager/Presence");
+- if (proxy != NULL) {
+- guint status;
+- const char *status_text;
+- GValue value = { 0, };
+-
+- status = 0;
+- status_text = NULL;
+-
+- error = NULL;
+- dbus_g_proxy_call (proxy,
+- "Get",
+- &error,
+- G_TYPE_STRING, "org.gnome.SessionManager.Presence",
+- G_TYPE_STRING, "status",
+- G_TYPE_INVALID,
+- G_TYPE_VALUE, &value,
+- G_TYPE_INVALID);
+-
+- if (error != NULL) {
+- g_warning ("Couldn't get presence status: %s", error->message);
+- g_error_free (error);
+- goto done;
+- } else {
+- status = g_value_get_uint (&value);
+- }
+-
+- g_value_unset (&value);
+-
+- error = NULL;
+- dbus_g_proxy_call (proxy,
+- "Get",
+- &error,
+- G_TYPE_STRING, "org.gnome.SessionManager.Presence",
+- G_TYPE_STRING, "status-text",
+- G_TYPE_INVALID,
+- G_TYPE_VALUE, &value,
+- G_TYPE_INVALID);
+-
+- if (error != NULL) {
+- g_warning ("Couldn't get presence status text: %s", error->message);
+- g_error_free (error);
+- } else {
+- status_text = g_value_get_string (&value);
+- }
+-
+- set_status (watcher, status);
+- set_status_text (watcher, status_text);
+- }
+- } else {
+- g_warning ("Failed to get session presence proxy: %s", error->message);
++ dbus_g_proxy_call (proxy,
++ "Get",
++ &error,
++ G_TYPE_STRING, "org.gnome.SessionManager.Presence",
++ G_TYPE_STRING, "status",
++ G_TYPE_INVALID,
++ G_TYPE_VALUE, &value,
++ G_TYPE_INVALID);
++
++ if (error != NULL) {
++ g_warning ("Couldn't get presence status: %s", error->message);
+ g_error_free (error);
+- goto done;
++ return;
++ } else {
++ status = g_value_get_uint (&value);
+ }
+
+- ret = TRUE;
++ g_value_unset (&value);
++
++ error = NULL;
++ dbus_g_proxy_call (proxy,
++ "Get",
++ &error,
++ G_TYPE_STRING, "org.gnome.SessionManager.Presence",
++ G_TYPE_STRING, "status-text",
++ G_TYPE_INVALID,
++ G_TYPE_VALUE, &value,
++ G_TYPE_INVALID);
++
++ if (error != NULL) {
++ g_warning ("Couldn't get presence status text: %s", error->message);
++ g_error_free (error);
++ } else {
++ status_text = g_value_get_string (&value);
++ }
+
+- done:
+- return ret;
++ set_status (watcher, status);
++ set_status_text (watcher, status_text);
+ }
+
+ static void
+--
+cgit v0.8.3.4
diff --git a/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-nvidia-fade.patch b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-nvidia-fade.patch
new file mode 100644
index 000000000000..240cb162c773
--- /dev/null
+++ b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-nvidia-fade.patch
@@ -0,0 +1,44 @@
+
+++ gnome-screensaver-2.30.2/debian/patches/13_nvidia_gamma_fade_fallback.patch
+
+Description: Fall back to XF86VM gamma fade if XRANDR gamma fade is not supported
+Author: Chris Coulson <chrisccoulson@ubuntu.com>
+Bug-Ubuntu: https://bugs.edge.launchpad.net/ubuntu/+source/gnome-screensaver/+bug/522806
+Bug: https://bugzilla.gnome.org/show_bug.cgi?id=610294
+Forwarded: https://bugzilla.gnome.org/show_bug.cgi?id=610294
+
+Index: gnome-screensaver-2.30.2/src/gs-fade.c
+===================================================================
+--- gnome-screensaver-2.30.2.orig/src/gs-fade.c 2010-11-15 17:13:12.730491003 +1100
++++ gnome-screensaver-2.30.2/src/gs-fade.c 2010-11-15 17:13:16.838491003 +1100
+@@ -572,6 +572,10 @@
+ GdkDisplay *display = gdk_display_get_default ();
+ GdkScreen *screen = gdk_display_get_screen (display, screen_idx);
+ struct GSFadeScreenPrivate *screen_priv;
++ GnomeRRCrtc **crtcs;
++ GnomeRRCrtc *crtc;
++ gboolean res;
++ int gamma_size;
+
+ screen_priv = &fade->priv->screen_priv[screen_idx];
+
+@@ -584,6 +588,19 @@
+ return;
+ }
+
++ crtcs = gnome_rr_screen_list_crtcs (screen_priv->rrscreen);
++
++ while (*crtcs)
++ {
++ crtc = *crtcs;
++ res = gnome_rr_crtc_get_gamma (crtc, &gamma_size, NULL, NULL, NULL);
++ if (res == FALSE || gamma_size == 0) {
++ screen_priv->fade_type = FADE_TYPE_NONE;
++ return;
++ }
++ crtcs++;
++ }
++
+ screen_priv->fade_type = FADE_TYPE_XRANDR;
+ screen_priv->fade_setup = xrandr_fade_setup;
+ screen_priv->fade_finish = screen_fade_finish;
diff --git a/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-nvidia-fade2.patch b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-nvidia-fade2.patch
new file mode 100644
index 000000000000..255add876662
--- /dev/null
+++ b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-nvidia-fade2.patch
@@ -0,0 +1,65 @@
+
+++ gnome-screensaver-2.30.2/debian/patches/16_dont_crash_in_kvm.patch
+
+Description: Don't crash when the XF86VM extension doesn't allow the gamma to be set
+ On some systems where the XF86VM extension is present, the gamma value
+ can be read successfully with XF86VidModeGetGamma but attempting to
+ change the gamma value with XF86VidModeSetGamma will result in a
+ BadValue error (eg, on KVM).
+
+ Trap this error and abort the fade rather than crashing.
+Bug-Ubuntu: https://launchpad.net/bugs/581864
+Bug: https://bugzilla.gnome.org/show_bug.cgi?id=618932
+Forwarded: https://bugzilla.gnome.org/attachment.cgi?id=161276
+Author: Chris Coulson <chris.coulson@canonical.com>
+
+Index: gnome-screensaver-2.30.2/src/gs-fade.c
+===================================================================
+--- gnome-screensaver-2.30.2.orig/src/gs-fade.c 2010-11-15 16:35:43.078663002 +1100
++++ gnome-screensaver-2.30.2/src/gs-fade.c 2010-11-15 16:37:45.814662558 +1100
+@@ -208,7 +208,13 @@
+ g2.blue = XF86_MIN_GAMMA;
+ }
+
++ gdk_error_trap_push ();
+ status = XF86VidModeSetGamma (GDK_DISPLAY (), screen, &g2);
++ gdk_flush ();
++ if (gdk_error_trap_pop ()) {
++ gs_debug ("Failed to set gamma. Bailing out and aborting fade");
++ return FALSE;
++ }
+ } else {
+
+ # ifdef HAVE_XF86VMODE_GAMMA_RAMP
+@@ -225,7 +231,13 @@
+ b[i] = gamma_info->b[i] * ratio;
+ }
+
++ gdk_error_trap_push ();
+ status = XF86VidModeSetGammaRamp (GDK_DISPLAY (), screen, gamma_info->size, r, g, b);
++ gdk_flush ();
++ if (gdk_error_trap_pop ()) {
++ gs_debug ("Failed to set gamma. Bailing out and aborting fade");
++ return FALSE;
++ }
+
+ g_free (r);
+ g_free (g);
+@@ -236,8 +248,6 @@
+ # endif /* !HAVE_XF86VMODE_GAMMA_RAMP */
+ }
+
+- gdk_flush ();
+-
+ return status;
+ }
+
+@@ -391,7 +401,7 @@
+ screen_priv = &fade->priv->screen_priv[screen_idx];
+ res = xf86_whack_gamma (screen_idx, screen_priv, alpha);
+
+- return TRUE;
++ return res;
+ }
+ #endif /* HAVE_XF86VMODE_GAMMA */
+
diff --git a/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-popsquares-header.patch b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-popsquares-header.patch
new file mode 100644
index 000000000000..f6d7d5366b6a
--- /dev/null
+++ b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-popsquares-header.patch
@@ -0,0 +1,13 @@
+Patch for implicit declaration of exit in popsquares.c reported by Gentoo QA
+patch generated by David J Cozatt
+
+--- savers/popsquares.c
++++ savers/popsquares.c
+@@ -22,6 +22,7 @@
+ #include "config.h"
+
+ #include <string.h>
++#include <stdlib.h>
+ #include <gdk/gdk.h>
+ #include <gdk/gdkx.h>
+ #include <gtk/gtk.h>
diff --git a/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-prevent-twice.patch b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-prevent-twice.patch
new file mode 100644
index 000000000000..85b58905c836
--- /dev/null
+++ b/gnome-extra/gnome-screensaver/files/gnome-screensaver-2.30.2-prevent-twice.patch
@@ -0,0 +1,64 @@
+From 85d22a5d784b2b8201054257f8696138de1e1b70 Mon Sep 17 00:00:00 2001
+From: Marc Deslauriers <marc.deslauriers@ubuntu.com>
+Date: Wed, 16 Feb 2011 13:40:15 +0000
+Subject: Make sure it cannot be running twice
+
+It is currently possible to start gnome-screensaver twice because
+of a race condition. This change makes sure that we bail out if
+we cannot become the primary owner of the bus name.
+
+https://bugzilla.gnome.org/show_bug.cgi?id=642462
+---
+diff --git a/src/gs-listener-dbus.c b/src/gs-listener-dbus.c
+index 6d0d4e5..e11c7fc 100644
+--- a/src/gs-listener-dbus.c
++++ b/src/gs-listener-dbus.c
+@@ -1169,7 +1169,7 @@ gboolean
+ gs_listener_acquire (GSListener *listener,
+ GError **error)
+ {
+- gboolean acquired;
++ int res;
+ DBusError buserror;
+ gboolean is_connected;
+
+@@ -1213,9 +1213,10 @@ gs_listener_acquire (GSListener *listener,
+ return FALSE;
+ }
+
+- acquired = dbus_bus_request_name (listener->priv->connection,
+- GS_LISTENER_SERVICE,
+- 0, &buserror) != -1;
++ res = dbus_bus_request_name (listener->priv->connection,
++ GS_LISTENER_SERVICE,
++ DBUS_NAME_FLAG_DO_NOT_QUEUE,
++ &buserror);
+ if (dbus_error_is_set (&buserror)) {
+ g_set_error (error,
+ GS_LISTENER_ERROR,
+@@ -1223,6 +1224,14 @@ gs_listener_acquire (GSListener *listener,
+ "%s",
+ buserror.message);
+ }
++ if (res == DBUS_REQUEST_NAME_REPLY_EXISTS) {
++ g_set_error (error,
++ GS_LISTENER_ERROR,
++ GS_LISTENER_ERROR_ACQUISITION_FAILURE,
++ "%s",
++ _("screensaver already running in this session"));
++ return FALSE;
++ }
+
+ dbus_error_free (&buserror);
+
+@@ -1263,7 +1272,7 @@ gs_listener_acquire (GSListener *listener,
+ NULL);
+ }
+
+- return acquired;
++ return (res != -1);
+ }
+
+ static char *
+--
+cgit v0.8.3.4
diff --git a/gnome-extra/gnome-screensaver/gnome-screensaver-2.30.2-r1.ebuild b/gnome-extra/gnome-screensaver/gnome-screensaver-2.30.2-r1.ebuild
new file mode 100644
index 000000000000..dbd2d4d32eb9
--- /dev/null
+++ b/gnome-extra/gnome-screensaver/gnome-screensaver-2.30.2-r1.ebuild
@@ -0,0 +1,144 @@
+# Copyright 1999-2011 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/gnome-extra/gnome-screensaver/gnome-screensaver-2.30.2-r1.ebuild,v 1.1 2011/03/07 14:31:25 pacho Exp $
+
+EAPI="2"
+
+inherit eutils gnome2 multilib autotools
+
+DESCRIPTION="Replaces xscreensaver, integrating with the desktop."
+HOMEPAGE="http://live.gnome.org/GnomeScreensaver"
+SRC_URI="${SRC_URI}
+ branding? ( http://www.gentoo.org/images/gentoo-logo.svg )"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~ia64 ~ppc ~ppc64 ~sparc ~x86 ~x86-fbsd"
+KERNEL_IUSE="kernel_linux"
+IUSE="branding debug doc libnotify opengl pam $KERNEL_IUSE"
+
+RDEPEND=">=gnome-base/gconf-2.6.1
+ >=x11-libs/gtk+-2.14.0
+ >=gnome-base/gnome-desktop-2.29.0:2
+ >=gnome-base/gnome-menus-2.12
+ >=dev-libs/glib-2.15
+ >=gnome-base/libgnomekbd-0.1
+ >=dev-libs/dbus-glib-0.71
+ libnotify? ( x11-libs/libnotify )
+ opengl? ( virtual/opengl )
+ pam? ( virtual/pam )
+ !pam? ( kernel_linux? ( sys-apps/shadow ) )
+ x11-libs/libX11
+ x11-libs/libXext
+ x11-libs/libXrandr
+ x11-libs/libXScrnSaver
+ x11-libs/libXxf86misc
+ x11-libs/libXxf86vm"
+DEPEND="${RDEPEND}
+ >=dev-util/pkgconfig-0.9
+ >=dev-util/intltool-0.40
+ doc? (
+ app-text/xmlto
+ ~app-text/docbook-xml-dtd-4.1.2
+ ~app-text/docbook-xml-dtd-4.4 )
+ x11-proto/xextproto
+ x11-proto/randrproto
+ x11-proto/scrnsaverproto
+ x11-proto/xf86miscproto"
+
+DOCS="AUTHORS ChangeLog HACKING NEWS README TODO"
+
+pkg_setup() {
+ G2CONF="${G2CONF}
+ $(use_enable doc docbook-docs)
+ $(use_enable debug)
+ $(use_with libnotify)
+ $(use_with opengl gl)
+ $(use_enable pam)
+ --enable-locking
+ --with-xf86gamma-ext
+ --with-kbd-layout-indicator
+ --with-xscreensaverdir=/usr/share/xscreensaver/config
+ --with-xscreensaverhackdir=/usr/$(get_libdir)/misc/xscreensaver"
+}
+
+src_prepare() {
+ gnome2_src_prepare
+
+ # libnotify support was removed from trunk, so not needed for next release
+ epatch "${FILESDIR}/${P}-libnotify-0.7.patch"
+
+ # The dialog uses libxklavier directly, so link against it, upstream bug #634949
+ epatch "${FILESDIR}/${P}-libxklavier-configure.patch"
+
+ # Fix QA warning, upstream bug #637676
+ epatch "${FILESDIR}/${P}-popsquares-header.patch"
+
+ # Fix fading on nvidia setups, upstream bugs #610294 and #618932
+ epatch "${FILESDIR}/${P}-nvidia-fade.patch"
+ epatch "${FILESDIR}/${P}-nvidia-fade2.patch"
+
+ # Don't run twice, upstream bug #642462
+ epatch "${FILESDIR}/${P}-prevent-twice.patch"
+
+ # Don't user name owner proxies for SessionManager, upstream bug #611207
+ epatch "${FILESDIR}/${P}-name-manager.patch"
+
+ # Fix intltoolize broken file, see upstream #577133
+ sed "s:'\^\$\$lang\$\$':\^\$\$lang\$\$:g" -i po/Makefile.in.in \
+ || die "sed failed"
+
+ intltoolize --force --copy --automake || die "intltoolize failed"
+ eautoreconf
+}
+
+src_install() {
+ gnome2_src_install
+
+ # Install the conversion script in the documentation
+ dodoc "${S}/data/migrate-xscreensaver-config.sh"
+ dodoc "${S}/data/xscreensaver-config.xsl"
+
+ # Conversion information
+ sed -e "s:\${PF}:${PF}:" < "${FILESDIR}/xss-conversion-2.txt" \
+ > "${S}/xss-conversion.txt" || die "sed failed"
+
+ dodoc "${S}/xss-conversion.txt"
+
+ # Non PAM users will need this suid to read the password hashes.
+ # OpenPAM users will probably need this too when
+ # http://bugzilla.gnome.org/show_bug.cgi?id=370847
+ # is fixed.
+ if ! use pam ; then
+ fperms u+s /usr/libexec/gnome-screensaver-dialog
+ fi
+
+ if use branding ; then
+ insinto /usr/share/pixmaps/
+ doins "${DISTDIR}/gentoo-logo.svg" || die "doins 1 failed"
+ insinto /usr/share/applications/screensavers/
+ doins "${FILESDIR}/gentoologo-floaters.desktop" || die "doins 2 failed"
+ fi
+}
+
+pkg_postinst() {
+ gnome2_pkg_postinst
+
+ if has_version "<x11-base/xorg-server-1.5.3-r4" ; then
+ ewarn "You have a too old xorg-server installation. This will cause"
+ ewarn "gnome-screensaver to eat up your CPU. Please consider upgrading."
+ echo
+ fi
+
+ if has_version "<x11-misc/xscreensaver-4.22-r2" ; then
+ ewarn "You have xscreensaver installed, you probably want to disable it."
+ ewarn "To prevent a duplicate screensaver entry in the menu, you need to"
+ ewarn "build xscreensaver with -gnome in the USE flags."
+ ewarn "echo \"x11-misc/xscreensaver -gnome\" >> /etc/portage/package.use"
+
+ echo
+ fi
+
+ elog "Information for converting screensavers is located in "
+ elog "/usr/share/doc/${PF}/xss-conversion.txt.${PORTAGE_COMPRESS}"
+}