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_registry.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_registry.cc')
-rw-r--r-- | winsup/cygwin/fhandler_registry.cc | 28 |
1 files changed, 13 insertions, 15 deletions
diff --git a/winsup/cygwin/fhandler_registry.cc b/winsup/cygwin/fhandler_registry.cc index 07be1d0c7..885a35247 100644 --- a/winsup/cygwin/fhandler_registry.cc +++ b/winsup/cygwin/fhandler_registry.cc @@ -273,26 +273,25 @@ fhandler_registry::fstat (struct __stat64 *buf) return 0; } -struct dirent * -fhandler_registry::readdir (DIR * dir) +int +fhandler_registry::readdir (DIR *dir, dirent *de) { DWORD buf_size = CYG_MAX_PATH; char buf[buf_size]; HANDLE handle; - struct dirent *res = NULL; const char *path = dir->__d_dirname + proc_len + 1 + registry_len; LONG error; + int res = ENMFILE; if (*path == 0) { if (dir->__d_position >= ROOT_KEY_COUNT) goto out; - strcpy (dir->__d_dirent->d_name, registry_listing[dir->__d_position++]); - res = dir->__d_dirent; + strcpy (de->d_name, registry_listing[dir->__d_position++]); + res = 0; goto out; } - if (dir->__handle == INVALID_HANDLE_VALUE - && dir->__d_position == 0) + if (dir->__handle == INVALID_HANDLE_VALUE && dir->__d_position == 0) { handle = open_key (path + 1, KEY_READ, false); dir->__handle = handle; @@ -301,9 +300,8 @@ fhandler_registry::readdir (DIR * dir) goto out; if (dir->__d_position < SPECIAL_DOT_FILE_COUNT) { - strcpy (dir->__d_dirent->d_name, - special_dot_files[dir->__d_position++]); - res = dir->__d_dirent; + strcpy (de->d_name, special_dot_files[dir->__d_position++]); + res = 0; goto out; } retry: @@ -338,16 +336,16 @@ retry: /* We get here if `buf' contains valid data. */ if (*buf == 0) - strcpy (dir->__d_dirent->d_name, DEFAULT_VALUE_NAME); + strcpy (de->d_name, DEFAULT_VALUE_NAME); else - strcpy (dir->__d_dirent->d_name, buf); + strcpy (de->d_name, buf); dir->__d_position++; if (dir->__d_position & REG_ENUM_VALUES_MASK) dir->__d_position += 0x10000; - res = dir->__d_dirent; + res = 0; out: - syscall_printf ("%p = readdir (%p)", &dir->__d_dirent, dir); + syscall_printf ("%d = readdir (%p, %p)", res, dir, de); return res; } @@ -365,7 +363,7 @@ fhandler_registry::seekdir (DIR * dir, _off64_t loc) */ rewinddir (dir); while (loc > (dir->__d_position & REG_POSITION_MASK)) - if (!readdir (dir)) + if (!readdir (dir, dir->__d_dirent)) break; } |