Merge branch 'lm/range-diff-submodule-fix'

"git range-diff" did not work well when the compared ranges had
changes in submodules and the "--submodule=log" was used.

* lm/range-diff-submodule-fix:
  range-diff: allow to diff files regardless of submodule config
This commit is contained in:
Junio C Hamano 2018-10-30 15:43:40 +09:00
commit d450e56423
2 changed files with 30 additions and 1 deletions

View File

@ -354,7 +354,7 @@ static struct diff_filespec *get_filespec(const char *name, const char *p)
{ {
struct diff_filespec *spec = alloc_filespec(name); struct diff_filespec *spec = alloc_filespec(name);
fill_filespec(spec, &null_oid, 0, 0644); fill_filespec(spec, &null_oid, 0, 0100644);
spec->data = (char *)p; spec->data = (char *)p;
spec->size = strlen(p); spec->size = strlen(p);
spec->should_munmap = 0; spec->should_munmap = 0;

View File

@ -122,6 +122,35 @@ test_expect_success 'changed commit' '
test_cmp expected actual test_cmp expected actual
' '
test_expect_success 'changed commit with sm config' '
git range-diff --no-color --submodule=log topic...changed >actual &&
cat >expected <<-EOF &&
1: 4de457d = 1: a4b3333 s/5/A/
2: fccce22 = 2: f51d370 s/4/A/
3: 147e64e ! 3: 0559556 s/11/B/
@@ -10,7 +10,7 @@
9
10
-11
-+B
++BB
12
13
14
4: a63e992 ! 4: d966c5c s/12/B/
@@ -8,7 +8,7 @@
@@
9
10
- B
+ BB
-12
+B
13
EOF
test_cmp expected actual
'
test_expect_success 'no commits on one side' ' test_expect_success 'no commits on one side' '
git commit --amend -m "new message" && git commit --amend -m "new message" &&
git range-diff master HEAD@{1} HEAD git range-diff master HEAD@{1} HEAD