diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-12-17 19:31:36 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2008-12-17 22:36:34 +0100 |
commit | dfab6aaecfe9df67123efc778f6aea4e9814715a (patch) | |
tree | f4ba53a0681ed08c28259ea797767628952b99ed /diff.c | |
parent | Make 'diff_populate_filespec()' use the new 'strbuf_readlink()' (diff) | |
download | git-dfab6aaecfe9df67123efc778f6aea4e9814715a.tar.xz git-dfab6aaecfe9df67123efc778f6aea4e9814715a.zip |
Make 'prepare_temp_file()' ignore st_size for symlinks
The code was already set up to not really need it, so this just massages
it a bit to remove the use entirely.
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'diff.c')
-rw-r--r-- | diff.c | 9 |
1 files changed, 4 insertions, 5 deletions
@@ -1881,13 +1881,12 @@ static void prepare_temp_file(const char *name, if (S_ISLNK(st.st_mode)) { int ret; char buf[PATH_MAX + 1]; /* ought to be SYMLINK_MAX */ - size_t sz = xsize_t(st.st_size); - if (sizeof(buf) <= st.st_size) - die("symlink too long: %s", name); - ret = readlink(name, buf, sz); + ret = readlink(name, buf, sizeof(buf)); if (ret < 0) die("readlink(%s)", name); - prep_temp_blob(temp, buf, sz, + if (ret == sizeof(buf)) + die("symlink too long: %s", name); + prep_temp_blob(temp, buf, ret, (one->sha1_valid ? one->sha1 : null_sha1), (one->sha1_valid ? |