fixed DPMS crashing issue
authorAnselm R Garbe <garbeam@gmail.com>
Tue, 8 Apr 2008 08:55:46 +0000 (09:55 +0100)
committerAnselm R Garbe <garbeam@gmail.com>
Tue, 8 Apr 2008 08:55:46 +0000 (09:55 +0100)
config.mk
slock.c

index d17c76281e3258e037df1599dd59e8f43aad8037..442b4cf249b4f8330bbdbe3342ec311d3baf6da4 100644 (file)
--- a/config.mk
+++ b/config.mk
@@ -1,5 +1,5 @@
 # slock version
-VERSION = 0.8
+VERSION = 0.9
 
 # Customize below to fit your system
 
diff --git a/slock.c b/slock.c
index 2dc96483426b360fe8c051e7776c13cf0530f35f..0116c70404738ee0973614965af5af5ff0fddb29 100644 (file)
--- a/slock.c
+++ b/slock.c
@@ -1,5 +1,4 @@
-/* © 2006-2008 Anselm R Garbe <garbeam at gmail dot com>
- * See LICENSE file for license details. */
+/* See LICENSE file for license details. */
 #define _XOPEN_SOURCE 500
 #if HAVE_SHADOW_H
 #include <shadow.h>
@@ -126,11 +125,16 @@ main(int argc, char **argv) {
 
        /* main event loop */
        while(running && !XNextEvent(dpy, &ev)) {
-               if(len == 0) 
+               if(len == 0 && DPMSCapable(dpy)
                        DPMSForceLevel(dpy, DPMSModeOff);
                if(ev.type == KeyPress) {
                        buf[0] = 0;
                        num = XLookupString(&ev.xkey, buf, sizeof buf, &ksym, 0);
+                       if(IsKeypadKey(ksym)) 
+                               if(ksym == XK_KP_Enter)
+                                       ksym = XK_Return;
+                               else if(ksym >= XK_KP_0 && ksym <= XK_KP_9)
+                                       ksym = (ksym - XK_KP_0) + XK_0;
                        if(IsFunctionKey(ksym) || IsKeypadKey(ksym)
                                        || IsMiscFunctionKey(ksym) || IsPFKey(ksym)
                                        || IsPrivateKeypadKey(ksym))