diff options
author | Corinna Vinschen <corinna@vinschen.de> | 2000-03-19 11:05:14 +0000 |
---|---|---|
committer | Corinna Vinschen <corinna@vinschen.de> | 2000-03-19 11:05:14 +0000 |
commit | 1b16b354fa345218ccf43d2482b0a8fb4682930f (patch) | |
tree | 3d2d392742d2c74037eaf989c80493c628c237c2 | |
parent | 5bc5ee4457a633ca8b47ec4264cdeee29b1c5342 (diff) | |
download | newlib-1b16b354fa345218ccf43d2482b0a8fb4682930f.zip newlib-1b16b354fa345218ccf43d2482b0a8fb4682930f.tar.gz newlib-1b16b354fa345218ccf43d2482b0a8fb4682930f.tar.bz2 |
* syscalls.cc (stat_worker): Set st_nlink to 1 on remote drives.
-rw-r--r-- | winsup/cygwin/ChangeLog | 4 | ||||
-rw-r--r-- | winsup/cygwin/syscalls.cc | 6 |
2 files changed, 8 insertions, 2 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index 4c9903f..1508dee 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,7 @@ +Sun Mar 19 12:01:00 2000 Corinna Vinschen <corinna@vinschen.de> + + * syscalls.cc (stat_worker): Set st_nlink to 1 on remote drives. + Sat Mar 18 23:04:27 2000 Christopher Faylor <cgf@cygnus.com> * times.cc: Fix extern declarations for variables that are exported but diff --git a/winsup/cygwin/syscalls.cc b/winsup/cygwin/syscalls.cc index e94e8ea..a52faf8 100644 --- a/winsup/cygwin/syscalls.cc +++ b/winsup/cygwin/syscalls.cc @@ -986,7 +986,7 @@ stat_worker (const char *caller, const char *name, struct stat *buf, /* See the comment 10 lines below */ if (atts != -1 && (atts & FILE_ATTRIBUTE_DIRECTORY)) buf->st_nlink = - (dtype == DRIVE_REMOTE ? 2 : num_entries (win32_name)); + (dtype == DRIVE_REMOTE ? 1 : num_entries (win32_name)); } } else @@ -998,7 +998,9 @@ stat_worker (const char *caller, const char *name, struct stat *buf, those subdirectories point to it. This is too slow on remote drives, so we do without it and set the number of links to 2. */ - buf->st_nlink = (dtype == DRIVE_REMOTE ? 2 : num_entries (win32_name)); + /* Unfortunately the count of 2 confuses `find(1)' command. So + let's try it with `1' as link count. */ + buf->st_nlink = (dtype == DRIVE_REMOTE ? 1 : num_entries (win32_name)); buf->st_dev = FHDEVN(FH_DISK) << 8; buf->st_ino = hash_path_name (0, real_path.get_win32 ()); buf->st_mode = S_IFDIR | STD_RBITS | STD_XBITS; |