summaryrefslogtreecommitdiff
path: root/t/t9806-git-p4-options.sh
diff options
context:
space:
mode:
authorLibravatar Clemens Buchacher <drizzd@aon.at>2013-05-28 00:49:57 +0200
committerLibravatar Junio C Hamano <gitster@pobox.com>2013-05-28 11:26:24 -0700
commit46ec510ac088ac2669e617a4c8c35e6218dabecc (patch)
tree31bd560c6e1c11bd5d56c29067fa9640f4bb1c0d /t/t9806-git-p4-options.sh
parentfast-export: fix argument name in error messages (diff)
downloadtgif-46ec510ac088ac2669e617a4c8c35e6218dabecc.tar.xz
fix segfault with git log -c --follow
In diff_tree_combined we make a copy of diffopts. In try_to_follow_renames, called via diff_tree_sha1, we free and re-initialize diffopts->pathspec->items. Since we did not make a deep copy of diffopts in diff_tree_combined, the original diffopts does not get the update. By the time we return from diff_tree_combined, rev->diffopt->pathspec->items points to an invalid memory address. We get a segfault next time we try to access that pathspec. Instead, along with the copy of diffopts, make a copy pathspec->items as well. We would also have to make a copy of pathspec->raw to keep it consistent with pathspec->items, but nobody seems to rely on that. Signed-off-by: Clemens Buchacher <drizzd@aon.at> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t9806-git-p4-options.sh')
0 files changed, 0 insertions, 0 deletions