Blame src/merge_driver.h

Packit ae9e2a
/*
Packit ae9e2a
 * Copyright (C) the libgit2 contributors. All rights reserved.
Packit ae9e2a
 *
Packit ae9e2a
 * This file is part of libgit2, distributed under the GNU GPL v2 with
Packit ae9e2a
 * a Linking Exception. For full terms see the included COPYING file.
Packit ae9e2a
 */
Packit ae9e2a
#ifndef INCLUDE_merge_driver_h__
Packit ae9e2a
#define INCLUDE_merge_driver_h__
Packit ae9e2a
Packit ae9e2a
#include "git2/merge.h"
Packit ae9e2a
#include "git2/index.h"
Packit ae9e2a
#include "git2/sys/merge.h"
Packit ae9e2a
Packit ae9e2a
struct git_merge_driver_source {
Packit ae9e2a
	git_repository *repo;
Packit ae9e2a
	const char *default_driver;
Packit ae9e2a
	const git_merge_file_options *file_opts;
Packit ae9e2a
Packit ae9e2a
	const git_index_entry *ancestor;
Packit ae9e2a
	const git_index_entry *ours;
Packit ae9e2a
	const git_index_entry *theirs;
Packit ae9e2a
};
Packit ae9e2a
Packit ae9e2a
typedef struct git_merge_driver__builtin {
Packit ae9e2a
	git_merge_driver base;
Packit ae9e2a
	git_merge_file_favor_t favor;
Packit ae9e2a
} git_merge_driver__builtin;
Packit ae9e2a
Packit ae9e2a
extern int git_merge_driver_global_init(void);
Packit ae9e2a
Packit ae9e2a
extern int git_merge_driver_for_path(
Packit ae9e2a
	char **name_out,
Packit ae9e2a
	git_merge_driver **driver_out,
Packit ae9e2a
	git_repository *repo,
Packit ae9e2a
	const char *path);
Packit ae9e2a
Packit ae9e2a
/* Merge driver configuration */
Packit ae9e2a
extern int git_merge_driver_for_source(
Packit ae9e2a
	const char **name_out,
Packit ae9e2a
	git_merge_driver **driver_out,
Packit ae9e2a
	const git_merge_driver_source *src);
Packit ae9e2a
Packit ae9e2a
extern int git_merge_driver__builtin_apply(
Packit ae9e2a
	git_merge_driver *self,
Packit ae9e2a
	const char **path_out,
Packit ae9e2a
	uint32_t *mode_out,
Packit ae9e2a
	git_buf *merged_out,
Packit ae9e2a
	const char *filter_name,
Packit ae9e2a
	const git_merge_driver_source *src);
Packit ae9e2a
Packit ae9e2a
/* Merge driver for text files, performs a standard three-way merge */
Packit ae9e2a
extern git_merge_driver__builtin git_merge_driver__text;
Packit ae9e2a
Packit ae9e2a
/* Merge driver for union-style merging */
Packit ae9e2a
extern git_merge_driver__builtin git_merge_driver__union;
Packit ae9e2a
Packit ae9e2a
/* Merge driver for unmergeable (binary) files: always produces conflicts */
Packit ae9e2a
extern git_merge_driver git_merge_driver__binary;
Packit ae9e2a
Packit ae9e2a
#endif