* [PATCH v2 0/2] git-merge-file: do not add LF at EOF while applying unrelated change @ 2014-06-28 22:04 Max Kirillov 2014-06-28 22:04 ` [PATCH v2 1/2] t6023-merge-file.sh: fix and mark as broken invalid tests Max Kirillov 2014-06-28 22:04 ` [PATCH v2 2/2] git-merge-file: do not add LF at EOF while applying unrelated change Max Kirillov 0 siblings, 2 replies; 8+ messages in thread From: Max Kirillov @ 2014-06-28 22:04 UTC (permalink / raw) To: Bert Wesarg, Junio C Hamano, Johannes Schindelin; +Cc: git, Max Kirillov I realized the case when the newline adding can be needed. The version 2 have this case (union-merge of changes at EOF without LF) fixed, with adding corresponding tests. Max Kirillov (2): t6023-merge-file.sh: fix and mark as broken invalid tests git-merge-file: do not add LF at EOF while applying unrelated change t/t6023-merge-file.sh | 91 +++++++++++++++++++++++++++++++++++++++++++++++++-- xdiff/xmerge.c | 4 +-- 2 files changed, 90 insertions(+), 5 deletions(-) -- 2.0.0.526.g5318336 ^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH v2 1/2] t6023-merge-file.sh: fix and mark as broken invalid tests 2014-06-28 22:04 [PATCH v2 0/2] git-merge-file: do not add LF at EOF while applying unrelated change Max Kirillov @ 2014-06-28 22:04 ` Max Kirillov 2014-06-28 22:04 ` [PATCH v2 2/2] git-merge-file: do not add LF at EOF while applying unrelated change Max Kirillov 1 sibling, 0 replies; 8+ messages in thread From: Max Kirillov @ 2014-06-28 22:04 UTC (permalink / raw) To: Bert Wesarg, Junio C Hamano, Johannes Schindelin; +Cc: git, Max Kirillov Tests "merge without conflict (missing LF at EOF" and "merge result added missing LF" are meaningless - the first one is identical to "merge without conflict" and the second compares results of those identical tests, which are always same. This has been so since their addition in ba1f5f3537. Probably "new4.txt" was meant to be used instead of "new2.txt". Unfortunately, the current merge-file breaks with new4 - conflict is reported. They also fail at that revision if fixed. Fix the file reference to "new4.txt" and mark the tests as failing - they look like legitimate expectations, just not satisfied at time being. Signed-off-by: Max Kirillov <max@max630.net> --- t/t6023-merge-file.sh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/t/t6023-merge-file.sh b/t/t6023-merge-file.sh index d9f3439..6da921c 100755 --- a/t/t6023-merge-file.sh +++ b/t/t6023-merge-file.sh @@ -77,10 +77,10 @@ test_expect_success "merge without conflict (--quiet)" \ "git merge-file --quiet test.txt orig.txt new2.txt" cp new1.txt test2.txt -test_expect_success "merge without conflict (missing LF at EOF)" \ - "git merge-file test2.txt orig.txt new2.txt" +test_expect_failure "merge without conflict (missing LF at EOF)" \ + "git merge-file test2.txt orig.txt new4.txt" -test_expect_success "merge result added missing LF" \ +test_expect_failure "merge result added missing LF" \ "test_cmp test.txt test2.txt" cp test.txt backup.txt -- 2.0.0.526.g5318336 ^ permalink raw reply related [flat|nested] 8+ messages in thread
* [PATCH v2 2/2] git-merge-file: do not add LF at EOF while applying unrelated change 2014-06-28 22:04 [PATCH v2 0/2] git-merge-file: do not add LF at EOF while applying unrelated change Max Kirillov 2014-06-28 22:04 ` [PATCH v2 1/2] t6023-merge-file.sh: fix and mark as broken invalid tests Max Kirillov @ 2014-06-28 22:04 ` Max Kirillov 2014-06-30 14:55 ` Johannes Schindelin 1 sibling, 1 reply; 8+ messages in thread From: Max Kirillov @ 2014-06-28 22:04 UTC (permalink / raw) To: Bert Wesarg, Junio C Hamano, Johannes Schindelin; +Cc: git, Max Kirillov If 'current-file' does not contain LF at EOF, and change between 'base-file' and 'other-file' does not change any line close to EOF, the 3-way merge should not add LF to EOF. This is what 'diff3 -m' does, and seems to be a reasonable expectation. The change which introduced the behavior is cd1d61c44f. It always calls function xdl_recs_copy() for sides with add_nl == 1. In fact, it looks like the only case when this is needed is when 2 files are being union-merged, and they do not have LF at EOF (strictly speaking, the first of them). Add tests: * "merge without conflict (missing LF at EOF, away from change in the other file)" and "merge does not add LF away of change", to demonstrate the changed behavior. * "conflict at EOF without LF resolved by --union", to verify that the union-merge at the end inerts newline between versions. * some more tests which I felt like not covering the functionality well Signed-off-by: Max Kirillov <max@max630.net> --- t/t6023-merge-file.sh | 85 +++++++++++++++++++++++++++++++++++++++++++++++++++ xdiff/xmerge.c | 4 +-- 2 files changed, 87 insertions(+), 2 deletions(-) diff --git a/t/t6023-merge-file.sh b/t/t6023-merge-file.sh index 6da921c..59ae712 100755 --- a/t/t6023-merge-file.sh +++ b/t/t6023-merge-file.sh @@ -83,6 +83,23 @@ test_expect_failure "merge without conflict (missing LF at EOF)" \ test_expect_failure "merge result added missing LF" \ "test_cmp test.txt test2.txt" +cp new4.txt test3.txt +test_expect_success "merge without conflict (missing LF at EOF, away from change in the other file)" \ + "git merge-file --quiet test3.txt new2.txt new3.txt" + +cat > expect.txt << EOF +DOMINUS regit me, +et nihil mihi deerit. +In loco pascuae ibi me collocavit, +super aquam refectionis educavit me; +animam meam convertit, +deduxit me super semitas jusitiae, +EOF +printf "propter nomen suum." >> expect.txt + +test_expect_success "merge does not add LF away of change" \ + "test_cmp test3.txt expect.txt" + cp test.txt backup.txt test_expect_success "merge with conflicts" \ "test_must_fail git merge-file test.txt orig.txt new3.txt" @@ -107,6 +124,55 @@ EOF test_expect_success "expected conflict markers" "test_cmp test.txt expect.txt" cp backup.txt test.txt + +cat > expect.txt << EOF +Dominus regit me, et nihil mihi deerit. +In loco pascuae ibi me collocavit, +super aquam refectionis educavit me; +animam meam convertit, +deduxit me super semitas jusitiae, +propter nomen suum. +Nam et si ambulavero in medio umbrae mortis, +non timebo mala, quoniam tu mecum es: +virga tua et baculus tuus ipsa me consolata sunt. +EOF +test_expect_success "merge conflicting with --ours" \ + "git merge-file --ours test.txt orig.txt new3.txt && test_cmp test.txt expect.txt" +cp backup.txt test.txt + +cat > expect.txt << EOF +DOMINUS regit me, +et nihil mihi deerit. +In loco pascuae ibi me collocavit, +super aquam refectionis educavit me; +animam meam convertit, +deduxit me super semitas jusitiae, +propter nomen suum. +Nam et si ambulavero in medio umbrae mortis, +non timebo mala, quoniam tu mecum es: +virga tua et baculus tuus ipsa me consolata sunt. +EOF +test_expect_success "merge conflicting with --theirs" \ + "git merge-file --theirs test.txt orig.txt new3.txt && test_cmp test.txt expect.txt" +cp backup.txt test.txt + +cat > expect.txt << EOF +Dominus regit me, et nihil mihi deerit. +DOMINUS regit me, +et nihil mihi deerit. +In loco pascuae ibi me collocavit, +super aquam refectionis educavit me; +animam meam convertit, +deduxit me super semitas jusitiae, +propter nomen suum. +Nam et si ambulavero in medio umbrae mortis, +non timebo mala, quoniam tu mecum es: +virga tua et baculus tuus ipsa me consolata sunt. +EOF +test_expect_success "merge conflicting with --union" \ + "git merge-file --union test.txt orig.txt new3.txt && test_cmp test.txt expect.txt" +cp backup.txt test.txt + test_expect_success "merge with conflicts, using -L" \ "test_must_fail git merge-file -L 1 -L 2 test.txt orig.txt new3.txt" @@ -260,4 +326,23 @@ test_expect_success 'marker size' ' test_cmp expect actual ' +printf "line1\nline2\nline3" >nolf-orig.txt +printf "line1\nline2\nline3x" >nolf-diff1.txt +printf "line1\nline2\nline3y" >nolf-diff2.txt + +test_expect_success 'conflict at EOF without LF resolved by --ours' \ + 'git merge-file -p --ours nolf-diff1.txt nolf-orig.txt nolf-diff2.txt >output.txt && + printf "line1\nline2\nline3x" >expect.txt && + test_cmp expect.txt output.txt' + +test_expect_success 'conflict at EOF without LF resolved by --theirs' \ + 'git merge-file -p --theirs nolf-diff1.txt nolf-orig.txt nolf-diff2.txt >output.txt && + printf "line1\nline2\nline3y" >expect.txt && + test_cmp expect.txt output.txt' + +test_expect_success 'conflict at EOF without LF resolved by --union' \ + 'git merge-file -p --union nolf-diff1.txt nolf-orig.txt nolf-diff2.txt >output.txt && + printf "line1\nline2\nline3x\nline3y" >expect.txt && + test_cmp expect.txt output.txt' + test_done diff --git a/xdiff/xmerge.c b/xdiff/xmerge.c index 9e13b25..625198e 100644 --- a/xdiff/xmerge.c +++ b/xdiff/xmerge.c @@ -245,11 +245,11 @@ static int xdl_fill_merge_buffer(xdfenv_t *xe1, const char *name1, dest ? dest + size : NULL); /* Postimage from side #1 */ if (m->mode & 1) - size += xdl_recs_copy(xe1, m->i1, m->chg1, 1, + size += xdl_recs_copy(xe1, m->i1, m->chg1, (m->mode & 2), dest ? dest + size : NULL); /* Postimage from side #2 */ if (m->mode & 2) - size += xdl_recs_copy(xe2, m->i2, m->chg2, 1, + size += xdl_recs_copy(xe2, m->i2, m->chg2, 0, dest ? dest + size : NULL); } else continue; -- 2.0.0.526.g5318336 ^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH v2 2/2] git-merge-file: do not add LF at EOF while applying unrelated change 2014-06-28 22:04 ` [PATCH v2 2/2] git-merge-file: do not add LF at EOF while applying unrelated change Max Kirillov @ 2014-06-30 14:55 ` Johannes Schindelin 2014-07-01 17:01 ` Junio C Hamano 2014-07-02 4:44 ` Max Kirillov 0 siblings, 2 replies; 8+ messages in thread From: Johannes Schindelin @ 2014-06-30 14:55 UTC (permalink / raw) To: Max Kirillov; +Cc: Bert Wesarg, Junio C Hamano, git Hi Max, On Sun, 29 Jun 2014, Max Kirillov wrote: > diff --git a/xdiff/xmerge.c b/xdiff/xmerge.c > index 9e13b25..625198e 100644 > --- a/xdiff/xmerge.c > +++ b/xdiff/xmerge.c > @@ -245,11 +245,11 @@ static int xdl_fill_merge_buffer(xdfenv_t *xe1, const char *name1, > dest ? dest + size : NULL); > /* Postimage from side #1 */ > if (m->mode & 1) > - size += xdl_recs_copy(xe1, m->i1, m->chg1, 1, > + size += xdl_recs_copy(xe1, m->i1, m->chg1, (m->mode & 2), > dest ? dest + size : NULL); > /* Postimage from side #2 */ > if (m->mode & 2) > - size += xdl_recs_copy(xe2, m->i2, m->chg2, 1, > + size += xdl_recs_copy(xe2, m->i2, m->chg2, 0, > dest ? dest + size : NULL); > } else > continue; Makes sense to me, especially with the nice explanation in the commit message. I just wish the tests were a little easier to understand... It is probably my fault because I insisted on using a text that has *nothing* to do with Git. These days, I would probably have used better file names and would have used file contents that reflect the purpose in the tests (i.e. a line saying "This line ends with a carriage return" or some such). Having said that, here is my ACK for the current revision of the patch series (because I know how much work it would be to fix the issue I described above, and it is an *entirely different* issue from the one you fixed with this series, too). Ciao, Dscho ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v2 2/2] git-merge-file: do not add LF at EOF while applying unrelated change 2014-06-30 14:55 ` Johannes Schindelin @ 2014-07-01 17:01 ` Junio C Hamano 2014-07-02 4:44 ` Max Kirillov 1 sibling, 0 replies; 8+ messages in thread From: Junio C Hamano @ 2014-07-01 17:01 UTC (permalink / raw) To: Johannes Schindelin; +Cc: Max Kirillov, Bert Wesarg, git Johannes Schindelin <Johannes.Schindelin@gmx.de> writes: > Hi Max, > > On Sun, 29 Jun 2014, Max Kirillov wrote: > >> diff --git a/xdiff/xmerge.c b/xdiff/xmerge.c >> index 9e13b25..625198e 100644 >> --- a/xdiff/xmerge.c >> +++ b/xdiff/xmerge.c >> @@ -245,11 +245,11 @@ static int xdl_fill_merge_buffer(xdfenv_t *xe1, const char *name1, >> dest ? dest + size : NULL); >> /* Postimage from side #1 */ >> if (m->mode & 1) >> - size += xdl_recs_copy(xe1, m->i1, m->chg1, 1, >> + size += xdl_recs_copy(xe1, m->i1, m->chg1, (m->mode & 2), >> dest ? dest + size : NULL); >> /* Postimage from side #2 */ >> if (m->mode & 2) >> - size += xdl_recs_copy(xe2, m->i2, m->chg2, 1, >> + size += xdl_recs_copy(xe2, m->i2, m->chg2, 0, >> dest ? dest + size : NULL); >> } else >> continue; > > Makes sense to me, especially with the nice explanation in the commit > message. > Having said that, here is my ACK for the current revision of the patch > series ... Thanks, both. Queued. ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v2 2/2] git-merge-file: do not add LF at EOF while applying unrelated change 2014-06-30 14:55 ` Johannes Schindelin 2014-07-01 17:01 ` Junio C Hamano @ 2014-07-02 4:44 ` Max Kirillov 2014-07-02 14:08 ` Johannes Schindelin 1 sibling, 1 reply; 8+ messages in thread From: Max Kirillov @ 2014-07-02 4:44 UTC (permalink / raw) To: Johannes Schindelin; +Cc: Bert Wesarg, Junio C Hamano, git On Mon, Jun 30, 2014 at 04:55:10PM +0200, Johannes Schindelin wrote: > I just wish the tests were a little easier to understand... What could be improved with them? > Having said that, here is my ACK for the current revision > of the patch series Thanks. By the way, for "\r\n" eol it did even worse, adding just "\n". And I guess it still adds just "\n" for union merge. Should file merge consider the core.eol? I think it should, and for the conflict markers also, it looks ugly when whole file has "\r\n" but the conflict markers have "\n". But then git-merge-file could not be used outside of repository, I guess. In general, I wish file merging (and diffing) were more tolerant of the line endings in input. Because in windows environment, when people have different core.autocrlf, it becomes quite frustrating to always get conflicts and changes. -- Max ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v2 2/2] git-merge-file: do not add LF at EOF while applying unrelated change 2014-07-02 4:44 ` Max Kirillov @ 2014-07-02 14:08 ` Johannes Schindelin 2014-07-03 4:31 ` Max Kirillov 0 siblings, 1 reply; 8+ messages in thread From: Johannes Schindelin @ 2014-07-02 14:08 UTC (permalink / raw) To: Max Kirillov; +Cc: Bert Wesarg, Junio C Hamano, git Hi Max, On Wed, 2 Jul 2014, Max Kirillov wrote: > On Mon, Jun 30, 2014 at 04:55:10PM +0200, Johannes Schindelin wrote: > > I just wish the tests were a little easier to understand... > > What could be improved with them? Oh, I would name the files more appropriately, for example. That is, instead of test1.txt I would call it mixed-endings.txt or lf-only.txt or some such. And instead of the Latin version of Psalm 23, I would put lines into the files that describe their own role in the test, i.e. unchanged ends with a carriage return ends with a line feed unchanged or similar. Please keep in mind that this critique is most likely on my *own* work, for all I know *I* introduced those files. > By the way, for "\r\n" eol it did even worse, adding just "\n". And I > guess it still adds just "\n" for union merge. Should file merge > consider the core.eol? I think it should, and for the conflict markers > also, it looks ugly when whole file has "\r\n" but the conflict markers > have "\n". But then git-merge-file could not be used outside of > repository, I guess. Oh, why not? It could read the configuration if it's inside a working directory, and just read /etc/gitconfig and $HOME/.gitconfig when outside... > In general, I wish file merging (and diffing) were more tolerant of the > line endings in input. Because in windows environment, when people have > different core.autocrlf, it becomes quite frustrating to always get > conflicts and changes. Amen! Ciao, Dscho ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v2 2/2] git-merge-file: do not add LF at EOF while applying unrelated change 2014-07-02 14:08 ` Johannes Schindelin @ 2014-07-03 4:31 ` Max Kirillov 0 siblings, 0 replies; 8+ messages in thread From: Max Kirillov @ 2014-07-03 4:31 UTC (permalink / raw) To: Johannes Schindelin; +Cc: Bert Wesarg, Junio C Hamano, git On Wed, Jul 02, 2014 at 04:08:28PM +0200, Johannes Schindelin wrote: >> What could be improved with them? > > Oh, I would name the files more appropriately, for example. That is, > instead of test1.txt I would call it mixed-endings.txt or lf-only.txt or > some such. > > And instead of the Latin version of Psalm 23, I would put lines into the > files that describe their own role in the test, i.e. > > unchanged > ends with a carriage return > ends with a line feed > unchanged > > or similar. > > Please keep in mind that this critique is most likely on my *own* work, > for all I know *I* introduced those files. I asked to have something in mind if I return to this. Thanks for the notes. -- Max ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2014-07-03 4:32 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2014-06-28 22:04 [PATCH v2 0/2] git-merge-file: do not add LF at EOF while applying unrelated change Max Kirillov 2014-06-28 22:04 ` [PATCH v2 1/2] t6023-merge-file.sh: fix and mark as broken invalid tests Max Kirillov 2014-06-28 22:04 ` [PATCH v2 2/2] git-merge-file: do not add LF at EOF while applying unrelated change Max Kirillov 2014-06-30 14:55 ` Johannes Schindelin 2014-07-01 17:01 ` Junio C Hamano 2014-07-02 4:44 ` Max Kirillov 2014-07-02 14:08 ` Johannes Schindelin 2014-07-03 4:31 ` Max Kirillov
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).