summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorEdward Thomson <ethomson@microsoft.com>2015-06-22 18:43:13 -0400
committerEdward Thomson <ethomson@microsoft.com>2015-06-23 16:48:46 -0400
commit83ba5e3654631eb186c8b820def459b0680509df (patch)
treedbd1c98c1aaca47b2ed0cfede7e97905f1521677 /src
parent0c34fa5094ba624ebe398d1b154fd27c207108cb (diff)
downloadlibgit2-83ba5e3654631eb186c8b820def459b0680509df.tar.gz
diff_tform: remove reversed copy of delta merger
Drop `git_diff__merge_like_cgit_reversed`, since it's a copy and paste mess of slightly incompatible changes.
Diffstat (limited to 'src')
-rw-r--r--src/diff_tform.c53
1 files changed, 7 insertions, 46 deletions
diff --git a/src/diff_tform.c b/src/diff_tform.c
index 041592fbf..cc809c159 100644
--- a/src/diff_tform.c
+++ b/src/diff_tform.c
@@ -80,10 +80,11 @@ static git_diff_delta *diff_delta__merge_like_cgit(
return NULL;
/* If 'a' status is uninteresting, then we're done */
- if (a->status == GIT_DELTA_UNMODIFIED)
+ if (a->status == GIT_DELTA_UNMODIFIED ||
+ a->status == GIT_DELTA_UNTRACKED ||
+ a->status == GIT_DELTA_UNREADABLE)
return dup;
- assert(a->status != GIT_DELTA_UNMODIFIED);
assert(b->status != GIT_DELTA_UNMODIFIED);
/* A cgit exception is that the diff of a file that is only in the
@@ -108,47 +109,6 @@ static git_diff_delta *diff_delta__merge_like_cgit(
return dup;
}
-static git_diff_delta *diff_delta__merge_like_cgit_reversed(
- const git_diff_delta *a,
- const git_diff_delta *b,
- git_pool *pool)
-{
- git_diff_delta *dup;
-
- /* reversed version of above logic */
-
- if (a->status == GIT_DELTA_CONFLICTED)
- return diff_delta__dup(a, pool);
- if (b->status == GIT_DELTA_CONFLICTED)
- return diff_delta__dup(b, pool);
-
- if (a->status == GIT_DELTA_UNMODIFIED)
- return diff_delta__dup(b, pool);
-
- if ((dup = diff_delta__dup(a, pool)) == NULL)
- return NULL;
-
- if (b->status == GIT_DELTA_UNMODIFIED || b->status == GIT_DELTA_UNTRACKED || b->status == GIT_DELTA_UNREADABLE)
- return dup;
-
- if (dup->status == GIT_DELTA_DELETED) {
- if (b->status == GIT_DELTA_ADDED) {
- dup->status = GIT_DELTA_UNMODIFIED;
- dup->nfiles = 2;
- }
- } else {
- dup->status = b->status;
- dup->nfiles = b->nfiles;
- }
-
- git_oid_cpy(&dup->old_file.id, &b->old_file.id);
- dup->old_file.mode = b->old_file.mode;
- dup->old_file.size = b->old_file.size;
- dup->old_file.flags = b->old_file.flags;
-
- return dup;
-}
-
int git_diff_merge(git_diff *onto, const git_diff *from)
{
int error = 0;
@@ -191,9 +151,10 @@ int git_diff_merge(git_diff *onto, const git_diff *from)
delta = diff_delta__dup(f, &onto_pool);
j++;
} else {
- delta = reversed ?
- diff_delta__merge_like_cgit_reversed(o, f, &onto_pool) :
- diff_delta__merge_like_cgit(o, f, &onto_pool);
+ const git_diff_delta *left = reversed ? f : o;
+ const git_diff_delta *right = reversed ? o : f;
+
+ delta = diff_delta__merge_like_cgit(left, right, &onto_pool);
i++;
j++;
}