Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2005-08-20 10:19:55 +0400
committerChristopher Faylor <me@cgf.cx>2005-08-20 10:19:55 +0400
commitd9a227643589484cfccd75174482a7f2e96f49d5 (patch)
tree9538a97eb6010b3ddca0b89e6bec28be2351258a /winsup/cygwin/fhandler_disk_file.cc
parent683ef953925b1d05e49bd9e75147ebc02e9cb82c (diff)
* 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_disk_file.cc')
-rw-r--r--winsup/cygwin/fhandler_disk_file.cc62
1 files changed, 29 insertions, 33 deletions
diff --git a/winsup/cygwin/fhandler_disk_file.cc b/winsup/cygwin/fhandler_disk_file.cc
index 5c8eac9d2..f26c65dd8 100644
--- a/winsup/cygwin/fhandler_disk_file.cc
+++ b/winsup/cygwin/fhandler_disk_file.cc
@@ -1348,27 +1348,29 @@ free_dir:
return res;
}
-struct dirent *
-fhandler_disk_file::readdir (DIR *dir)
+int
+fhandler_disk_file::readdir (DIR *dir, dirent *de)
{
WIN32_FIND_DATA buf;
HANDLE handle;
- struct dirent *res = NULL;
+ int res;
- if (dir->__handle == INVALID_HANDLE_VALUE
- && dir->__d_position == 0)
+ if (dir->__handle == INVALID_HANDLE_VALUE && dir->__d_position == 0)
{
handle = FindFirstFileA (dir->__d_dirname, &buf);
DWORD lasterr = GetLastError ();
dir->__handle = handle;
if (handle == INVALID_HANDLE_VALUE && (lasterr != ERROR_NO_MORE_FILES))
{
- seterrno_from_win_error (__FILE__, __LINE__, lasterr);
- return res;
+ res = geterrno_from_win_error ();
+ goto out;
}
}
else if (dir->__handle == INVALID_HANDLE_VALUE)
- return res;
+ {
+ res = EBADF;
+ goto out;
+ }
else if (!FindNextFileA (dir->__handle, &buf))
{
bool added = false;
@@ -1396,15 +1398,10 @@ fhandler_disk_file::readdir (DIR *dir)
buf.dwFileAttributes = 0;
else
{
- DWORD lasterr = GetLastError ();
+ res = geterrno_from_win_error ();
FindClose (dir->__handle);
dir->__handle = INVALID_HANDLE_VALUE;
- /* POSIX says you shouldn't set errno when readdir can't
- find any more files; so, if another error we leave it set. */
- if (lasterr != ERROR_NO_MORE_FILES)
- seterrno_from_win_error (__FILE__, __LINE__, lasterr);
- syscall_printf ("%p = readdir (%p)", res, dir);
- return res;
+ goto out;
}
}
@@ -1427,25 +1424,25 @@ fhandler_disk_file::readdir (DIR *dir)
/* We get here if `buf' contains valid data. */
if (pc.isencoded ())
- fnunmunge (dir->__d_dirent->d_name, buf.cFileName);
+ fnunmunge (de->d_name, buf.cFileName);
else
- strcpy (dir->__d_dirent->d_name, buf.cFileName);
+ strcpy (de->d_name, buf.cFileName);
if (dir->__flags && dirent_isroot)
{
- if (strcasematch (dir->__d_dirent->d_name, "dev"))
+ if (strcasematch (de->d_name, "dev"))
dir->__flags |= dirent_saw_dev;
- else if (strcasematch (dir->__d_dirent->d_name, "proc"))
+ else if (strcasematch (de->d_name, "proc"))
dir->__flags |= dirent_saw_proc;
- if (strlen (dir->__d_dirent->d_name) == mount_table->cygdrive_len - 2
- && strncasematch (dir->__d_dirent->d_name, mount_table->cygdrive + 1,
+ if (strlen (de->d_name) == mount_table->cygdrive_len - 2
+ && strncasematch (de->d_name, mount_table->cygdrive + 1,
mount_table->cygdrive_len - 2))
dir->__flags |= dirent_saw_cygdrive;
}
dir->__d_position++;
- res = dir->__d_dirent;
- syscall_printf ("%p = readdir (%p) (%s)", &dir->__d_dirent, dir,
- buf.cFileName);
+ res = 0;
+out:
+ syscall_printf ("%d = readdir (%p) (%s)", dir, &de, de->d_name);
return res;
}
@@ -1526,24 +1523,23 @@ fhandler_cygdrive::opendir ()
return dir;
}
-struct dirent *
-fhandler_cygdrive::readdir (DIR *dir)
+int
+fhandler_cygdrive::readdir (DIR *dir, dirent *de)
{
if (!pdrive || !*pdrive)
- return NULL;
+ return ENMFILE;
if (GetFileAttributes (pdrive) == INVALID_FILE_ATTRIBUTES)
{
pdrive = strchr (pdrive, '\0') + 1;
- return readdir (dir);
+ return readdir (dir, de);
}
- *dir->__d_dirent->d_name = cyg_tolower (*pdrive);
- dir->__d_dirent->d_name[1] = '\0';
+ *de->d_name = cyg_tolower (*pdrive);
+ de->d_name[1] = '\0';
dir->__d_position++;
pdrive = strchr (pdrive, '\0') + 1;
- syscall_printf ("%p = readdir (%p) (%s)", &dir->__d_dirent, dir,
- dir->__d_dirent->d_name);
- return dir->__d_dirent;
+ syscall_printf ("%p = readdir (%p) (%s)", &de, dir, de->d_name);
+ return 0;
}
void