/* * Implementation of git-merge-ours.sh as builtin * * Copyright (c) 2007 Thomas Harning Jr * Original: * Original Copyright (c) 2005 Junio C Hamano * * Pretend we resolved the heads, but declare our tree trumps everybody else. */ #include "git-compat-util.h" #include "builtin.h" #include "config.h" #include "environment.h" #include "diff.h" static const char builtin_merge_ours_usage[] = "git merge-ours ... -- HEAD ..."; int cmd_merge_ours(int argc, const char **argv, const char *prefix UNUSED, struct repository *repo) { show_usage_if_asked(argc, argv, builtin_merge_ours_usage); repo_config(repo, git_default_config, NULL); prepare_repo_settings(repo); repo->settings.command_requires_full_index = 0; /* * The contents of the current index becomes the tree we * commit. The index must match HEAD, or this merge cannot go * through. */ if (repo_read_index(repo) < 0) die_errno("read_cache failed"); if (index_differs_from(repo, "HEAD", NULL, 0)) return 2; return 0; }