mirror of
https://github.com/git/git.git
synced 2024-05-05 21:06:11 +02:00
merge-ort/merge-recursive: do report errors in `merge_submodule()`
In 24876ebf68
(commit-reach(repo_in_merge_bases_many): report missing
commits, 2024-02-28), I taught `merge_submodule()` to handle errors
reported by `repo_in_merge_bases_many()`.
However, those errors were not passed through to the callers. That was
unintentional, and this commit remedies that.
Note that `find_first_merges()` can now also return -1 (because it
passes through that return value from `repo_in_merge_bases()`), and this
commit also adds the forgotten handling for that scenario.
Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Acked-by: Elijah Newren <newren@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
81a34cbb2e
commit
25fd20eb44
|
@ -1819,6 +1819,7 @@ static int merge_submodule(struct merge_options *opt,
|
|||
_("Failed to merge submodule %s "
|
||||
"(repository corrupt)"),
|
||||
path);
|
||||
ret = -1;
|
||||
goto cleanup;
|
||||
}
|
||||
if (ret2 > 0)
|
||||
|
@ -1829,6 +1830,7 @@ static int merge_submodule(struct merge_options *opt,
|
|||
_("Failed to merge submodule %s "
|
||||
"(repository corrupt)"),
|
||||
path);
|
||||
ret = -1;
|
||||
goto cleanup;
|
||||
}
|
||||
if (!ret2) {
|
||||
|
@ -1848,6 +1850,7 @@ static int merge_submodule(struct merge_options *opt,
|
|||
_("Failed to merge submodule %s "
|
||||
"(repository corrupt)"),
|
||||
path);
|
||||
ret = -1;
|
||||
goto cleanup;
|
||||
}
|
||||
if (ret2 > 0) {
|
||||
|
@ -1866,6 +1869,7 @@ static int merge_submodule(struct merge_options *opt,
|
|||
_("Failed to merge submodule %s "
|
||||
"(repository corrupt)"),
|
||||
path);
|
||||
ret = -1;
|
||||
goto cleanup;
|
||||
}
|
||||
if (ret2 > 0) {
|
||||
|
@ -1899,6 +1903,7 @@ static int merge_submodule(struct merge_options *opt,
|
|||
_("Failed to merge submodule %s "
|
||||
"(repository corrupt)"),
|
||||
path);
|
||||
ret = -1;
|
||||
break;
|
||||
case 0:
|
||||
path_msg(opt, CONFLICT_SUBMODULE_FAILED_TO_MERGE, 0,
|
||||
|
|
|
@ -1246,12 +1246,14 @@ static int merge_submodule(struct merge_options *opt,
|
|||
ret2 = repo_in_merge_bases(&subrepo, commit_base, commit_a);
|
||||
if (ret2 < 0) {
|
||||
output(opt, 1, _("Failed to merge submodule %s (repository corrupt)"), path);
|
||||
ret = -1;
|
||||
goto cleanup;
|
||||
}
|
||||
if (ret2 > 0)
|
||||
ret2 = repo_in_merge_bases(&subrepo, commit_base, commit_b);
|
||||
if (ret2 < 0) {
|
||||
output(opt, 1, _("Failed to merge submodule %s (repository corrupt)"), path);
|
||||
ret = -1;
|
||||
goto cleanup;
|
||||
}
|
||||
if (!ret2) {
|
||||
|
@ -1263,6 +1265,7 @@ static int merge_submodule(struct merge_options *opt,
|
|||
ret2 = repo_in_merge_bases(&subrepo, commit_a, commit_b);
|
||||
if (ret2 < 0) {
|
||||
output(opt, 1, _("Failed to merge submodule %s (repository corrupt)"), path);
|
||||
ret = -1;
|
||||
goto cleanup;
|
||||
}
|
||||
if (ret2) {
|
||||
|
@ -1281,6 +1284,7 @@ static int merge_submodule(struct merge_options *opt,
|
|||
ret2 = repo_in_merge_bases(&subrepo, commit_b, commit_a);
|
||||
if (ret2 < 0) {
|
||||
output(opt, 1, _("Failed to merge submodule %s (repository corrupt)"), path);
|
||||
ret = -1;
|
||||
goto cleanup;
|
||||
}
|
||||
if (ret2) {
|
||||
|
@ -1312,6 +1316,10 @@ static int merge_submodule(struct merge_options *opt,
|
|||
parent_count = find_first_merges(&subrepo, &merges, path,
|
||||
commit_a, commit_b);
|
||||
switch (parent_count) {
|
||||
case -1:
|
||||
output(opt, 1,_("Failed to merge submodule %s (repository corrupt)"), path);
|
||||
ret = -1;
|
||||
break;
|
||||
case 0:
|
||||
output(opt, 1, _("Failed to merge submodule %s (merge following commits not found)"), path);
|
||||
break;
|
||||
|
|
Loading…
Reference in New Issue