diff options
author | Christopher Faylor <me@cgf.cx> | 2005-08-19 16:29:43 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2005-08-19 16:29:43 +0000 |
commit | 683ef953925b1d05e49bd9e75147ebc02e9cb82c (patch) | |
tree | 7c2b45f9cd656d7b9c3f97066181192e04f9a6dd /winsup/cygwin/fhandler_disk_file.cc | |
parent | 358063ace374e05025d124a17a0167b818b666ea (diff) | |
download | cygnal-683ef953925b1d05e49bd9e75147ebc02e9cb82c.tar.gz cygnal-683ef953925b1d05e49bd9e75147ebc02e9cb82c.tar.bz2 cygnal-683ef953925b1d05e49bd9e75147ebc02e9cb82c.zip |
* fhandler.h (dirent_states): Add dirent_saw_proc.
* fhandler_disk_file.cc (fhandler_disk_file::readdir): Fill in "proc" if it is
the root dir and it is missing.
Diffstat (limited to 'winsup/cygwin/fhandler_disk_file.cc')
-rw-r--r-- | winsup/cygwin/fhandler_disk_file.cc | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/winsup/cygwin/fhandler_disk_file.cc b/winsup/cygwin/fhandler_disk_file.cc index e0ef7079a..5c8eac9d2 100644 --- a/winsup/cygwin/fhandler_disk_file.cc +++ b/winsup/cygwin/fhandler_disk_file.cc @@ -1379,6 +1379,11 @@ fhandler_disk_file::readdir (DIR *dir) strcpy (buf.cFileName, "dev"); added = true; } + else if (!(dir->__flags & dirent_saw_proc)) + { + strcpy (buf.cFileName, "proc"); + added = true; + } else if (!(dir->__flags & dirent_saw_cygdrive) && mount_table->cygdrive_len > 1) { @@ -1425,12 +1430,12 @@ fhandler_disk_file::readdir (DIR *dir) fnunmunge (dir->__d_dirent->d_name, buf.cFileName); else strcpy (dir->__d_dirent->d_name, buf.cFileName); - if (!(dir->__flags && dirent_isroot)) - /* nothing */; - else + if (dir->__flags && dirent_isroot) { if (strcasematch (dir->__d_dirent->d_name, "dev")) dir->__flags |= dirent_saw_dev; + else if (strcasematch (dir->__d_dirent->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, mount_table->cygdrive_len - 2)) |