X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=combine-diff.c;h=3a9b32f6b8882f3adb91e5833c205635657a98b7;hb=163b95919428cd7d782af91296e0b886683f2daa;hp=9daa0cb9a95fe6c2176a927f093d8788d0195240;hpb=1db8b60b2a6ef0cc0f7cc7d0783b7cda2ce894ca;p=git.git diff --git a/combine-diff.c b/combine-diff.c index 9daa0cb9a..3a9b32f6b 100644 --- a/combine-diff.c +++ b/combine-diff.c @@ -684,7 +684,7 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent, goto deleted_file; if (S_ISLNK(st.st_mode)) { - size_t len = st.st_size; + size_t len = xsize_t(st.st_size); result_size = len; result = xmalloc(len + 1); if (result_size != readlink(elem->path, result, len)) { @@ -697,10 +697,20 @@ static void show_patch_diff(struct combine_diff_path *elem, int num_parent, } else if (0 <= (fd = open(elem->path, O_RDONLY)) && !fstat(fd, &st)) { - size_t len = st.st_size; + size_t len = xsize_t(st.st_size); size_t sz = 0; + int is_file, i; elem->mode = canon_mode(st.st_mode); + /* if symlinks don't work, assume symlink if all parents + * are symlinks + */ + is_file = has_symlinks; + for (i = 0; !is_file && i < num_parent; i++) + is_file = !S_ISLNK(elem->parent[i].mode); + if (!is_file) + elem->mode = canon_mode(S_IFLNK); + result_size = len; result = xmalloc(len + 1); while (sz < len) {