From: "Elijah Newren via GitGitGadget" <gitgitgadget@gmail.com>
To: git@vger.kernel.org
Cc: "Jeff King" <peff@peff.net>,
"Jonathan Nieder" <jrnieder@gmail.com>,
"Sergey Organov" <sorganov@gmail.com>,
"Bagas Sanjaya" <bagasdotme@gmail.com>,
"Elijah Newren" <newren@gmail.com>,
"Ævar Arnfjörð Bjarmason" <avarab@gmail.com>,
"Neeraj Singh" <nksingh85@gmail.com>,
"Johannes Altmanninger" <aclopte@gmail.com>,
"Elijah Newren" <newren@gmail.com>
Subject: [PATCH v4 00/10] Add a new --remerge-diff capability to show & log
Date: Fri, 21 Jan 2022 19:12:10 +0000 [thread overview]
Message-ID: <pull.1103.v4.git.1642792341.gitgitgadget@gmail.com> (raw)
In-Reply-To: <pull.1103.v3.git.1640907369.gitgitgadget@gmail.com>
Here are some patches to add a --remerge-diff capability to show & log,
which works by comparing merge commits to an automatic remerge (note that
the automatic remerge tree can contain files with conflict markers).
Changes since v3:
* Filter conflict headers according to pathspecs
* Instead of always including conflict headers for all diff types, only
select them with --diff-filter=U OR whenever the associated diff in
question is selected
* New testcases dealing with --diff-filter, pathspecs, and default history
simplification
* Switched back from die_errno() to die()
Changes NOT included (mostly because I'm not sure what to add or where):
* Johannes Altimanninger suggested changing the ordering of the new headers
relative to other headers. He made a good point, but I also like having
the conflict messages next to the text, so I'm conflicted about what's
best.
* (Technically not part of this feature, but kind of related.) Months ago,
Junio suggested documenting ${GIT_DIR}/AUTO_MERGE better
(https://lore.kernel.org/git/xmqqtuj4nepe.fsf@gitster.g/). I looked at
the time, but couldn't find a place to put it that made sense to me.
Changes since v2 (of the restarted submission):
* Numerous small improvements suggested by Johannes Altmanninger
* Avoid including conflict messages from inner merges (due to example
pointed out by Ævar).
* Added a "remerge" prefix to all the new diff headers (suggested by Junio
in a previous round, but I couldn't come up with a good name before. It
suddenly hit me that "remerge" is an obvious prefix to use, and even
helps explain what the rest of the line is for.)
Changes since v1 (of the restarted submission, which technically was v2):
* Restructured the series, so the first patch introduces the feature --
with a bunch of caveats. Subsequent patches clean up those caveats. This
avoids introducing not-yet-used functions, and hopefully makes review
easier.
* added testcases
* numerous small improvements suggested by Ævar and Junio
Changes since original submission[1]:
* Rebased on top of the version of ns/tmp-objdir that Neeraj submitted
(Neeraj's patches were based on v2.34, but ns/tmp-objdir got applied on
an old commit and does not even build because of that).
* Modify ll-merge API to return a status, instead of printing "Cannot merge
binary files" on stdout[2] (as suggested by Peff)
* Make conflict messages and other such warnings into diff headers of the
subsequent remerge-diff rather than appearing in the diff as file content
of some funny looking filenames (as suggested by Peff[3] and Junio[4])
* Sergey ack'ed the diff-merges.c portion of the patches, but that wasn't
limited to one patch so not sure where to record that ack.
[1]
https://lore.kernel.org/git/pull.1080.git.git.1630376800.gitgitgadget@gmail.com/;
GitHub wouldn't let me change the target branch for the PR, so I had to
create a new one with the new base and thus the reason for not sending this
as v2 even though it is. [2]
https://lore.kernel.org/git/YVOZRhWttzF18Xql@coredump.intra.peff.net/,
https://lore.kernel.org/git/YVOZty9D7NRbzhE5@coredump.intra.peff.net/ [3]
https://lore.kernel.org/git/YVOXPTjsp9lrxmS6@coredump.intra.peff.net/ [4]
https://lore.kernel.org/git/xmqqr1d7e4ug.fsf@gitster.g/
=== FURTHER BACKGROUND (original cover letter material) ==
Here are some example commits you can try this out on (with git show
--remerge-diff $COMMIT):
* git.git conflicted merge: 07601b5b36
* git.git non-conflicted change: bf04590ecd
* linux.git conflicted merge: eab3540562fb
* linux.git non-conflicted change: 223cea6a4f05
Many more can be found by just running git log --merges --remerge-diff in
your repository of choice and searching for diffs (most merges tend to be
clean and unmodified and thus produce no diff but a search of '^diff' in the
log output tends to find the examples nicely).
Some basic high level details about this new option:
* This option is most naturally compared to --cc, though the output seems
to be much more understandable to most users than --cc output.
* Since merges are often clean and unmodified, this new option results in
an empty diff for most merges.
* This new option shows things like the removal of conflict markers, which
hunks users picked from the various conflicted sides to keep or remove,
and shows changes made outside of conflict markers (which might reflect
changes needed to resolve semantic conflicts or cleanups of e.g.
compilation warnings or other additional changes an integrator felt
belonged in the merged result).
* This new option does not (currently) work for octopus merges, since
merge-ort is specific to two-parent merges[1].
* This option will not work on a read-only or full filesystem[2].
* We discussed this capability at Git Merge 2020, and one of the
suggestions was doing a periodic git gc --auto during the operation (due
to potential new blobs and trees created during the operation). I found a
way to avoid that; see [2].
* This option is faster than you'd probably expect; it handles 33.5 merge
commits per second in linux.git on my computer; see below.
In regards to the performance point above, the timing for running the
following command:
time git log --min-parents=2 --max-parents=2 $DIFF_FLAG | wc -l
in linux.git (with v5.4 checked out, since my copy of linux is very out of
date) is as follows:
DIFF_FLAG=--cc: 71m 31.536s
DIFF_FLAG=--remerge-diff: 31m 3.170s
Note that there are 62476 merges in this history. Also, output size is:
DIFF_FLAG=--cc: 2169111 lines
DIFF_FLAG=--remerge-diff: 2458020 lines
So roughly the same amount of output as --cc, as you'd expect.
As a side note: git log --remerge-diff, when run in various repositories and
allowed to run all the way back to the beginning(s) of history, is a nice
stress test of sorts for merge-ort. Especially when users run it for you on
their repositories they are working on, whether intentionally or via a bug
in a tool triggering that command to be run unexpectedly. Long story short,
such a bug in an internal tool existed in December 2020 and this command was
run on an internal repository and found a platform-specific bug in merge-ort
on some really old merge commit from that repo. I fixed that bug (a
STABLE_QSORT thing) while upstreaming all the merge-ort patches in the mean
time, but it was nice getting extra testing. Having more folks run this on
their repositories might be useful extra testing of the new merge strategy.
Also, I previously mentioned --remerge-diff-only (a flag to show how
cherry-picks or reverts differ from an automatic cherry-pick or revert, in
addition to showing how merges differ from an automatic merge). This series
does not include the patches to introduce that option; I'll submit them
later.
Two other things that might be interesting but are not included and which I
haven't investigated:
* some mechanism for passing extra merge options through (e.g.
-Xignore-space-change)
* a capability to compare the automatic merge to a second automatic merge
done with different merge options. (Not sure if this would be of interest
to end users, but might be interesting while developing new a
--strategy-option, or maybe checking how changing some default in the
merge algorithm would affect historical merges in various repositories).
[1] I have nebulous ideas of how an Octopus-centric ORT strategy could be
written -- basically, just repeatedly invoking ort and trying to make sure
nested conflicts can be differentiated. For now, though, a simple warning is
printed that octopus merges are not handled and no diff will be shown. [2]
New blobs/trees can be written by the three-way merging step. These are
written to a temporary area (via tmp-objdir.c) under the git object store
that is cleaned up at the end of the operation, with the new loose objects
from the remerge being cleaned up after each individual merge.
Elijah Newren (10):
show, log: provide a --remerge-diff capability
log: clean unneeded objects during `log --remerge-diff`
ll-merge: make callers responsible for showing warnings
merge-ort: capture and print ll-merge warnings in our preferred
fashion
merge-ort: mark a few more conflict messages as omittable
merge-ort: format messages slightly different for use in headers
diff: add ability to insert additional headers for paths
show, log: include conflict/warning messages in --remerge-diff headers
merge-ort: mark conflict/warning messages from inner merges as
omittable
diff-merges: avoid history simplifications when diffing merges
Documentation/diff-options.txt | 10 +-
apply.c | 5 +-
builtin/checkout.c | 12 +-
builtin/log.c | 15 ++
diff-merges.c | 14 ++
diff.c | 124 +++++++++++++-
diff.h | 3 +-
ll-merge.c | 40 +++--
ll-merge.h | 9 +-
log-tree.c | 118 +++++++++++++-
merge-blobs.c | 5 +-
merge-ort.c | 55 ++++++-
merge-ort.h | 10 ++
merge-recursive.c | 9 +-
merge-recursive.h | 2 +
notes-merge.c | 5 +-
rerere.c | 9 +-
revision.h | 6 +-
t/t4069-remerge-diff.sh | 290 +++++++++++++++++++++++++++++++++
t/t6404-recursive-merge.sh | 9 +-
t/t6406-merge-attr.sh | 9 +-
tmp-objdir.c | 5 +
tmp-objdir.h | 6 +
23 files changed, 722 insertions(+), 48 deletions(-)
create mode 100755 t/t4069-remerge-diff.sh
base-commit: 4e44121c2d7bced65e25eb7ec5156290132bec94
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1103%2Fnewren%2Fremerge-diff-v4
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1103/newren/remerge-diff-v4
Pull-Request: https://github.com/gitgitgadget/git/pull/1103
Range-diff vs v3:
1: d57ae218cf9 ! 1: 0b94724311d show, log: provide a --remerge-diff capability
@@ builtin/log.c: static int cmd_log_walk(struct rev_info *rev)
+ if (rev->remerge_diff) {
+ remerge_objdir = tmp_objdir_create("remerge-diff");
+ if (!remerge_objdir)
-+ die_errno(_("unable to create temporary object directory"));
++ die(_("unable to create temporary object directory"));
+ tmp_objdir_replace_primary_odb(remerge_objdir, 1);
+ }
@@ t/t4069-remerge-diff.sh (new)
+
+. ./test-lib.sh
+
++# This test is ort-specific
++test "${GIT_TEST_MERGE_ALGORITHM:-ort}" = ort || {
++ skip_all="GIT_TEST_MERGE_ALGORITHM != ort"
++ test_done
++}
++
+test_expect_success 'setup basic merges' '
+ test_write_lines 1 2 3 4 5 6 7 8 9 >numbers &&
+ git add numbers &&
2: 798625b53f2 ! 2: f06de6c1b2f log: clean unneeded objects during `log --remerge-diff`
@@ builtin/log.c: static int cmd_log_walk(struct rev_info *rev)
- if (!remerge_objdir)
+ rev->remerge_objdir = tmp_objdir_create("remerge-diff");
+ if (!rev->remerge_objdir)
- die_errno(_("unable to create temporary object directory"));
+ die(_("unable to create temporary object directory"));
- tmp_objdir_replace_primary_odb(remerge_objdir, 1);
+ tmp_objdir_replace_primary_odb(rev->remerge_objdir, 1);
}
3: b952f674df1 = 3: 8d6c3d48f0e ll-merge: make callers responsible for showing warnings
4: e8cf1626960 = 4: de8e8f88fa4 merge-ort: capture and print ll-merge warnings in our preferred fashion
5: 4d1848c8a29 = 5: 6b535a4d55a merge-ort: mark a few more conflict messages as omittable
6: 81e736b847e = 6: e2441608c63 merge-ort: format messages slightly different for use in headers
7: 5000a94aa98 ! 7: 62734beb693 diff: add ability to insert additional headers for paths
@@ diff.c: int diff_unmodified_pair(struct diff_filepair *p)
static void diff_flush_patch(struct diff_filepair *p, struct diff_options *o)
{
- if (diff_unmodified_pair(p))
++ int include_conflict_headers =
++ (additional_headers(o, p->one->path) &&
++ (!o->filter || filter_bit_tst(DIFF_STATUS_UNMERGED, o)));
++
+ /*
+ * Check if we can return early without showing a diff. Note that
+ * diff_filepair only stores {oid, path, mode, is_valid}
+ * information for each path, and thus diff_unmodified_pair() only
+ * considers those bits of info. However, we do not want pairs
-+ * created by create_filepairs_for_header_only_notifications() to
-+ * be ignored, so return early if both p is unmodified AND
-+ * p->one->path is not in additional headers.
++ * created by create_filepairs_for_header_only_notifications()
++ * (which always look like unmodified pairs) to be ignored, so
++ * return early if both p is unmodified AND we don't want to
++ * include_conflict_headers.
+ */
-+ if (diff_unmodified_pair(p) && !additional_headers(o, p->one->path))
++ if (diff_unmodified_pair(p) && !include_conflict_headers)
return;
+ /* Actually, we can also return early to avoid showing tree diffs */
@@ diff.c: static void diff_flush_checkdiff(struct diff_filepair *p,
{
struct diff_queue_struct *q = &diff_queued_diff;
int i;
++ int include_conflict_headers =
++ (o->additional_path_headers &&
++ (!o->filter || filter_bit_tst(DIFF_STATUS_UNMERGED, o)));
+
-+ if (o->additional_path_headers &&
-+ !strmap_empty(o->additional_path_headers))
++ if (include_conflict_headers)
+ return 0;
++
for (i = 0; i < q->nr; i++)
if (!diff_unmodified_pair(q->queue[i]))
return 0;
@@ diff.h: void diffcore_fix_diff_index(void);
" -a --text treat all files as text.\n"
-int diff_queue_is_empty(void);
-+int diff_queue_is_empty(struct diff_options*);
++int diff_queue_is_empty(struct diff_options *o);
void diff_flush(struct diff_options*);
void diff_free(struct diff_options*);
void diff_warn_rename_limit(const char *varname, int needed, int degraded_cc);
8: 78ec1f44e4e ! 8: 17eccf7e0d6 show, log: include conflict/warning messages in --remerge-diff headers
@@ Commit message
Signed-off-by: Elijah Newren <newren@gmail.com>
## log-tree.c ##
+@@
+ #include "line-log.h"
+ #include "help.h"
+ #include "range-diff.h"
++#include "strmap.h"
+
+ static struct decoration name_decoration = { "object names" };
+ static int decoration_loaded;
+@@ log-tree.c: static int do_diff_combined(struct rev_info *opt, struct commit *commit)
+ return !opt->loginfo;
+ }
+
++static void setup_additional_headers(struct diff_options *o,
++ struct strmap *all_headers)
++{
++ struct hashmap_iter iter;
++ struct strmap_entry *entry;
++
++ /*
++ * Make o->additional_path_headers contain the subset of all_headers
++ * that match o->pathspec. If there aren't any that match o->pathspec,
++ * then make o->additional_path_headers be NULL.
++ */
++
++ if (!o->pathspec.nr) {
++ o->additional_path_headers = all_headers;
++ return;
++ }
++
++ o->additional_path_headers = xmalloc(sizeof(struct strmap));
++ strmap_init_with_options(o->additional_path_headers, NULL, 0);
++ strmap_for_each_entry(all_headers, &iter, entry) {
++ if (match_pathspec(the_repository->index, &o->pathspec,
++ entry->key, strlen(entry->key),
++ 0 /* prefix */, NULL /* seen */,
++ 0 /* is_dir */))
++ strmap_put(o->additional_path_headers,
++ entry->key, entry->value);
++ }
++ if (!strmap_get_size(o->additional_path_headers)) {
++ strmap_clear(o->additional_path_headers, 0);
++ FREE_AND_NULL(o->additional_path_headers);
++ }
++}
++
++static void cleanup_additional_headers(struct diff_options *o)
++{
++ if (!o->pathspec.nr) {
++ o->additional_path_headers = NULL;
++ return;
++ }
++ if (!o->additional_path_headers)
++ return;
++
++ strmap_clear(o->additional_path_headers, 0);
++ FREE_AND_NULL(o->additional_path_headers);
++}
++
+ static int do_remerge_diff(struct rev_info *opt,
+ struct commit_list *parents,
+ struct object_id *oid,
@@ log-tree.c: static int do_remerge_diff(struct rev_info *opt,
/* Setup merge options */
init_merge_options(&o, the_repository);
@@ log-tree.c: static int do_remerge_diff(struct rev_info *opt,
merge_incore_recursive(&o, bases, parent1, parent2, &res);
/* Show the diff */
-+ opt->diffopt.additional_path_headers = res.path_messages;
++ setup_additional_headers(&opt->diffopt, res.path_messages);
diff_tree_oid(&res.tree->object.oid, oid, "", &opt->diffopt);
log_tree_diff_flush(opt);
/* Cleanup */
-+ opt->diffopt.additional_path_headers = NULL;
++ cleanup_additional_headers(&opt->diffopt);
strbuf_release(&parent1_desc);
strbuf_release(&parent2_desc);
merge_finalize(&o, &res);
@@ merge-ort.h: struct merge_result {
* to merge_incore_*(). Includes data needed to update the index (if
## t/t4069-remerge-diff.sh ##
-@@ t/t4069-remerge-diff.sh: test_description='remerge-diff handling'
-
- . ./test-lib.sh
-
-+# --remerge-diff uses ort under the hood regardless of setting. However,
-+# we set up a file/directory conflict beforehand, and the different backends
-+# handle the conflict differently, which would require separate code paths
-+# to resolve. There's not much point in making the code uglier to do that,
-+# though, when the real thing we are testing (--remerge-diff) will hardcode
-+# calls directly into the merge-ort API anyway. So just force the use of
-+# ort on the setup too.
-+GIT_TEST_MERGE_ALGORITHM=ort
-+
- test_expect_success 'setup basic merges' '
- test_write_lines 1 2 3 4 5 6 7 8 9 >numbers &&
- git add numbers &&
@@ t/t4069-remerge-diff.sh: test_expect_success 'remerge-diff with both a resolved conflict and an unrelated
git log -1 --oneline ab_resolution >tmp &&
cat <<-EOF >>tmp &&
@@ t/t4069-remerge-diff.sh: test_expect_success 'remerge-diff with both a resolved
+ sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
+ test_cmp expect actual
+'
++
++test_expect_success 'remerge-diff w/ diff-filter=U: all conflict headers, no diff content' '
++ git log -1 --oneline resolution >tmp &&
++ cat <<-EOF >>tmp &&
++ diff --git a/file_or_directory~HASH (side1) b/file_or_directory~HASH (side1)
++ remerge CONFLICT (file/directory): directory in the way of file_or_directory from HASH (side1); moving it to file_or_directory~HASH (side1) instead.
++ diff --git a/letters b/letters
++ remerge CONFLICT (rename/rename): letters renamed to letters_side1 in HASH (side1) and to letters_side2 in HASH (side2).
++ diff --git a/numbers b/numbers
++ remerge CONFLICT (modify/delete): numbers deleted in HASH (side2) and modified in HASH (side1). Version HASH (side1) of numbers left in tree.
++ EOF
++ # We still have some sha1 hashes above; rip them out so test works
++ # with sha256
++ sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >expect &&
++
++ git show --oneline --remerge-diff --diff-filter=U resolution >tmp &&
++ sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
++ test_cmp expect actual
++'
++
++test_expect_success 'remerge-diff w/ diff-filter=R: relevant file + conflict header' '
++ git log -1 --oneline resolution >tmp &&
++ cat <<-EOF >>tmp &&
++ diff --git a/file_or_directory~HASH (side1) b/wanted_content
++ similarity index 100%
++ rename from file_or_directory~HASH (side1)
++ rename to wanted_content
++ remerge CONFLICT (file/directory): directory in the way of file_or_directory from HASH (side1); moving it to file_or_directory~HASH (side1) instead.
++ EOF
++ # We still have some sha1 hashes above; rip them out so test works
++ # with sha256
++ sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >expect &&
++
++ git show --oneline --remerge-diff --diff-filter=R resolution >tmp &&
++ sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
++ test_cmp expect actual
++'
++
++test_expect_success 'remerge-diff w/ pathspec: limits to relevant file including conflict header' '
++ git log -1 --oneline resolution >tmp &&
++ cat <<-EOF >>tmp &&
++ diff --git a/letters b/letters
++ remerge CONFLICT (rename/rename): letters renamed to letters_side1 in HASH (side1) and to letters_side2 in HASH (side2).
++ diff --git a/letters_side2 b/letters_side2
++ deleted file mode 100644
++ index b236ae5..0000000
++ --- a/letters_side2
++ +++ /dev/null
++ @@ -1,9 +0,0 @@
++ -a
++ -b
++ -c
++ -d
++ -e
++ -f
++ -g
++ -h
++ -i
++ EOF
++ # We still have some sha1 hashes above; rip them out so test works
++ # with sha256
++ sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >expect &&
++
++ git show --oneline --remerge-diff --full-history resolution -- "letters*" >tmp &&
++ sed -e "s/[0-9a-f]\{7,\}/HASH/g" tmp >actual &&
++ test_cmp expect actual
++'
+
test_done
9: 64b44ee84f3 = 9: b3e7656cfc6 merge-ort: mark conflict/warning messages from inner merges as omittable
-: ----------- > 10: ea5df61cf35 diff-merges: avoid history simplifications when diffing merges
--
gitgitgadget
next prev parent reply other threads:[~2022-01-21 19:12 UTC|newest]
Thread overview: 113+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-12-21 18:05 [PATCH 0/9] Add a new --remerge-diff capability to show & log Elijah Newren via GitGitGadget
2021-12-21 18:05 ` [PATCH 1/9] tmp_objdir: add a helper function for discarding all contained objects Elijah Newren via GitGitGadget
2021-12-21 23:26 ` Junio C Hamano
2021-12-21 23:51 ` Elijah Newren
2021-12-22 6:23 ` Junio C Hamano
2021-12-25 2:29 ` Elijah Newren
2021-12-21 18:05 ` [PATCH 2/9] ll-merge: make callers responsible for showing warnings Elijah Newren via GitGitGadget
2021-12-21 21:19 ` Ævar Arnfjörð Bjarmason
2021-12-21 21:57 ` Elijah Newren
2021-12-21 23:02 ` Ævar Arnfjörð Bjarmason
2021-12-21 23:15 ` Elijah Newren
2021-12-21 23:44 ` Junio C Hamano
2021-12-23 18:26 ` Elijah Newren
2021-12-21 18:05 ` [PATCH 3/9] merge-ort: capture and print ll-merge warnings in our preferred fashion Elijah Newren via GitGitGadget
2021-12-22 0:00 ` Junio C Hamano
2021-12-23 18:36 ` Elijah Newren
2021-12-21 18:05 ` [PATCH 4/9] merge-ort: mark a few more conflict messages as omittable Elijah Newren via GitGitGadget
2021-12-22 0:06 ` Junio C Hamano
2021-12-23 18:38 ` Elijah Newren
2021-12-21 18:05 ` [PATCH 5/9] merge-ort: make path_messages available to external callers Elijah Newren via GitGitGadget
2021-12-21 18:05 ` [PATCH 6/9] diff: add ability to insert additional headers for paths Elijah Newren via GitGitGadget
2021-12-22 0:24 ` Junio C Hamano
2021-12-25 2:35 ` Elijah Newren
2021-12-21 18:05 ` [PATCH 7/9] merge-ort: format messages slightly different for use in headers Elijah Newren via GitGitGadget
2021-12-21 18:05 ` [PATCH 8/9] show, log: provide a --remerge-diff capability Elijah Newren via GitGitGadget
2021-12-21 21:23 ` Ævar Arnfjörð Bjarmason
2021-12-21 22:18 ` Elijah Newren
2021-12-21 18:05 ` [PATCH 9/9] doc/diff-options: explain the new --remerge-diff option Elijah Newren via GitGitGadget
2021-12-21 21:28 ` Ævar Arnfjörð Bjarmason
2021-12-21 22:24 ` Elijah Newren
2021-12-21 23:47 ` Ævar Arnfjörð Bjarmason
2021-12-22 19:05 ` Elijah Newren
2021-12-21 23:20 ` [PATCH 0/9] Add a new --remerge-diff capability to show & log Junio C Hamano
2021-12-21 23:43 ` Elijah Newren
2021-12-22 0:33 ` Junio C Hamano
2021-12-25 7:59 ` [PATCH v2 0/8] " Elijah Newren via GitGitGadget
2021-12-25 7:59 ` [PATCH v2 1/8] show, log: provide a --remerge-diff capability Elijah Newren via GitGitGadget
2021-12-28 10:56 ` Johannes Altmanninger
2021-12-28 22:34 ` Elijah Newren
2021-12-28 23:01 ` brian m. carlson
2021-12-28 23:45 ` Elijah Newren
2021-12-25 7:59 ` [PATCH v2 2/8] log: clean unneeded objects during `log --remerge-diff` Elijah Newren via GitGitGadget
2021-12-25 7:59 ` [PATCH v2 3/8] ll-merge: make callers responsible for showing warnings Elijah Newren via GitGitGadget
2021-12-28 10:56 ` Johannes Altmanninger
2021-12-28 19:37 ` Elijah Newren
2021-12-28 22:05 ` Johannes Altmanninger
2021-12-25 7:59 ` [PATCH v2 4/8] merge-ort: capture and print ll-merge warnings in our preferred fashion Elijah Newren via GitGitGadget
2021-12-25 7:59 ` [PATCH v2 5/8] merge-ort: mark a few more conflict messages as omittable Elijah Newren via GitGitGadget
2021-12-25 7:59 ` [PATCH v2 6/8] merge-ort: format messages slightly different for use in headers Elijah Newren via GitGitGadget
2021-12-26 18:30 ` In-tree strbuf "in-place" search/replace (was: [PATCH v2 6/8] merge-ort: format messages slightly different for use in headers) Ævar Arnfjörð Bjarmason
2021-12-28 10:56 ` [PATCH v2 6/8] merge-ort: format messages slightly different for use in headers Johannes Altmanninger
2021-12-28 21:48 ` Elijah Newren
2021-12-25 7:59 ` [PATCH v2 7/8] diff: add ability to insert additional headers for paths Elijah Newren via GitGitGadget
2021-12-28 10:57 ` Johannes Altmanninger
2021-12-28 21:09 ` Elijah Newren
2021-12-29 0:16 ` Johannes Altmanninger
2021-12-30 22:04 ` Elijah Newren
2021-12-31 3:07 ` Johannes Altmanninger
2021-12-25 7:59 ` [PATCH v2 8/8] show, log: include conflict/warning messages in --remerge-diff headers Elijah Newren via GitGitGadget
2021-12-28 10:57 ` Johannes Altmanninger
2021-12-28 23:42 ` Elijah Newren
2021-12-26 21:52 ` [PATCH v2 0/8] Add a new --remerge-diff capability to show & log Ævar Arnfjörð Bjarmason
2021-12-27 21:11 ` Elijah Newren
2022-01-10 15:48 ` Ævar Arnfjörð Bjarmason
2021-12-28 10:55 ` Johannes Altmanninger
2021-12-30 23:36 ` [PATCH v3 0/9] " Elijah Newren via GitGitGadget
2021-12-30 23:36 ` [PATCH v3 1/9] show, log: provide a --remerge-diff capability Elijah Newren via GitGitGadget
2022-01-19 15:49 ` Ævar Arnfjörð Bjarmason
2022-01-20 2:31 ` Elijah Newren
2022-01-20 7:53 ` Elijah Newren
2022-01-19 16:01 ` Ævar Arnfjörð Bjarmason
2022-01-20 2:33 ` Elijah Newren
2021-12-30 23:36 ` [PATCH v3 2/9] log: clean unneeded objects during `log --remerge-diff` Elijah Newren via GitGitGadget
2021-12-30 23:36 ` [PATCH v3 3/9] ll-merge: make callers responsible for showing warnings Elijah Newren via GitGitGadget
2022-01-19 16:41 ` Ævar Arnfjörð Bjarmason
2022-01-20 3:29 ` Elijah Newren
2021-12-30 23:36 ` [PATCH v3 4/9] merge-ort: capture and print ll-merge warnings in our preferred fashion Elijah Newren via GitGitGadget
2021-12-30 23:36 ` [PATCH v3 5/9] merge-ort: mark a few more conflict messages as omittable Elijah Newren via GitGitGadget
2021-12-30 23:36 ` [PATCH v3 6/9] merge-ort: format messages slightly different for use in headers Elijah Newren via GitGitGadget
2021-12-30 23:36 ` [PATCH v3 7/9] diff: add ability to insert additional headers for paths Elijah Newren via GitGitGadget
2021-12-30 23:36 ` [PATCH v3 8/9] show, log: include conflict/warning messages in --remerge-diff headers Elijah Newren via GitGitGadget
2022-01-19 16:19 ` Ævar Arnfjörð Bjarmason
2022-01-21 2:16 ` Elijah Newren
2022-01-21 16:55 ` Elijah Newren
2021-12-30 23:36 ` [PATCH v3 9/9] merge-ort: mark conflict/warning messages from inner merges as omittable Elijah Newren via GitGitGadget
2021-12-31 8:46 ` [PATCH v3 0/9] Add a new --remerge-diff capability to show & log Junio C Hamano
2022-01-21 19:12 ` Elijah Newren via GitGitGadget [this message]
2022-01-21 19:12 ` [PATCH v4 01/10] show, log: provide a --remerge-diff capability Elijah Newren via GitGitGadget
2022-02-01 9:09 ` Ævar Arnfjörð Bjarmason
2022-02-01 16:40 ` Elijah Newren
2022-01-21 19:12 ` [PATCH v4 02/10] log: clean unneeded objects during `log --remerge-diff` Elijah Newren via GitGitGadget
2022-02-01 9:35 ` Ævar Arnfjörð Bjarmason
2022-02-01 16:54 ` Elijah Newren
2022-02-02 11:17 ` Ævar Arnfjörð Bjarmason
2022-01-21 19:12 ` [PATCH v4 03/10] ll-merge: make callers responsible for showing warnings Elijah Newren via GitGitGadget
2022-01-21 19:12 ` [PATCH v4 04/10] merge-ort: capture and print ll-merge warnings in our preferred fashion Elijah Newren via GitGitGadget
2022-01-21 19:12 ` [PATCH v4 05/10] merge-ort: mark a few more conflict messages as omittable Elijah Newren via GitGitGadget
2022-01-21 19:12 ` [PATCH v4 06/10] merge-ort: format messages slightly different for use in headers Elijah Newren via GitGitGadget
2022-01-21 19:12 ` [PATCH v4 07/10] diff: add ability to insert additional headers for paths Elijah Newren via GitGitGadget
2022-01-21 19:12 ` [PATCH v4 08/10] show, log: include conflict/warning messages in --remerge-diff headers Elijah Newren via GitGitGadget
2022-01-21 19:12 ` [PATCH v4 09/10] merge-ort: mark conflict/warning messages from inner merges as omittable Elijah Newren via GitGitGadget
2022-01-21 19:12 ` [PATCH v4 10/10] diff-merges: avoid history simplifications when diffing merges Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 00/10] Add a new --remerge-diff capability to show & log Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 01/10] show, log: provide a --remerge-diff capability Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 02/10] log: clean unneeded objects during `log --remerge-diff` Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 03/10] ll-merge: make callers responsible for showing warnings Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 04/10] merge-ort: capture and print ll-merge warnings in our preferred fashion Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 05/10] merge-ort: mark a few more conflict messages as omittable Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 06/10] merge-ort: format messages slightly different for use in headers Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 07/10] diff: add ability to insert additional headers for paths Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 08/10] show, log: include conflict/warning messages in --remerge-diff headers Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 09/10] merge-ort: mark conflict/warning messages from inner merges as omittable Elijah Newren via GitGitGadget
2022-02-02 2:37 ` [PATCH v5 10/10] diff-merges: avoid history simplifications when diffing merges Elijah Newren via GitGitGadget
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=pull.1103.v4.git.1642792341.gitgitgadget@gmail.com \
--to=gitgitgadget@gmail.com \
--cc=aclopte@gmail.com \
--cc=avarab@gmail.com \
--cc=bagasdotme@gmail.com \
--cc=git@vger.kernel.org \
--cc=jrnieder@gmail.com \
--cc=newren@gmail.com \
--cc=nksingh85@gmail.com \
--cc=peff@peff.net \
--cc=sorganov@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).