Win32: add a cache below mingw's lstat and dirent implementations
commit2e646a9330ad9babf9351bdab8f82edf901bc65b
authorKarsten Blees <blees@dcon.de>
Tue, 1 Oct 2013 10:51:54 +0000 (1 12:51 +0200)
committerKarsten Blees <blees@dcon.de>
Sat, 16 Aug 2014 01:03:13 +0000 (16 03:03 +0200)
treecd164587a3b4bb02f8db9966b2feb76a435a4981
parent119a8f8656036d398076d472ff7197e17b7a49e0
Win32: add a cache below mingw's lstat and dirent implementations

Checking the work tree status is quite slow on Windows, due to slow lstat
emulation (git calls lstat once for each file in the index). Windows
operating system APIs seem to be much better at scanning the status
of entire directories than checking single files.

Add an lstat implementation that uses a cache for lstat data. Cache misses
read the entire parent directory and add it to the cache. Subsequent lstat
calls for the same directory are served directly from the cache.

Also implement opendir / readdir / closedir so that they create and use
directory listings in the cache.

The cache doesn't track file system changes and doesn't plug into any
modifying file APIs, so it has to be explicitly enabled for git functions
that don't modify the working copy.

Note: in an earlier version of this patch, the cache was always active and
tracked file system changes via ReadDirectoryChangesW. However, this was
much more complex and had negative impact on the performance of modifying
git commands such as 'git checkout'.

Signed-off-by: Karsten Blees <blees@dcon.de>
compat/win32/fscache.c [new file with mode: 0644]
compat/win32/fscache.h [new file with mode: 0644]
config.mak.uname
git-compat-util.h