From ccad42d4836e2bb4d1843eccd94f58f0189abb1d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ren=C3=A9=20Scharfe?= Date: Sat, 9 Aug 2014 19:43:29 +0200 Subject: read-cache: check for leading symlinks when refreshing index Don't add paths with leading symlinks to the index while refreshing; we only track those symlinks themselves. We already ignore them while preloading (see read_index_preload.c). Reported-by: Nikolay Avdeev Signed-off-by: Rene Scharfe Signed-off-by: Junio C Hamano --- read-cache.c | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'read-cache.c') diff --git a/read-cache.c b/read-cache.c index 4b4effd64b..5c234cbd70 100644 --- a/read-cache.c +++ b/read-cache.c @@ -1044,6 +1044,14 @@ static struct cache_entry *refresh_cache_ent(struct index_state *istate, return ce; } + if (has_symlink_leading_path(ce->name, ce_namelen(ce))) { + if (ignore_missing) + return ce; + if (err) + *err = ENOENT; + return NULL; + } + if (lstat(ce->name, &st) < 0) { if (ignore_missing && errno == ENOENT) return ce; -- cgit v1.2.1