diff options
author | Edward Thomson <ethomson@edwardthomson.com> | 2021-06-15 00:15:27 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-06-15 00:15:27 +0100 |
commit | 6efcfdb89b9aa7b57d6028c3968037d545db1e11 (patch) | |
tree | d359449857bc2e4d698ea6661800e931d9229118 /src | |
parent | 9ecbff125a5d042c9120ed9002d3dc1376c670ed (diff) | |
parent | cf9196bdbc009e79f3806f7353c1ce6885dd677e (diff) | |
download | libgit2-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.c | 7 |
1 files changed, 4 insertions, 3 deletions
@@ -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); |