зеркало из https://github.com/microsoft/git.git
rerere: split code to call ll_merge() further
The merge() helper function is given an existing rerere ID (i.e. the name of the .git/rr-cache/* subdirectory, and the variant number) that identifies one <preimage, postimage> pair, try to see if the conflicted state in the given path can be resolved by using the pair, and if this succeeds, then update the conflicted path with the result in the working tree. To implement rerere_forget() in the multiple variant world, we'd need a helper to do the "see if a <preimage, postimage> pair cleanly resolves a conflicted state we have in-core" part, without actually touching any file in the working tree, in order to identify which variant(s) to remove. Split the logic to do so into a separate helper function try_merge() out of merge(). Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
3d730ed9b2
Коммит
0ce02b3620
47
rerere.c
47
rerere.c
|
@ -621,6 +621,33 @@ int rerere_remaining(struct string_list *merge_rr)
|
|||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* Try using the given conflict resolution "ID" to see
|
||||
* if that recorded conflict resolves cleanly what we
|
||||
* got in the "cur".
|
||||
*/
|
||||
static int try_merge(const struct rerere_id *id, const char *path,
|
||||
mmfile_t *cur, mmbuffer_t *result)
|
||||
{
|
||||
int ret;
|
||||
mmfile_t base = {NULL, 0}, other = {NULL, 0};
|
||||
|
||||
if (read_mmfile(&base, rerere_path(id, "preimage")) ||
|
||||
read_mmfile(&other, rerere_path(id, "postimage")))
|
||||
ret = 1;
|
||||
else
|
||||
/*
|
||||
* A three-way merge. Note that this honors user-customizable
|
||||
* low-level merge driver settings.
|
||||
*/
|
||||
ret = ll_merge(result, path, &base, NULL, cur, "", &other, "", NULL);
|
||||
|
||||
free(base.ptr);
|
||||
free(other.ptr);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
/*
|
||||
* Find the conflict identified by "id"; the change between its
|
||||
* "preimage" (i.e. a previous contents with conflict markers) and its
|
||||
|
@ -635,30 +662,20 @@ static int merge(const struct rerere_id *id, const char *path)
|
|||
{
|
||||
FILE *f;
|
||||
int ret;
|
||||
mmfile_t cur = {NULL, 0}, base = {NULL, 0}, other = {NULL, 0};
|
||||
mmfile_t cur = {NULL, 0};
|
||||
mmbuffer_t result = {NULL, 0};
|
||||
|
||||
/*
|
||||
* Normalize the conflicts in path and write it out to
|
||||
* "thisimage" temporary file.
|
||||
*/
|
||||
if (handle_file(path, NULL, rerere_path(id, "thisimage")) < 0) {
|
||||
if ((handle_file(path, NULL, rerere_path(id, "thisimage")) < 0) ||
|
||||
read_mmfile(&cur, rerere_path(id, "thisimage"))) {
|
||||
ret = 1;
|
||||
goto out;
|
||||
}
|
||||
|
||||
if (read_mmfile(&cur, rerere_path(id, "thisimage")) ||
|
||||
read_mmfile(&base, rerere_path(id, "preimage")) ||
|
||||
read_mmfile(&other, rerere_path(id, "postimage"))) {
|
||||
ret = 1;
|
||||
goto out;
|
||||
}
|
||||
|
||||
/*
|
||||
* A three-way merge. Note that this honors user-customizable
|
||||
* low-level merge driver settings.
|
||||
*/
|
||||
ret = ll_merge(&result, path, &base, NULL, &cur, "", &other, "", NULL);
|
||||
ret = try_merge(id, path, &cur, &result);
|
||||
if (ret)
|
||||
goto out;
|
||||
|
||||
|
@ -684,8 +701,6 @@ static int merge(const struct rerere_id *id, const char *path)
|
|||
|
||||
out:
|
||||
free(cur.ptr);
|
||||
free(base.ptr);
|
||||
free(other.ptr);
|
||||
free(result.ptr);
|
||||
|
||||
return ret;
|
||||
|
|
Загрузка…
Ссылка в новой задаче