summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>2006-03-05 11:53:37 +0000
committerRoland McGrath <roland@gnu.org>2006-03-05 11:53:37 +0000
commitf96c3e9f43bf1301425e36d1f67a5e1d5fbbb8db (patch)
tree642ccfce2b729d759569c21041226be47d7ade4d
parent0b9b4d884213cb1838a9cb7b26eb668d59dcefb4 (diff)
* sysdeps/mach/hurd/opendir.c (__opendir): Likewise.
-rw-r--r--ChangeLog1
-rw-r--r--sysdeps/mach/hurd/opendir.c28
2 files changed, 4 insertions, 25 deletions
diff --git a/ChangeLog b/ChangeLog
index d75bbcbd7d..c3a4d0aa3e 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -2,6 +2,7 @@
* sysdeps/mach/hurd/fdopendir.c (__fdopendir): Use O_DIRECTORY
to force directory check.
+ * sysdeps/mach/hurd/opendir.c (__opendir): Likewise.
2006-03-04 Roland McGrath <roland@frob.com>
diff --git a/sysdeps/mach/hurd/opendir.c b/sysdeps/mach/hurd/opendir.c
index 5b10142d39..23e04ede0e 100644
--- a/sysdeps/mach/hurd/opendir.c
+++ b/sysdeps/mach/hurd/opendir.c
@@ -1,4 +1,4 @@
-/* Copyright (C) 1993,94,95,96,97,98,2001,2003,2005
+/* Copyright (C) 1993,1994,1995,1996,1997,1998,2001,2003,2005,2006
Free Software Foundation, Inc.
This file is part of the GNU C Library.
@@ -71,9 +71,6 @@ _hurd_fd_opendir (struct hurd_fd *d)
DIR *
__opendir (const char *name)
{
- int fd;
- DIR *dirp;
-
if (name[0] == '\0')
{
/* POSIX.1-1990 says an empty name gets ENOENT;
@@ -82,31 +79,12 @@ __opendir (const char *name)
return NULL;
}
- {
- /* Append trailing slash to directory name to force ENOTDIR
- if it's not a directory.
-
- We open using the O_NONBLOCK flag so that a nondirectory with
- blocking behavior (FIFO or device) gets ENOTDIR immediately
- rather than waiting for the special file's open wakeup predicate. */
-
- size_t len = strlen (name);
- if (name[len - 1] == '/')
- fd = __open (name, O_RDONLY | O_NONBLOCK);
- else
- {
- char n[len + 2];
- memcpy (n, name, len);
- n[len] = '/';
- n[len + 1] = '\0';
- fd = __open (n, O_RDONLY | O_NONBLOCK);
- }
- }
+ int fd = __open (name, O_RDONLY | O_NONBLOCK | O_DIRECTORY);
if (fd < 0)
return NULL;
/* Extract the pointer to the descriptor structure. */
- dirp = _hurd_fd_opendir (_hurd_fd_get (fd));
+ DIR *dirp = _hurd_fd_opendir (_hurd_fd_get (fd));
if (dirp == NULL)
__close (fd);