diff options
author | "Steven J. Hill" <sjhill@realitydiluted.com> | 2006-08-22 01:56:31 +0000 |
---|---|---|
committer | "Steven J. Hill" <sjhill@realitydiluted.com> | 2006-08-22 01:56:31 +0000 |
commit | c969ef4b8fc1d06c13203b36f8cf5bb61a7730f0 (patch) | |
tree | eb2da173a5661b2b2e615045f26f7b69e774290d /test/misc/bug-readdir1.c | |
parent | fea84e591f94b025ef7c2da843ae80b809f93dbe (diff) | |
download | uClibc-alpine-c969ef4b8fc1d06c13203b36f8cf5bb61a7730f0.tar.bz2 uClibc-alpine-c969ef4b8fc1d06c13203b36f8cf5bb61a7730f0.tar.xz |
Merge from trunk. Whoa crap.
Diffstat (limited to 'test/misc/bug-readdir1.c')
-rw-r--r-- | test/misc/bug-readdir1.c | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/test/misc/bug-readdir1.c b/test/misc/bug-readdir1.c new file mode 100644 index 000000000..4c3521dbb --- /dev/null +++ b/test/misc/bug-readdir1.c @@ -0,0 +1,38 @@ +#include <dirent.h> +#include <errno.h> +#include <errno.h> +#include <stdio.h> +#include <stdlib.h> +#include <unistd.h> +#include <sys/types.h> + + +int +main (void) +{ + DIR *dirp; + struct dirent* ent; + + /* open a dir stream */ + dirp = opendir ("/tmp"); + if (dirp == NULL) + { + if (errno == ENOENT) + exit (0); + + perror ("opendir"); + exit (1); + } + + /* close the directory file descriptor, making it invalid */ + if (close (dirfd (dirp)) != 0) + { + puts ("could not close directory file descriptor"); + /* This is not an error. It is not guaranteed this is possible. */ + return 0; + } + + ent = readdir (dirp); + + return ent != NULL || errno != EBADF; +} |