summaryrefslogtreecommitdiff
path: root/t/t1600-index.sh
diff options
context:
space:
mode:
authorLibravatar David Aguilar <davvid@gmail.com>2016-12-07 02:16:08 -0800
committerLibravatar Junio C Hamano <gitster@pobox.com>2016-12-11 16:18:31 -0800
commit86defcbe3f6c54a31dc898cb3adb4a3b25f1eb1a (patch)
tree3694210813ff6fc37f6e074763bc65b7c88d3a14 /t/t1600-index.sh
parentdifftool: use Git::* functions instead of passing around state (diff)
downloadtgif-86defcbe3f6c54a31dc898cb3adb4a3b25f1eb1a.tar.xz
difftool: fix dir-diff index creation when in a subdirectory
9ec26e7977 (difftool: fix argument handling in subdirs, 2016-07-18) corrected how path arguments are handled in a subdirectory, but it introduced a regression in how entries outside of the subdirectory are handled by dir-diff. When preparing the right-side of the diff we only include the changed paths in the temporary area. The left side of the diff is constructed from a temporary index that is built from the same set of changed files, but it was being constructed from within the subdirectory. This is a problem because the indexed paths are toplevel-relative, and thus they were not getting added to the index. Teach difftool to chdir to the toplevel of the repository before preparing its temporary indexes. This ensures that all of the toplevel-relative paths are valid. Add test cases to more thoroughly exercise this scenario. Reported-by: Frank Becker <fb@mooflu.com> Signed-off-by: David Aguilar <davvid@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 't/t1600-index.sh')
0 files changed, 0 insertions, 0 deletions