diff options
author | Connor Lane Smith <cls@lubutu.com> | 2011-10-17 10:08:04 +0100 |
---|---|---|
committer | Connor Lane Smith <cls@lubutu.com> | 2011-10-17 10:08:04 +0100 |
commit | 5e0156c0727fa8f225c3309f265da241a98edc08 (patch) | |
tree | 47ab53541e5ba56cbdfa70fd9498ae53c2a35d73 /lsx.c | |
parent | ca7ef6d2c901b2f302e735da369b730edb3575cf (diff) | |
parent | 7bbd4c56ebe1c91b90561e7f22e875f58e7facc9 (diff) |
merge lsx -> default
Diffstat (limited to 'lsx.c')
-rw-r--r-- | lsx.c | 21 |
1 files changed, 13 insertions, 8 deletions
@@ -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> @@ -8,6 +9,8 @@ static void lsx(const char *dir); +static int status = EXIT_SUCCESS; + int main(int argc, char *argv[]) { int i; @@ -16,7 +19,7 @@ main(int argc, char *argv[]) { lsx("."); else for(i = 1; i < argc; i++) lsx(argv[i]); - return EXIT_SUCCESS; + return status; } void @@ -26,13 +29,15 @@ lsx(const char *dir) { struct stat st; DIR *dp; - if(!(dp = opendir(dir))) { - perror(dir); - return; - } - while((d = readdir(dp))) + for(dp = opendir(dir); dp && (d = readdir(dp)); errno = 0) 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) + && access(buf, X_OK) == 0 && stat(buf, &st) == 0 && S_ISREG(st.st_mode)) puts(d->d_name); - closedir(dp); + + if(errno != 0) { + status = EXIT_FAILURE; + perror(dir); + } + if(dp) + closedir(dp); } |