all repos — dmenu @ 5e0156c0727fa8f225c3309f265da241a98edc08

my build of dmenu

merge lsx -> default
Connor Lane Smith cls@lubutu.com
Mon, 17 Oct 2011 10:08:04 +0100
commit

5e0156c0727fa8f225c3309f265da241a98edc08

parent

ca7ef6d2c901b2f302e735da369b730edb3575cf

1 files changed, 13 insertions(+), 8 deletions(-)

jump to
M lsx.clsx.c

@@ -1,5 +1,6 @@

/* See LICENSE file for copyright and license details. */ #include <dirent.h> +#include <errno.h> #include <limits.h> #include <stdio.h> #include <stdlib.h>

@@ -7,6 +8,8 @@ #include <unistd.h>

#include <sys/stat.h> static void lsx(const char *dir); + +static int status = EXIT_SUCCESS; int main(int argc, char *argv[]) {

@@ -16,7 +19,7 @@ if(argc < 2)

lsx("."); else for(i = 1; i < argc; i++) lsx(argv[i]); - return EXIT_SUCCESS; + return status; } void

@@ -26,13 +29,15 @@ struct dirent *d;

struct stat st; DIR *dp; - if(!(dp = opendir(dir))) { + for(dp = opendir(dir); dp && (d = readdir(dp)); errno = 0) + if(snprintf(buf, sizeof buf, "%s/%s", dir, d->d_name) < (int)sizeof buf + && access(buf, X_OK) == 0 && stat(buf, &st) == 0 && S_ISREG(st.st_mode)) + puts(d->d_name); + + if(errno != 0) { + status = EXIT_FAILURE; perror(dir); - return; } - while((d = readdir(dp))) - if(snprintf(buf, sizeof buf, "%s/%s", dir, d->d_name) < (int)sizeof buf - && !stat(buf, &st) && S_ISREG(st.st_mode) && access(buf, X_OK) == 0) - puts(d->d_name); - closedir(dp); + if(dp) + closedir(dp); }