diff options
author | nijtmans@users.sourceforge.net <jan.nijtmans> | 2013-03-19 13:37:40 (GMT) |
---|---|---|
committer | nijtmans@users.sourceforge.net <jan.nijtmans> | 2013-03-19 13:37:40 (GMT) |
commit | a8259adb4918d9d9c40b223c5a8658f60bbb6bcf (patch) | |
tree | 646f2a6b59fcbb0ab7e2d0501c4be7010f376ff8 | |
parent | 236f7ecfe197125a8316702f4120ac97df51bd13 (diff) | |
download | tcl-a8259adb4918d9d9c40b223c5a8658f60bbb6bcf.zip tcl-a8259adb4918d9d9c40b223c5a8658f60bbb6bcf.tar.gz tcl-a8259adb4918d9d9c40b223c5a8658f60bbb6bcf.tar.bz2 |
make sure that [file stat] returns the right data, even for locked files.
-rw-r--r-- | win/tclWinFile.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/win/tclWinFile.c b/win/tclWinFile.c index 8e41096..22fc6f3 100644 --- a/win/tclWinFile.c +++ b/win/tclWinFile.c @@ -1892,11 +1892,17 @@ NativeStat(nativePath, statPtr, checkLinks) if((*tclWinProcs->getFileAttributesExProc)(nativePath, GetFileExInfoStandard, &data) != TRUE) { + HANDLE hFind; + WIN32_FIND_DATAT ffd; DWORD lasterror = GetLastError(); + if (lasterror != ERROR_SHARING_VIOLATION) { TclWinConvertError(lasterror); return -1; } + hFind = (*tclWinProcs->findFirstFileProc)(nativePath, &ffd); + memcpy(&data, &ffd, sizeof(data)); + FindClose(hFind); } |