Unverified Commit aded938e by Edward Thomson Committed by GitHub

Merge pull request #6204 from boretrk/merge_flags

merge: fix overlap between GIT_MERGE_FILE_FAVOR__CONFLICTED and GIT_MERGE_FILE_SIMPLIFY_ALNUM
parents d99b4019 0fbf62cd
...@@ -91,7 +91,15 @@ typedef enum { ...@@ -91,7 +91,15 @@ typedef enum {
* instead simply use the first base. This flag provides a similar * instead simply use the first base. This flag provides a similar
* merge base to `git-merge-resolve`. * merge base to `git-merge-resolve`.
*/ */
GIT_MERGE_NO_RECURSIVE = (1 << 3) GIT_MERGE_NO_RECURSIVE = (1 << 3),
/**
* Treat this merge as if it is to produce the virtual base
* of a recursive merge. This will ensure that there are
* no conflicts, any conflicting regions will keep conflict
* markers in the merge result.
*/
GIT_MERGE_VIRTUAL_BASE = (1 << 4)
} git_merge_flag_t; } git_merge_flag_t;
/** /**
...@@ -162,7 +170,14 @@ typedef enum { ...@@ -162,7 +170,14 @@ typedef enum {
GIT_MERGE_FILE_DIFF_MINIMAL = (1 << 7), GIT_MERGE_FILE_DIFF_MINIMAL = (1 << 7),
/** Create zdiff3 ("zealous diff3")-style files */ /** Create zdiff3 ("zealous diff3")-style files */
GIT_MERGE_FILE_STYLE_ZDIFF3 = (1 << 8) GIT_MERGE_FILE_STYLE_ZDIFF3 = (1 << 8),
/**
* Do not produce file conflicts when common regions have
* changed; keep the conflict markers in the file and accept
* that as the merge result.
*/
GIT_MERGE_FILE_ACCEPT_CONFLICTS = (1 << 9)
} git_merge_file_flag_t; } git_merge_file_flag_t;
#define GIT_MERGE_CONFLICT_MARKER_SIZE 7 #define GIT_MERGE_CONFLICT_MARKER_SIZE 7
......
...@@ -2116,11 +2116,11 @@ int git_merge__iterators( ...@@ -2116,11 +2116,11 @@ int git_merge__iterators(
file_opts.flags = opts.file_flags; file_opts.flags = opts.file_flags;
/* use the git-inspired labels when virtual base building */ /* use the git-inspired labels when virtual base building */
if (opts.flags & GIT_MERGE__VIRTUAL_BASE) { if (opts.flags & GIT_MERGE_VIRTUAL_BASE) {
file_opts.ancestor_label = "merged common ancestors"; file_opts.ancestor_label = "merged common ancestors";
file_opts.our_label = "Temporary merge branch 1"; file_opts.our_label = "Temporary merge branch 1";
file_opts.their_label = "Temporary merge branch 2"; file_opts.their_label = "Temporary merge branch 2";
file_opts.flags |= GIT_MERGE_FILE_FAVOR__CONFLICTED; file_opts.flags |= GIT_MERGE_FILE_ACCEPT_CONFLICTS;
file_opts.marker_size = GIT_MERGE_CONFLICT_MARKER_SIZE + 2; file_opts.marker_size = GIT_MERGE_CONFLICT_MARKER_SIZE + 2;
} }
...@@ -2280,7 +2280,7 @@ static int create_virtual_base( ...@@ -2280,7 +2280,7 @@ static int create_virtual_base(
memcpy(&virtual_opts, opts, sizeof(git_merge_options)); memcpy(&virtual_opts, opts, sizeof(git_merge_options));
virtual_opts.flags &= ~GIT_MERGE_FAIL_ON_CONFLICT; virtual_opts.flags &= ~GIT_MERGE_FAIL_ON_CONFLICT;
virtual_opts.flags |= GIT_MERGE__VIRTUAL_BASE; virtual_opts.flags |= GIT_MERGE_VIRTUAL_BASE;
if ((merge_annotated_commits(&index, NULL, repo, one, two, if ((merge_annotated_commits(&index, NULL, repo, one, two,
recursion_level + 1, &virtual_opts)) < 0) recursion_level + 1, &virtual_opts)) < 0)
......
...@@ -25,19 +25,6 @@ ...@@ -25,19 +25,6 @@
#define GIT_MERGE_DEFAULT_RENAME_THRESHOLD 50 #define GIT_MERGE_DEFAULT_RENAME_THRESHOLD 50
#define GIT_MERGE_DEFAULT_TARGET_LIMIT 1000 #define GIT_MERGE_DEFAULT_TARGET_LIMIT 1000
/** Internal merge flags. */
enum {
/** The merge is for a virtual base in a recursive merge. */
GIT_MERGE__VIRTUAL_BASE = (1 << 31)
};
enum {
/** Accept the conflict file, staging it as the merge result. */
GIT_MERGE_FILE_FAVOR__CONFLICTED = 4
};
/** Types of changes when files are merged from branch to branch. */ /** Types of changes when files are merged from branch to branch. */
typedef enum { typedef enum {
/* No conflict - a change only occurs in one branch. */ /* No conflict - a change only occurs in one branch. */
......
...@@ -93,7 +93,7 @@ int git_merge_driver__builtin_apply( ...@@ -93,7 +93,7 @@ int git_merge_driver__builtin_apply(
goto done; goto done;
if (!result.automergeable && if (!result.automergeable &&
!(file_opts.flags & GIT_MERGE_FILE_FAVOR__CONFLICTED)) { !(file_opts.flags & GIT_MERGE_FILE_ACCEPT_CONFLICTS)) {
error = GIT_EMERGECONFLICT; error = GIT_EMERGECONFLICT;
goto done; goto done;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment