summaryrefslogtreecommitdiff
path: root/src/merge.c
diff options
context:
space:
mode:
authorJacques Germishuys <jacquesg@striata.com>2014-04-07 20:15:45 +0200
committerJacques Germishuys <jacquesg@striata.com>2014-04-14 16:16:21 +0200
commit399f2b6294963b8a7a154ffd0103484d018c4e27 (patch)
treea63dd0e0e78ba4a636959082e40beccb1a9af592 /src/merge.c
parent553184a76245617556373af4cb5343e7fe58f41f (diff)
downloadlibgit2-399f2b6294963b8a7a154ffd0103484d018c4e27.tar.gz
Introduce git_merge__extract_conflict_paths
Diffstat (limited to 'src/merge.c')
-rw-r--r--src/merge.c41
1 files changed, 41 insertions, 0 deletions
diff --git a/src/merge.c b/src/merge.c
index dd6a39f37..371fad776 100644
--- a/src/merge.c
+++ b/src/merge.c
@@ -2469,6 +2469,47 @@ done:
return error;
}
+int git_merge__append_conflicts_to_merge_msg(
+ git_repository *repo,
+ git_index *index)
+{
+ git_filebuf file = GIT_FILEBUF_INIT;
+ git_buf file_path = GIT_BUF_INIT;
+ const char *last = NULL;
+ size_t i;
+ int error;
+
+ if ((error = git_buf_joinpath(&file_path, repo->path_repository, GIT_MERGE_MSG_FILE)) < 0 ||
+ (error = git_filebuf_open(&file, file_path.ptr, GIT_FILEBUF_APPEND, GIT_MERGE_FILE_MODE)) < 0)
+ goto cleanup;
+
+ if (git_index_has_conflicts(index))
+ git_filebuf_printf(&file, "\nConflicts:\n");
+
+ for (i = 0; i < git_index_entrycount(index); i++) {
+ const git_index_entry *e = git_index_get_byindex(index, i);
+
+ if (git_index_entry_stage(e) == 0)
+ continue;
+
+ if (last == NULL || strcmp(e->path, last) != 0)
+ git_filebuf_printf(&file, "\t%s\n", e->path);
+
+ last = e->path;
+ }
+
+ error = git_filebuf_commit(&file);
+
+cleanup:
+ if (error < 0)
+ git_filebuf_cleanup(&file);
+
+ git_buf_free(&file_path);
+
+ return error;
+}
+
+
static int merge_state_cleanup(git_repository *repo)
{
const char *state_files[] = {