| /* |
| * 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 <base>... -- HEAD <remote>..."; |
| |
| 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; |
| } |