diff options
| author | Junio C Hamano <gitster@pobox.com> | 2018-02-28 13:37:55 -0800 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2018-02-28 13:37:55 -0800 |
| commit | 177bd65cf8601216e906ad56ceb6a46f57df22fa (patch) | |
| tree | b7eb2ee9a3fe8dced866b236e3031f70ca0d9d55 | |
| parent | Merge branch 'sb/status-doc-fix' (diff) | |
| parent | apply: handle Subversion diffs with /dev/null gracefully (diff) | |
| download | git-177bd65cf8601216e906ad56ceb6a46f57df22fa.tar.gz git-177bd65cf8601216e906ad56ceb6a46f57df22fa.zip | |
Merge branch 'tk/apply-dev-null-verify-name-fix'
Many places in "git apply" knew that "/dev/null" that signals
"there is no such file on this side of the diff" can be followed by
whitespace and garbage when parsing a patch, except for one, which
made an otherwise valid patch (e.g. ones from subversion) rejected.
* tk/apply-dev-null-verify-name-fix:
apply: handle Subversion diffs with /dev/null gracefully
apply: demonstrate a problem applying svn diffs
| -rw-r--r-- | apply.c | 2 | ||||
| -rwxr-xr-x | t/t4135-apply-weird-filenames.sh | 17 |
2 files changed, 18 insertions, 1 deletions
@@ -950,7 +950,7 @@ static int gitdiff_verify_name(struct apply_state *state, } free(another); } else { - if (!starts_with(line, "/dev/null\n")) + if (!is_dev_null(line)) return error(_("git apply: bad git-diff - expected /dev/null on line %d"), state->linenr); } diff --git a/t/t4135-apply-weird-filenames.sh b/t/t4135-apply-weird-filenames.sh index 27cb0009fb..c7c688fcc4 100755 --- a/t/t4135-apply-weird-filenames.sh +++ b/t/t4135-apply-weird-filenames.sh @@ -89,4 +89,21 @@ test_expect_success 'traditional, whitespace-damaged, colon in timezone' ' test_cmp expected "post image.txt" ' +cat >diff-from-svn <<\EOF +Index: Makefile +=================================================================== +diff --git a/branches/Makefile +deleted file mode 100644 +--- a/branches/Makefile (revision 13) ++++ /dev/null (nonexistent) +@@ +1 0,0 @@ +- +EOF + +test_expect_success 'apply handles a diff generated by Subversion' ' + >Makefile && + git apply -p2 diff-from-svn && + test_path_is_missing Makefile +' + test_done |
