[arch-commits] Commit in cinnamon-screensaver/trunk (2 files)

Balló György bgyorgy at nymeria.archlinux.org
Tue Aug 27 14:57:44 UTC 2013


    Date: Tuesday, August 27, 2013 @ 16:57:44
  Author: bgyorgy
Revision: 96402

upgpkg: cinnamon-screensaver 1.8.0-2

Lock screen on suspend with systemd

Added:
  cinnamon-screensaver/trunk/lock_screen_on_suspend.patch
Modified:
  cinnamon-screensaver/trunk/PKGBUILD

------------------------------+
 PKGBUILD                     |   11 ++++++--
 lock_screen_on_suspend.patch |   51 +++++++++++++++++++++++++++++++++++++++++
 2 files changed, 59 insertions(+), 3 deletions(-)

Modified: PKGBUILD
===================================================================
--- PKGBUILD	2013-08-27 14:39:57 UTC (rev 96401)
+++ PKGBUILD	2013-08-27 14:57:44 UTC (rev 96402)
@@ -5,7 +5,7 @@
 
 pkgname=cinnamon-screensaver
 pkgver=1.8.0
-pkgrel=1
+pkgrel=2
 pkgdesc="Screensaver designed to integrate well with the Cinnamon desktop."
 arch=('i686' 'x86_64')
 license=('GPL')
@@ -16,10 +16,12 @@
 options=(!emptydirs)
 source=($pkgname-$pkgver.tar.gz::https://github.com/linuxmint/cinnamon-screensaver/archive/$pkgver.tar.gz
        cinnamon-screensaver.pam
-       fix-dbus-compatibility.patch)
+       fix-dbus-compatibility.patch
+       lock_screen_on_suspend.patch)
 sha256sums=('e85722d5af2ecbed98f50909285b335d7635214bf8cada49964f60bb5d1339c1'
             'b6ea9e2eb586d94bcabb617a8f1c2958111df87afdbb51f645882bccdc15cbda'
-            'eebd1d056c21d2d3f60fb954677b9214fd1d575ed1c2bbb56326cedf41a39eb6')
+            'eebd1d056c21d2d3f60fb954677b9214fd1d575ed1c2bbb56326cedf41a39eb6'
+            '516c479558576c6c5a2509abfcbf4fdafb5953d252e7a4ab972f9db6137daca8')
 
 build() {
   cd $pkgname-$pkgver
@@ -28,6 +30,9 @@
   # Fix compatibility with gnome-screensaver's D-Bus interface and various fixes
   patch -Np1 -i ${srcdir}/fix-dbus-compatibility.patch
 
+  # Lock screen on suspend with systemd
+  patch -Np1 -i ${srcdir}/lock_screen_on_suspend.patch
+
   ./autogen.sh --prefix=/usr --sysconfdir=/etc \
                --libexecdir=/usr/lib/cinnamon-screensaver \
                --localstatedir=/var \

Added: lock_screen_on_suspend.patch
===================================================================
--- lock_screen_on_suspend.patch	                        (rev 0)
+++ lock_screen_on_suspend.patch	2013-08-27 14:57:44 UTC (rev 96402)
@@ -0,0 +1,51 @@
+From f8f9beb6a3bf81240d36bfec43e5db9b102ea91e Mon Sep 17 00:00:00 2001
+From: Martin Pitt <martinpitt at gnome.org>
+Date: Wed, 1 May 2013 10:55:49 -0700
+Subject: [PATCH] Lock screen on suspend
+
+Listen for logind's PrepareForSleep signal, and lock the screen (if configured
+to do so). This mirrors what gnome-shell's screensaver does.
+---
+ src/gs-listener-dbus.c | 28 ++++++++++++++++++++++++++++
+ src/gs-listener-dbus.h |  1 +
+ src/gs-monitor.c       | 20 ++++++++++++++++++++
+ 3 files changed, 49 insertions(+)
+
+diff --git a/src/gs-listener-dbus.c b/src/gs-listener-dbus.c
+index 7f718fa..49586fd 100644
+--- a/src/gs-listener-dbus.c
++++ b/src/gs-listener-dbus.c
+@@ -871,6 +872,17 @@ listener_dbus_handle_system_message (DBusConnection *connection,
+                         }
+ 
+                         return DBUS_HANDLER_RESULT_HANDLED;
++                } else if (dbus_message_is_signal (message, SYSTEMD_LOGIND_INTERFACE, "PrepareForSleep")) {
++                        gboolean active;
++                        if (dbus_message_get_args (message, NULL,
++                                    DBUS_TYPE_BOOLEAN, &active,
++                                    DBUS_TYPE_INVALID) && active) {
++                                gs_debug ("systemd notified that system is about to sleep");
++                                g_signal_emit (listener, signals [LOCK], 0);
++                        } else {
++                                gs_debug ("cannot parse PrepareForSleep");
++                        }
++                        return DBUS_HANDLER_RESULT_HANDLED;
+                 } else if (dbus_message_is_signal (message, DBUS_INTERFACE_PROPERTIES, "PropertiesChanged")) {
+ 
+                         if (_listener_message_path_is_our_session (listener, message)) {
+@@ -1370,6 +1392,12 @@ gs_listener_acquire (GSListener *listener,
+                                             ",interface='"DBUS_INTERFACE_PROPERTIES"'"
+                                             ",member='PropertiesChanged'",
+                                             NULL);
++                        dbus_bus_add_match (listener->priv->system_connection,
++                                            "type='signal'"
++                                            ",sender='"SYSTEMD_LOGIND_SERVICE"'"
++                                            ",interface='"SYSTEMD_LOGIND_INTERFACE"'"
++                                            ",member='PrepareForSleep'",
++                                            NULL);
+ 
+                         return (res != -1);
+                 }
+-- 
+1.8.1.2
+




More information about the arch-commits mailing list