summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--winsup/cygwin/ChangeLog7
-rw-r--r--winsup/cygwin/fhandler_netdrive.cc14
2 files changed, 16 insertions, 5 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog
index 8d4e9745e..2e06516f8 100644
--- a/winsup/cygwin/ChangeLog
+++ b/winsup/cygwin/ChangeLog
@@ -1,3 +1,10 @@
+2005-05-18 Corinna Vinschen <corinna@vinschen.de>
+
+ * fhandler_netdrive.cc (fhandler_netdrive::telldir): Implement.
+ (fhandler_netdrive::seekdir): Implement.
+ (fhandler_netdrive::closedir): Call rewinddir to have only one point
+ of calling WNetCloseEnum.
+
2005-05-17 Corinna Vinschen <corinna@vinschen.de>
* fhandler.h (class fhandler_netdrive): Add method rewinddir.
diff --git a/winsup/cygwin/fhandler_netdrive.cc b/winsup/cygwin/fhandler_netdrive.cc
index c778a7d90..2fde21b8f 100644
--- a/winsup/cygwin/fhandler_netdrive.cc
+++ b/winsup/cygwin/fhandler_netdrive.cc
@@ -212,12 +212,18 @@ fhandler_netdrive::readdir (DIR *dir)
_off64_t
fhandler_netdrive::telldir (DIR *dir)
{
- return -1;
+ return dir->__d_position;
}
void
-fhandler_netdrive::seekdir (DIR *, _off64_t)
+fhandler_netdrive::seekdir (DIR *dir, _off64_t pos)
{
+ rewinddir (dir);
+ if (pos < 0)
+ return;
+ while (dir->__d_position < pos)
+ if (!readdir (dir))
+ break;
}
void
@@ -232,9 +238,7 @@ fhandler_netdrive::rewinddir (DIR *dir)
int
fhandler_netdrive::closedir (DIR *dir)
{
- if (dir->__handle != INVALID_HANDLE_VALUE)
- WNetCloseEnum (dir->__handle);
- dir->__handle = INVALID_HANDLE_VALUE;
+ rewinddir (dir);
return fhandler_virtual::closedir (dir);
}