From c71abdc65c8a7ff9597f7b6b5bf60a59be174224 Mon Sep 17 00:00:00 2001 From: Connor Lane Smith Date: Sun, 16 Oct 2011 18:14:51 +0100 Subject: lsx: return failure on error --- lsx.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/lsx.c b/lsx.c index f337a4a..57c03bf 100644 --- a/lsx.c +++ b/lsx.c @@ -8,6 +8,8 @@ static void lsx(const char *dir); +static int status = EXIT_SUCCESS; + int main(int argc, char *argv[]) { int i; @@ -16,7 +18,7 @@ main(int argc, char *argv[]) { lsx("."); else for(i = 1; i < argc; i++) lsx(argv[i]); - return EXIT_SUCCESS; + return status; } void @@ -27,12 +29,13 @@ lsx(const char *dir) { DIR *dp; if(!(dp = opendir(dir))) { + 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) + && stat(buf, &st) == 0 && S_ISREG(st.st_mode) && access(buf, X_OK) == 0) puts(d->d_name); closedir(dp); } -- cgit v1.2.3-54-g00ecf From 7bbd4c56ebe1c91b90561e7f22e875f58e7facc9 Mon Sep 17 00:00:00 2001 From: Connor Lane Smith Date: Mon, 17 Oct 2011 01:44:07 +0100 Subject: lsx: detect read errors --- lsx.c | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/lsx.c b/lsx.c index 57c03bf..cb016cf 100644 --- a/lsx.c +++ b/lsx.c @@ -1,5 +1,6 @@ /* See LICENSE file for copyright and license details. */ #include +#include #include #include #include @@ -28,14 +29,15 @@ lsx(const char *dir) { 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) == 0 && S_ISREG(st.st_mode) && access(buf, X_OK) == 0) - puts(d->d_name); - closedir(dp); + if(dp) + closedir(dp); } -- cgit v1.2.3-54-g00ecf