]> git.ipfire.org Git - thirdparty/git.git/commitdiff
merge-ort: provide helpful submodule update message when possible
authorElijah Newren <newren@gmail.com>
Thu, 18 Aug 2022 07:15:27 +0000 (07:15 +0000)
committerJunio C Hamano <gitster@pobox.com>
Thu, 18 Aug 2022 16:49:30 +0000 (09:49 -0700)
In commit 4057523a40 ("submodule merge: update conflict error message",
2022-08-04), a more detailed message was provided when submodules
conflict, in order to help users know how to resolve those conflicts.
There were a couple situations for which a different message would be
more appropriate, but that commit left handling those for future work.
Unfortunately, that commit would check if any submodules were of the
type that it didn't know how to explain, and, if so, would avoid
providing the more detailed explanation even for the submodules it did
know how to explain.

Change this to have the code print the helpful messages for the subset
of submodules it knows how to explain.

Signed-off-by: Elijah Newren <newren@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
merge-ort.c

index 8f14f1ad0b2b5b9c8e48ce68b89b55d1345660f8..d94e3f17d7bc7766cf1c20b5a92e06c63da60b41 100644 (file)
@@ -4490,21 +4490,17 @@ static void print_submodule_conflict_suggestion(struct string_list *csub) {
        if (!csub->nr)
                return;
 
-       /*
-        * NEEDSWORK: The steps to resolve these errors deserve a more
-        * detailed explanation than what is currently printed below.
-        */
+       strbuf_add_separated_string_list(&subs, " ", csub);
        for_each_string_list_item(item, csub) {
                struct conflicted_submodule_item *util = item->util;
 
+               /*
+                * NEEDSWORK: The steps to resolve these errors deserve a more
+                * detailed explanation than what is currently printed below.
+                */
                if (util->flag == CONFLICT_SUBMODULE_NOT_INITIALIZED ||
-                       util->flag == CONFLICT_SUBMODULE_HISTORY_NOT_AVAILABLE)
-                       return;
-       }
-
-       strbuf_add_separated_string_list(&subs, " ", csub);
-       for_each_string_list_item(item, csub) {
-               struct conflicted_submodule_item *util = item->util;
+                   util->flag == CONFLICT_SUBMODULE_HISTORY_NOT_AVAILABLE)
+                       continue;
 
                /*
                 * TRANSLATORS: This is a line of advice to resolve a merge