diff options
author | Egor Duda <deo@logos-m.ru> | 2001-06-20 07:44:33 +0000 |
---|---|---|
committer | Egor Duda <deo@logos-m.ru> | 2001-06-20 07:44:33 +0000 |
commit | 9cc97acbd0a601622de1198d8b56db8be48e12fb (patch) | |
tree | 5eedacd09dcd2ca0690079ceb3c7d3de6e15acec /winsup/cygwin/fhandler.cc | |
parent | ae036f47c54449400fb178008094e20e70488711 (diff) | |
download | cygnal-9cc97acbd0a601622de1198d8b56db8be48e12fb.tar.gz cygnal-9cc97acbd0a601622de1198d8b56db8be48e12fb.tar.bz2 cygnal-9cc97acbd0a601622de1198d8b56db8be48e12fb.zip |
* fhandler.cc (fhandler_base::open): Work around windows bug when
CreateFile() with dwDesiredAccess == 0 called on remote share returns
valid handle even if file doesn't exist.
Diffstat (limited to 'winsup/cygwin/fhandler.cc')
-rw-r--r-- | winsup/cygwin/fhandler.cc | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/winsup/cygwin/fhandler.cc b/winsup/cygwin/fhandler.cc index a07bc85ab..6c745c097 100644 --- a/winsup/cygwin/fhandler.cc +++ b/winsup/cygwin/fhandler.cc @@ -370,6 +370,17 @@ fhandler_base::open (int flags, mode_t mode) if (get_device () == FH_SERIAL) file_attributes |= FILE_FLAG_OVERLAPPED; + /* CreateFile() with dwDesiredAccess == 0 when called on remote + share returns some handle, even if file doesn't exist. This code + works around this bug. */ + if (get_query_open () && + isremote () && + creation_distribution == OPEN_EXISTING && + GetFileAttributes (get_win32_name ()) == (DWORD) -1) + { + set_errno (ENOENT); + goto done; + } x = CreateFileA (get_win32_name (), access, shared, &sec_none, creation_distribution, file_attributes, |