]> git.sur5r.net Git - i3/i3lock/commitdiff
getting current user with whoami like function rather than from env variable
authorMartin Stiborsky <martin.stiborsky@gmail.com>
Mon, 5 Jan 2015 10:46:11 +0000 (11:46 +0100)
committerMartin Stiborsky <martin.stiborsky@gmail.com>
Mon, 5 Jan 2015 10:46:11 +0000 (11:46 +0100)
i3lock.c

index 71b02eec842ede34fdb8f4b30c1df9564c27a6d1..fd32f97fc6c82fa628d69a46dc280b147f09f754 100644 (file)
--- a/i3lock.c
+++ b/i3lock.c
@@ -8,6 +8,7 @@
  */
 #include <stdio.h>
 #include <stdlib.h>
+#include <pwd.h>
 #include <string.h>
 #include <unistd.h>
 #include <stdbool.h>
@@ -658,8 +659,18 @@ static void raise_loop(xcb_window_t window) {
     }
 }
 
+char* whoami(void) {
+    uid_t uid = geteuid();
+    struct passwd *pw = getpwuid(uid);
+    if (pw) {
+        return pw->pw_name;
+     } else {
+        errx(EXIT_FAILURE, "Username not known!\n");
+     }
+}
+
 int main(int argc, char *argv[]) {
-    char *username;
+    char *username = whoami();
     char *image_path = NULL;
     int ret;
     struct pam_conv conv = {conv_callback, NULL};
@@ -684,9 +695,6 @@ int main(int argc, char *argv[]) {
         {NULL, no_argument, NULL, 0}
     };
 
-    if ((username = getenv("USER")) == NULL)
-        errx(EXIT_FAILURE, "USER environment variable not set, please set it.\n");
-
     char *optstring = "hvnbdc:p:ui:teI:f";
     while ((o = getopt_long(argc, argv, optstring, longopts, &optind)) != -1) {
         switch (o) {