X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=slock.c;h=8490dae275c05262ddb0398de662b1eed89dd4f2;hb=0cb05bdb75ac13f010d51e267007ca1c869763ec;hp=d576c0b2baff0dc2d33a87d6d901c82b7df94914;hpb=1460b14f450d65c68bf519538de5b5df1a7bc01c;p=slock.git diff --git a/slock.c b/slock.c index d576c0b..8490dae 100644 --- a/slock.c +++ b/slock.c @@ -22,7 +22,7 @@ #include #endif -void +static void die(const char *errstr, ...) { va_list ap; @@ -33,7 +33,7 @@ die(const char *errstr, ...) { } #ifndef HAVE_BSD_AUTH -const char * +static const char * get_password() { /* only run as root */ const char *rval; struct passwd *pw; @@ -79,6 +79,7 @@ main(int argc, char **argv) { XColor black, dummy; XEvent ev; XSetWindowAttributes wa; + CARD16 standby, suspend, off; if((argc == 2) && !strcmp("-v", argv[1])) die("slock-"VERSION", © 2006-2008 Anselm R Garbe\n"); @@ -123,20 +124,22 @@ main(int argc, char **argv) { len = 0; XSync(dpy, False); + if(DPMSCapable(dpy)) { /* save and customize DPMS settings */ + DPMSGetTimeouts(dpy, &standby, &suspend, &off); + DPMSSetTimeouts(dpy, 10, 30, 90); + } + /* main event loop */ while(running && !XNextEvent(dpy, &ev)) { - if(len == 0 && DPMSCapable(dpy)) { - DPMSEnable(dpy); - DPMSForceLevel(dpy, DPMSModeOff); - } if(ev.type == KeyPress) { buf[0] = 0; num = XLookupString(&ev.xkey, buf, sizeof buf, &ksym, 0); - if(IsKeypadKey(ksym)) + 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)) @@ -169,6 +172,9 @@ main(int argc, char **argv) { } } } + if(DPMSCapable(dpy)) { /* restore DPMS settings */ + DPMSSetTimeouts(dpy, standby, suspend, off); + } XUngrabPointer(dpy, CurrentTime); XFreePixmap(dpy, pmap); XDestroyWindow(dpy, w);