Sophie

Sophie

distrib > Fedora > 16 > x86_64 > media > updates-src > by-pkgid > 247d284e43936a2362a1b7252fbc7393 > files > 2

slock-0.9-10.fc16.src.rpm

# HG changeset patch
# User anselm@garbe.us
# Date 1327255090 -3600
# Node ID 0797174221851261d7023091c14eea4cf8ea5bf5
# Parent  d8975fb0640f10fd947ff9be92779156a9f4caaf
added dummy error handler to prevent X from terminating slock just in case

diff -r d8975fb0640f -r 079717422185 slock.c
--- a/slock.c	Thu Apr 21 08:22:47 2011 +0000
+++ b/slock.c	Sun Jan 22 18:58:10 2012 +0100
@@ -46,7 +46,7 @@
 
 #ifndef HAVE_BSD_AUTH
 static const char *
-get_password(void) { /* only run as root */
+getpw(void) { /* only run as root */
 	const char *rval;
 	struct passwd *pw;
 
@@ -74,9 +74,9 @@
 
 static void
 #ifdef HAVE_BSD_AUTH
-read_password(Display *dpy)
+readpw(Display *dpy)
 #else
-read_password(Display *dpy, const char *pws)
+readpw(Display *dpy, const char *pws)
 #endif
 {
 	char buf[32], passwd[256];
@@ -213,6 +213,11 @@
 	exit(EXIT_FAILURE);
 }
 
+static int
+xerrordummy(Display *dpy, XErrorEvent *ee) {
+	return 0;
+}
+
 int
 main(int argc, char **argv) {
 #ifndef HAVE_BSD_AUTH
@@ -224,7 +229,7 @@
 	struct st_lock **locks;
 
 	if((argc == 2) && !strcmp("-v", argv[1]))
-		die("slock-%s, © 2006-2008 Anselm R Garbe", VERSION);
+		die("slock-%s, © 2006-2012 Anselm R Garbe", VERSION);
 	else if(argc != 1)
 		usage();
 
@@ -232,12 +237,13 @@
 		die("no passwd entry for you");
 
 #ifndef HAVE_BSD_AUTH
-	pws = get_password();
+	pws = getpw();
 #endif
 
 	if(!(dpy = XOpenDisplay(0)))
 		die("cannot open display");
-
+	/* prevent default error handler to take over */
+	XSetErrorHandler(xerrordummy);
 	/* Get the number of screens in display "dpy" and blank them all. */
 	nscreens = ScreenCount(dpy);
 	locks = malloc(sizeof(struct st_lock *) * nscreens);
@@ -251,9 +257,9 @@
 
 	/* Everything is now blank. Now wait for the correct password. */
 #ifdef HAVE_BSD_AUTH
-	read_password(dpy);
+	readpw(dpy);
 #else
-	read_password(dpy, pws);
+	readpw(dpy, pws);
 #endif
 
 	/* Password ok, unlock everything and quit. */