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_netdrive.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_netdrive.cc')
-rw-r--r--winsup/cygwin/fhandler_netdrive.cc31
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;
}