Code

resolve_ref(): explicitly fail if a symlink is not readable
[git.git] / refs.c
diff --git a/refs.c b/refs.c
index d2aac24a366f946ea5a256a7bc47f10d36f98a88..c51fd45f99ef3a6d5fdb56b6bd5ba9a554f2e8f8 100644 (file)
--- 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);