aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFRIGN <dev@frign.de>2014-06-03 19:19:10 +0200
committersin <sin@2f30.org>2014-06-09 19:14:31 +0100
commit9db14b10dd09336c6a8fe283f99108c9acc4667a (patch)
tree2715c291963a7869545d46cd07395b61bc2ff067
parentSet errno to 0 before getpwuid() and check it afterwards (diff)
downloadslock-9db14b10dd09336c6a8fe283f99108c9acc4667a.tar.gz
slock-9db14b10dd09336c6a8fe283f99108c9acc4667a.tar.bz2
slock-9db14b10dd09336c6a8fe283f99108c9acc4667a.tar.xz
slock-9db14b10dd09336c6a8fe283f99108c9acc4667a.tar.zst
slock-9db14b10dd09336c6a8fe283f99108c9acc4667a.zip
Add /etc/passwd support
Fix slock to work with /etc/passwd without /etc/shadow. while we're at it, remove an occurence of trailing whitespace.
-rw-r--r--slock.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/slock.c b/slock.c
index 506231e..aedee2e 100644
--- a/slock.c
+++ b/slock.c
@@ -75,7 +75,7 @@ getpw(void) { /* only run as root */
rval = pw->pw_passwd;
#if HAVE_SHADOW_H
- if (strlen(rval) >= 1) { /* kludge, assumes pw placeholder entry has len >= 1 */
+ if (rval[0] == 'x' && rval[1] == '\0') {
struct spwd *sp;
sp = getspnam(getenv("USER"));
if(!sp)
@@ -147,7 +147,7 @@ readpw(Display *dpy, const char *pws)
--len;
break;
default:
- if(num && !iscntrl((int) buf[0]) && (len + num < sizeof passwd)) {
+ if(num && !iscntrl((int) buf[0]) && (len + num < sizeof passwd)) {
memcpy(passwd + len, buf, num);
len += num;
}