Win32: fix detection of empty directories in is_dir_empty
commit91db148bbe34a2645b14393ed82ebdee08152294
authorKarsten Blees <blees@dcon.de>
Thu, 15 Mar 2012 19:37:26 +0000 (15 20:37 +0100)
committerJohannes Schindelin <johannes.schindelin@gmx.de>
Sat, 10 May 2014 21:56:32 +0000 (10 16:56 -0500)
treef1a7c9e5a521384776d998f87d34374e8839a6af
parent84b79692651823279f252e2721eba428afc8fed4
Win32: fix detection of empty directories in is_dir_empty

On Windows XP (not Win7), directories cannot be deleted while a find handle
is open, causing "Deletion of directory '...' failed. Should I try again?"
prompts.

Prior to 19d1e75d "Win32: Unicode file name support (except dirent)",
these failures were silently ignored due to strbuf_free in is_dir_empty
resetting GetLastError to ERROR_SUCCESS.

Close the find handle in is_dir_empty so that git doesn't block deletion
of the directory even after all other applications have released it.

Reported-by: John Chen <john0312@gmail.com>
Signed-off-by: Karsten Blees <blees@dcon.de>
compat/mingw.c