summaryrefslogtreecommitdiff
path: root/lib/libc/gen/readdir.c
diff options
context:
space:
mode:
authorAlfred Perlstein <alfred@FreeBSD.org>1999-11-29 19:12:50 +0000
committerAlfred Perlstein <alfred@FreeBSD.org>1999-11-29 19:12:50 +0000
commit8b6c02f328e21efda4d5de8c79d8b553e8b4ce2f (patch)
tree16ee8b855ef353393708518caa8c119b0dadcc31 /lib/libc/gen/readdir.c
parent6c48b6cf75960ede12a39f91a6c87ad709c6c47e (diff)
Notes
Diffstat (limited to 'lib/libc/gen/readdir.c')
-rw-r--r--lib/libc/gen/readdir.c37
1 files changed, 20 insertions, 17 deletions
diff --git a/lib/libc/gen/readdir.c b/lib/libc/gen/readdir.c
index 9b8c1758554a..2e91a9ac2448 100644
--- a/lib/libc/gen/readdir.c
+++ b/lib/libc/gen/readdir.c
@@ -89,34 +89,37 @@ readdir_r(dirp, entry, result)
struct dirent **result;
{
struct dirent *dp;
- int ret;
+ int ret, saved_errno;
- if (dirp->dd_fd < 0) {
- return EBADF;
- }
#ifdef _THREAD_SAFE
- if ((ret = _FD_LOCK(dirp->dd_fd, FD_READ, NULL)) != 0) {
- return ret;
- }
+ if ((ret = _FD_LOCK(dirp->dd_fd, FD_READ, NULL)) != 0)
+ return (ret);
#endif
+
+ saved_errno = errno;
errno = 0;
dp = readdir(dirp);
- if (dp == NULL && errno != 0) {
+ if (errno != 0) {
+ if (dp == NULL) {
#ifdef _THREAD_SAFE
- _FD_UNLOCK(dirp->dd_fd, FD_READ);
+ _FD_UNLOCK(dirp->dd_fd, FD_READ);
#endif
- return errno;
- }
- if (dp != NULL) {
+ return (errno);
+ }
+ } else
+ errno = saved_errno;
+
+ if (dp != NULL)
memcpy(entry, dp, sizeof *entry);
- }
+
#ifdef _THREAD_SAFE
_FD_UNLOCK(dirp->dd_fd, FD_READ);
#endif
- if (dp != NULL) {
+
+ if (dp != NULL)
*result = entry;
- } else {
+ else
*result = NULL;
- }
- return 0;
+
+ return (0);
}