summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorEdward Thomson <ethomson@edwardthomson.com>2021-06-15 00:15:27 +0100
committerGitHub <noreply@github.com>2021-06-15 00:15:27 +0100
commit6efcfdb89b9aa7b57d6028c3968037d545db1e11 (patch)
treed359449857bc2e4d698ea6661800e931d9229118 /src
parent9ecbff125a5d042c9120ed9002d3dc1376c670ed (diff)
parentcf9196bdbc009e79f3806f7353c1ce6885dd677e (diff)
downloadlibgit2-6efcfdb89b9aa7b57d6028c3968037d545db1e11.tar.gz
Merge pull request #5900 from dtolnay-contrib/lstat
Tolerate readlink size less than st_size
Diffstat (limited to 'src')
-rw-r--r--src/odb.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/odb.c b/src/odb.c
index 1b91434bf..7625ce6e3 100644
--- a/src/odb.c
+++ b/src/odb.c
@@ -297,14 +297,15 @@ int git_odb__hashlink(git_oid *out, const char *path)
GIT_ERROR_CHECK_ALLOC(link_data);
read_len = p_readlink(path, link_data, size);
- link_data[size] = '\0';
- if (read_len != size) {
+ if (read_len == -1) {
git_error_set(GIT_ERROR_OS, "failed to read symlink data for '%s'", path);
git__free(link_data);
return -1;
}
+ GIT_ASSERT(read_len <= size);
+ link_data[read_len] = '\0';
- result = git_odb_hash(out, link_data, size, GIT_OBJECT_BLOB);
+ result = git_odb_hash(out, link_data, read_len, GIT_OBJECT_BLOB);
git__free(link_data);
} else {
int fd = git_futils_open_ro(path);