From: Michael Haggerty Date: Thu, 15 Sep 2011 21:10:31 +0000 (+0200) Subject: resolve_ref(): explicitly fail if a symlink is not readable X-Git-Tag: v1.7.8-rc0~19^2~15 X-Git-Url: https://git.tokkee.org/?a=commitdiff_plain;h=7bb2bf8e5cc47f7731c9c012ecc943b14f99ee5a;p=git.git resolve_ref(): explicitly fail if a symlink is not readable Previously the failure came later, after a few steps in which the length was treated like the actual length of a string. Even though the old code gave the same answers, it was somewhat misleading. Signed-off-by: Michael Haggerty Signed-off-by: Junio C Hamano --- diff --git a/refs.c b/refs.c index d2aac24a3..c51fd45f9 100644 --- a/refs.c +++ b/refs.c @@ -518,6 +518,8 @@ const char *resolve_ref(const char *ref, unsigned char *sha1, int reading, int * /* Follow "normalized" - ie "refs/.." symlinks by hand */ if (S_ISLNK(st.st_mode)) { len = readlink(path, buffer, sizeof(buffer)-1); + if (len < 0) + return NULL; if (len >= 5 && !memcmp("refs/", buffer, 5)) { buffer[len] = 0; strcpy(ref_buffer, buffer);