diff options
author | Christopher Faylor <me@cgf.cx> | 2005-08-20 06:19:55 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2005-08-20 06:19:55 +0000 |
commit | d9a227643589484cfccd75174482a7f2e96f49d5 (patch) | |
tree | 9538a97eb6010b3ddca0b89e6bec28be2351258a /winsup/cygwin/fhandler_netdrive.cc | |
parent | 683ef953925b1d05e49bd9e75147ebc02e9cb82c (diff) | |
download | cygnal-d9a227643589484cfccd75174482a7f2e96f49d5.tar.gz cygnal-d9a227643589484cfccd75174482a7f2e96f49d5.tar.bz2 cygnal-d9a227643589484cfccd75174482a7f2e96f49d5.zip |
* cygerrno.h (geterrno_from_win_error): Change declaration to default to using
GetLastError and EACCESS.
* cygwin.din: Export readdir_r.
* include/cygwin/version.h: Bump API version number to 138.
* syscalls.cc (readdir_worker): New function, renamed from old readdir()
function.
(readdir): Use readdir_worker.
(readdir_r): New function.
* fhandler.h (fhandler_base::readdir): Accommodate second argument indicating
dirent buffer.
(fhandler_disk_file::readdir): Ditto.
(fhandler_cygdrive::readdir): Ditto.
(fhandler_proc::readdir): Ditto.
(fhandler_netdrive::readdir): Ditto.
(fhandler_registry::readdir): Ditto.
(fhandler_process::readdir): Ditto.
* fhandler.cc (fhandler_base::readdir): Ditto.
* fhandler_disk_file.cc (fhandler_disk_file::readdir): Ditto.
* fhandler_cygdrive.cc (fhandler_cygdrive::readdir): Ditto.
* fhandler_proc.cc (fhandler_proc::readdir): Ditto.
* fhandler_netdrive.cc (fhandler_netdrive::readdir): Ditto.
* fhandler_registry.cc (fhandler_registry::readdir): Ditto.
* fhandler_process.cc (fhandler_process::readdir): Ditto.
Diffstat (limited to 'winsup/cygwin/fhandler_netdrive.cc')
-rw-r--r-- | winsup/cygwin/fhandler_netdrive.cc | 31 |
1 files changed, 17 insertions, 14 deletions
diff --git a/winsup/cygwin/fhandler_netdrive.cc b/winsup/cygwin/fhandler_netdrive.cc index 81064ec65..4665d2893 100644 --- a/winsup/cygwin/fhandler_netdrive.cc +++ b/winsup/cygwin/fhandler_netdrive.cc @@ -147,12 +147,13 @@ fhandler_netdrive::fstat (struct __stat64 *buf) return 0; } -struct dirent * -fhandler_netdrive::readdir (DIR *dir) +int +fhandler_netdrive::readdir (DIR *dir, dirent *de) { DWORD size; NETRESOURCE *nro; DWORD ret; + int res; if (!dir->__d_position) { @@ -167,8 +168,8 @@ fhandler_netdrive::readdir (DIR *dir) size = MAX_COMPUTERNAME_LENGTH + 1; if (!GetComputerName (namebuf + 2, &size)) { - __seterrno (); - return NULL; + res = geterrno_from_win_error (); + goto out; } } else @@ -189,24 +190,26 @@ fhandler_netdrive::readdir (DIR *dir) &nr, &dir->__handle, 0, "WNetOpenEnum"); if (ret != NO_ERROR) { - __seterrno_from_win_error (ret); dir->__handle = INVALID_HANDLE_VALUE; - return NULL; + res = geterrno_from_win_error (ret); + goto out; } } ret = create_thread_and_wait (GET_RESOURCE_ENUM, dir->__handle, nro = (LPNETRESOURCE) alloca (16384), 16384, "WnetEnumResource"); if (ret != NO_ERROR) + res = geterrno_from_win_error (ret); + else { - if (ret != ERROR_NO_MORE_ITEMS) - __seterrno_from_win_error (ret); - return NULL; + dir->__d_position++; + char *bs = strrchr (nro->lpRemoteName, '\\'); + strcpy (de->d_name, bs ? bs + 1 : nro->lpRemoteName); + res = 0; } - dir->__d_position++; - char *bs = strrchr (nro->lpRemoteName, '\\'); - strcpy (dir->__d_dirent->d_name, bs ? bs + 1 : nro->lpRemoteName); - return dir->__d_dirent; +out: + syscall_printf ("%d = readdir (%p, %p)", res, dir, de); + return res; } void @@ -216,7 +219,7 @@ fhandler_netdrive::seekdir (DIR *dir, _off64_t pos) if (pos < 0) return; while (dir->__d_position < pos) - if (!readdir (dir)) + if (!readdir (dir, dir->__d_dirent)) break; } |