From f96c3e9f43bf1301425e36d1f67a5e1d5fbbb8db Mon Sep 17 00:00:00 2001 From: Roland McGrath Date: Sun, 5 Mar 2006 11:53:37 +0000 Subject: * sysdeps/mach/hurd/opendir.c (__opendir): Likewise. --- ChangeLog | 1 + sysdeps/mach/hurd/opendir.c | 28 +++------------------------- 2 files changed, 4 insertions(+), 25 deletions(-) diff --git a/ChangeLog b/ChangeLog index d75bbcb..c3a4d0a 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 diff --git a/sysdeps/mach/hurd/opendir.c b/sysdeps/mach/hurd/opendir.c index 5b10142..23e04ed 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); -- cgit v1.1