diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2009-07-09 22:35:31 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2009-07-10 05:05:19 +0200 |
commit | b9fd284657de3ec30922fb17c0baf243ae947fdd (patch) | |
tree | db952a083002444b5c95af6f40a39f8b32d258e0 /cache.h | |
parent | Prepare symlink caching for thread-safety (diff) | |
download | git-b9fd284657de3ec30922fb17c0baf243ae947fdd.tar.xz git-b9fd284657de3ec30922fb17c0baf243ae947fdd.zip |
Export thread-safe version of 'has_symlink_leading_path()'
The threaded index preloading will want it, so that it can avoid
locking by simply using a per-thread symlink/directory cache.
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'cache.h')
-rw-r--r-- | cache.h | 10 |
1 files changed, 10 insertions, 0 deletions
@@ -744,7 +744,17 @@ struct checkout { }; extern int checkout_entry(struct cache_entry *ce, const struct checkout *state, char *topath); + +struct cache_def { + char path[PATH_MAX + 1]; + int len; + int flags; + int track_flags; + int prefix_len_stat_func; +}; + extern int has_symlink_leading_path(const char *name, int len); +extern int threaded_has_symlink_leading_path(struct cache_def *, const char *, int); extern int has_symlink_or_noent_leading_path(const char *name, int len); extern int has_dirs_only_path(const char *name, int len, int prefix_len); extern void invalidate_lstat_cache(const char *name, int len); |