builtin-checkout.c 20.4 KB
Newer Older
D
Daniel Barkalow 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14
#include "cache.h"
#include "builtin.h"
#include "parse-options.h"
#include "refs.h"
#include "commit.h"
#include "tree.h"
#include "tree-walk.h"
#include "unpack-trees.h"
#include "dir.h"
#include "run-command.h"
#include "merge-recursive.h"
#include "branch.h"
#include "diff.h"
#include "revision.h"
15
#include "remote.h"
16 17 18
#include "blob.h"
#include "xdiff-interface.h"
#include "ll-merge.h"
D
Daniel Barkalow 已提交
19 20 21 22 23 24 25

static const char * const checkout_usage[] = {
	"git checkout [options] <branch>",
	"git checkout [options] [<branch>] -- <file>...",
	NULL,
};

26 27 28 29
struct checkout_opts {
	int quiet;
	int merge;
	int force;
30
	int writeout_stage;
31 32 33 34 35 36 37
	int writeout_error;

	const char *new_branch;
	int new_branch_log;
	enum branch_track track;
};

D
Daniel Barkalow 已提交
38 39 40
static int post_checkout_hook(struct commit *old, struct commit *new,
			      int changed)
{
41 42 43 44
	return run_hook(NULL, "post-checkout",
			sha1_to_hex(old ? old->object.sha1 : null_sha1),
			sha1_to_hex(new ? new->object.sha1 : null_sha1),
			changed ? "1" : "0", NULL);
45 46
	/* "new" can be NULL when checking out from the index before
	   a commit exists. */
47

D
Daniel Barkalow 已提交
48 49 50
}

static int update_some(const unsigned char *sha1, const char *base, int baselen,
51
		const char *pathname, unsigned mode, int stage, void *context)
D
Daniel Barkalow 已提交
52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
{
	int len;
	struct cache_entry *ce;

	if (S_ISDIR(mode))
		return READ_TREE_RECURSIVE;

	len = baselen + strlen(pathname);
	ce = xcalloc(1, cache_entry_size(len));
	hashcpy(ce->sha1, sha1);
	memcpy(ce->name, base, baselen);
	memcpy(ce->name + baselen, pathname, len - baselen);
	ce->ce_flags = create_ce_flags(len, 0);
	ce->ce_mode = create_ce_mode(mode);
	add_cache_entry(ce, ADD_CACHE_OK_TO_ADD | ADD_CACHE_OK_TO_REPLACE);
	return 0;
}

static int read_tree_some(struct tree *tree, const char **pathspec)
{
72
	read_tree_recursive(tree, "", 0, 0, pathspec, update_some, NULL);
D
Daniel Barkalow 已提交
73 74 75 76 77 78 79 80

	/* update the index with the given tree's info
	 * for all args, expanding wildcards, and exit
	 * with any non-zero return code.
	 */
	return 0;
}

81 82 83 84 85 86 87 88
static int skip_same_name(struct cache_entry *ce, int pos)
{
	while (++pos < active_nr &&
	       !strcmp(active_cache[pos]->name, ce->name))
		; /* skip */
	return pos;
}

89 90 91 92 93 94 95 96 97 98 99 100 101
static int check_stage(int stage, struct cache_entry *ce, int pos)
{
	while (pos < active_nr &&
	       !strcmp(active_cache[pos]->name, ce->name)) {
		if (ce_stage(active_cache[pos]) == stage)
			return 0;
		pos++;
	}
	return error("path '%s' does not have %s version",
		     ce->name,
		     (stage == 2) ? "our" : "their");
}

102 103 104 105 106 107 108 109 110 111 112 113 114
static int check_all_stages(struct cache_entry *ce, int pos)
{
	if (ce_stage(ce) != 1 ||
	    active_nr <= pos + 2 ||
	    strcmp(active_cache[pos+1]->name, ce->name) ||
	    ce_stage(active_cache[pos+1]) != 2 ||
	    strcmp(active_cache[pos+2]->name, ce->name) ||
	    ce_stage(active_cache[pos+2]) != 3)
		return error("path '%s' does not have all three versions",
			     ce->name);
	return 0;
}

115 116 117 118 119 120 121 122 123 124 125 126 127
static int checkout_stage(int stage, struct cache_entry *ce, int pos,
			  struct checkout *state)
{
	while (pos < active_nr &&
	       !strcmp(active_cache[pos]->name, ce->name)) {
		if (ce_stage(active_cache[pos]) == stage)
			return checkout_entry(active_cache[pos], state, NULL);
		pos++;
	}
	return error("path '%s' does not have %s version",
		     ce->name,
		     (stage == 2) ? "our" : "their");
}
128

129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195
/* NEEDSWORK: share with merge-recursive */
static void fill_mm(const unsigned char *sha1, mmfile_t *mm)
{
	unsigned long size;
	enum object_type type;

	if (!hashcmp(sha1, null_sha1)) {
		mm->ptr = xstrdup("");
		mm->size = 0;
		return;
	}

	mm->ptr = read_sha1_file(sha1, &type, &size);
	if (!mm->ptr || type != OBJ_BLOB)
		die("unable to read blob object %s", sha1_to_hex(sha1));
	mm->size = size;
}

static int checkout_merged(int pos, struct checkout *state)
{
	struct cache_entry *ce = active_cache[pos];
	const char *path = ce->name;
	mmfile_t ancestor, ours, theirs;
	int status;
	unsigned char sha1[20];
	mmbuffer_t result_buf;

	if (ce_stage(ce) != 1 ||
	    active_nr <= pos + 2 ||
	    strcmp(active_cache[pos+1]->name, path) ||
	    ce_stage(active_cache[pos+1]) != 2 ||
	    strcmp(active_cache[pos+2]->name, path) ||
	    ce_stage(active_cache[pos+2]) != 3)
		return error("path '%s' does not have all 3 versions", path);

	fill_mm(active_cache[pos]->sha1, &ancestor);
	fill_mm(active_cache[pos+1]->sha1, &ours);
	fill_mm(active_cache[pos+2]->sha1, &theirs);

	status = ll_merge(&result_buf, path, &ancestor,
			  &ours, "ours", &theirs, "theirs", 1);
	free(ancestor.ptr);
	free(ours.ptr);
	free(theirs.ptr);
	if (status < 0 || !result_buf.ptr) {
		free(result_buf.ptr);
		return error("path '%s': cannot merge", path);
	}

	/*
	 * NEEDSWORK:
	 * There is absolutely no reason to write this as a blob object
	 * and create a phoney cache entry just to leak.  This hack is
	 * primarily to get to the write_entry() machinery that massages
	 * the contents to work-tree format and writes out which only
	 * allows it for a cache entry.  The code in write_entry() needs
	 * to be refactored to allow us to feed a <buffer, size, mode>
	 * instead of a cache entry.  Such a refactoring would help
	 * merge_recursive as well (it also writes the merge result to the
	 * object database even when it may contain conflicts).
	 */
	if (write_sha1_file(result_buf.ptr, result_buf.size,
			    blob_type, sha1))
		die("Unable to add merge result for '%s'", path);
	ce = make_cache_entry(create_ce_mode(active_cache[pos+1]->ce_mode),
			      sha1,
			      path, 2, 0);
196 197
	if (!ce)
		die("make_cache_entry failed for path '%s'", path);
198 199 200
	status = checkout_entry(ce, state, NULL);
	return status;
}
201

202 203
static int checkout_paths(struct tree *source_tree, const char **pathspec,
			  struct checkout_opts *opts)
D
Daniel Barkalow 已提交
204 205 206 207 208 209 210
{
	int pos;
	struct checkout state;
	static char *ps_matched;
	unsigned char rev[20];
	int flag;
	struct commit *head;
211
	int errs = 0;
212
	int stage = opts->writeout_stage;
213
	int merge = opts->merge;
214 215 216 217
	int newfd;
	struct lock_file *lock_file = xcalloc(1, sizeof(struct lock_file));

	newfd = hold_locked_index(lock_file, 1);
218 219
	if (read_cache() < 0)
		return error("corrupt index file");
220 221 222 223

	if (source_tree)
		read_tree_some(source_tree, pathspec);

D
Daniel Barkalow 已提交
224 225 226 227 228 229
	for (pos = 0; pathspec[pos]; pos++)
		;
	ps_matched = xcalloc(1, pos);

	for (pos = 0; pos < active_nr; pos++) {
		struct cache_entry *ce = active_cache[pos];
230
		match_pathspec(pathspec, ce->name, ce_namelen(ce), 0, ps_matched);
D
Daniel Barkalow 已提交
231 232 233 234 235
	}

	if (report_path_error(ps_matched, pathspec, 0))
		return 1;

236 237 238
	/* Any unmerged paths? */
	for (pos = 0; pos < active_nr; pos++) {
		struct cache_entry *ce = active_cache[pos];
239
		if (match_pathspec(pathspec, ce->name, ce_namelen(ce), 0, NULL)) {
240 241
			if (!ce_stage(ce))
				continue;
242 243
			if (opts->force) {
				warning("path '%s' is unmerged", ce->name);
244 245
			} else if (stage) {
				errs |= check_stage(stage, ce, pos);
246 247
			} else if (opts->merge) {
				errs |= check_all_stages(ce, pos);
248 249 250 251
			} else {
				errs = 1;
				error("path '%s' is unmerged", ce->name);
			}
252 253 254 255 256 257
			pos = skip_same_name(ce, pos) - 1;
		}
	}
	if (errs)
		return 1;

258
	/* Now we are committed to check them out */
D
Daniel Barkalow 已提交
259 260 261 262 263
	memset(&state, 0, sizeof(state));
	state.force = 1;
	state.refresh_cache = 1;
	for (pos = 0; pos < active_nr; pos++) {
		struct cache_entry *ce = active_cache[pos];
264
		if (match_pathspec(pathspec, ce->name, ce_namelen(ce), 0, NULL)) {
265 266 267 268
			if (!ce_stage(ce)) {
				errs |= checkout_entry(ce, &state, NULL);
				continue;
			}
269 270
			if (stage)
				errs |= checkout_stage(stage, ce, pos, &state);
271 272
			else if (merge)
				errs |= checkout_merged(pos, &state);
273
			pos = skip_same_name(ce, pos) - 1;
D
Daniel Barkalow 已提交
274 275 276
		}
	}

277 278 279 280
	if (write_cache(newfd, active_cache, active_nr) ||
	    commit_locked_index(lock_file))
		die("unable to write new index file");

D
Daniel Barkalow 已提交
281 282 283
	resolve_ref("HEAD", rev, 0, &flag);
	head = lookup_commit_reference_gently(rev, 1);

284 285
	errs |= post_checkout_hook(head, head, 0);
	return errs;
D
Daniel Barkalow 已提交
286 287 288 289 290 291 292 293 294 295 296 297 298 299 300
}

static void show_local_changes(struct object *head)
{
	struct rev_info rev;
	/* I think we want full paths, even if we're in a subdirectory. */
	init_revisions(&rev, NULL);
	rev.abbrev = 0;
	rev.diffopt.output_format |= DIFF_FORMAT_NAME_STATUS;
	add_pending_object(&rev, head, NULL);
	run_diff_index(&rev, 0);
}

static void describe_detached_head(char *msg, struct commit *commit)
{
301
	struct strbuf sb = STRBUF_INIT;
D
Daniel Barkalow 已提交
302
	parse_commit(commit);
303
	pretty_print_commit(CMIT_FMT_ONELINE, commit, &sb, 0, NULL, NULL, 0, 0);
D
Daniel Barkalow 已提交
304 305 306 307 308
	fprintf(stderr, "%s %s... %s\n", msg,
		find_unique_abbrev(commit->object.sha1, DEFAULT_ABBREV), sb.buf);
	strbuf_release(&sb);
}

309
static int reset_tree(struct tree *tree, struct checkout_opts *o, int worktree)
D
Daniel Barkalow 已提交
310 311 312
{
	struct unpack_trees_options opts;
	struct tree_desc tree_desc;
313

D
Daniel Barkalow 已提交
314 315
	memset(&opts, 0, sizeof(opts));
	opts.head_idx = -1;
316 317
	opts.update = worktree;
	opts.skip_unmerged = !worktree;
D
Daniel Barkalow 已提交
318 319 320
	opts.reset = 1;
	opts.merge = 1;
	opts.fn = oneway_merge;
321
	opts.verbose_update = !o->quiet;
322 323
	opts.src_index = &the_index;
	opts.dst_index = &the_index;
D
Daniel Barkalow 已提交
324 325
	parse_tree(tree);
	init_tree_desc(&tree_desc, tree->buffer, tree->size);
326 327 328 329 330 331 332 333 334 335 336 337
	switch (unpack_trees(1, &tree_desc, &opts)) {
	case -2:
		o->writeout_error = 1;
		/*
		 * We return 0 nevertheless, as the index is all right
		 * and more importantly we have made best efforts to
		 * update paths in the work tree, and we cannot revert
		 * them.
		 */
	case 0:
		return 0;
	default:
338
		return 128;
339
	}
D
Daniel Barkalow 已提交
340 341 342 343 344 345 346 347 348 349
}

struct branch_info {
	const char *name; /* The short name used */
	const char *path; /* The full name of a real branch */
	struct commit *commit; /* The named commit */
};

static void setup_branch_path(struct branch_info *branch)
{
350
	struct strbuf buf = STRBUF_INIT;
T
Thomas Rast 已提交
351
	int ret;
352

T
Thomas Rast 已提交
353 354
	if ((ret = interpret_nth_last_branch(branch->name, &buf))
	    && ret == strlen(branch->name)) {
355 356 357 358 359 360
		branch->name = xstrdup(buf.buf);
		strbuf_splice(&buf, 0, 0, "refs/heads/", 11);
	} else {
		strbuf_addstr(&buf, "refs/heads/");
		strbuf_addstr(&buf, branch->name);
	}
D
Daniel Barkalow 已提交
361 362 363 364
	branch->path = strbuf_detach(&buf, NULL);
}

static int merge_working_tree(struct checkout_opts *opts,
365
			      struct branch_info *old, struct branch_info *new)
D
Daniel Barkalow 已提交
366 367 368 369
{
	int ret;
	struct lock_file *lock_file = xcalloc(1, sizeof(struct lock_file));
	int newfd = hold_locked_index(lock_file, 1);
370 371 372

	if (read_cache() < 0)
		return error("corrupt index file");
D
Daniel Barkalow 已提交
373 374

	if (opts->force) {
375
		ret = reset_tree(new->commit->tree, opts, 1);
D
Daniel Barkalow 已提交
376 377 378 379 380 381
		if (ret)
			return ret;
	} else {
		struct tree_desc trees[2];
		struct tree *tree;
		struct unpack_trees_options topts;
382

D
Daniel Barkalow 已提交
383 384
		memset(&topts, 0, sizeof(topts));
		topts.head_idx = -1;
385 386
		topts.src_index = &the_index;
		topts.dst_index = &the_index;
D
Daniel Barkalow 已提交
387

388 389
		topts.msgs.not_uptodate_file = "You have local changes to '%s'; cannot switch branches.";

D
Daniel Barkalow 已提交
390 391 392
		refresh_cache(REFRESH_QUIET);

		if (unmerged_cache()) {
393 394
			error("you need to resolve your current index first");
			return 1;
D
Daniel Barkalow 已提交
395
		}
396 397

		/* 2-way merge to the new branch */
398
		topts.initial_checkout = is_cache_unborn();
399 400 401 402 403 404 405 406 407 408 409 410 411
		topts.update = 1;
		topts.merge = 1;
		topts.gently = opts->merge;
		topts.verbose_update = !opts->quiet;
		topts.fn = twoway_merge;
		topts.dir = xcalloc(1, sizeof(*topts.dir));
		topts.dir->show_ignored = 1;
		topts.dir->exclude_per_dir = ".gitignore";
		tree = parse_tree_indirect(old->commit->object.sha1);
		init_tree_desc(&trees[0], tree->buffer, tree->size);
		tree = parse_tree_indirect(new->commit->object.sha1);
		init_tree_desc(&trees[1], tree->buffer, tree->size);

412 413
		ret = unpack_trees(2, trees, &topts);
		if (ret == -1) {
D
Daniel Barkalow 已提交
414 415 416 417 418 419 420
			/*
			 * Unpack couldn't do a trivial merge; either
			 * give up or do a real merge, depending on
			 * whether the merge flag was used.
			 */
			struct tree *result;
			struct tree *work;
421
			struct merge_options o;
D
Daniel Barkalow 已提交
422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438
			if (!opts->merge)
				return 1;
			parse_commit(old->commit);

			/* Do more real merge */

			/*
			 * We update the index fully, then write the
			 * tree from the index, then merge the new
			 * branch with the current tree, with the old
			 * branch as the base. Then we reset the index
			 * (but not the working tree) to the new
			 * branch, leaving the working tree as the
			 * merged version, but skipping unmerged
			 * entries in the index.
			 */

439
			add_files_to_cache(NULL, NULL, 0);
440 441 442
			init_merge_options(&o);
			o.verbosity = 0;
			work = write_tree_from_memory(&o);
D
Daniel Barkalow 已提交
443

444
			ret = reset_tree(new->commit->tree, opts, 1);
D
Daniel Barkalow 已提交
445 446
			if (ret)
				return ret;
447 448 449 450
			o.branch1 = new->name;
			o.branch2 = "local";
			merge_trees(&o, new->commit->tree, work,
				old->commit->tree, &result);
451
			ret = reset_tree(new->commit->tree, opts, 0);
452 453
			if (ret)
				return ret;
D
Daniel Barkalow 已提交
454 455 456 457 458 459 460
		}
	}

	if (write_cache(newfd, active_cache, active_nr) ||
	    commit_locked_index(lock_file))
		die("unable to write new index file");

461
	if (!opts->force && !opts->quiet)
D
Daniel Barkalow 已提交
462 463 464 465 466
		show_local_changes(&new->commit->object);

	return 0;
}

467
static void report_tracking(struct branch_info *new)
468
{
469
	struct strbuf sb = STRBUF_INIT;
470
	struct branch *branch = branch_get(new->name);
471

472
	if (!format_tracking_info(branch, &sb))
473
		return;
474 475
	fputs(sb.buf, stdout);
	strbuf_release(&sb);
476
}
477

D
Daniel Barkalow 已提交
478 479 480 481
static void update_refs_for_switch(struct checkout_opts *opts,
				   struct branch_info *old,
				   struct branch_info *new)
{
482
	struct strbuf msg = STRBUF_INIT;
D
Daniel Barkalow 已提交
483 484 485 486 487 488 489 490 491
	const char *old_desc;
	if (opts->new_branch) {
		create_branch(old->name, opts->new_branch, new->name, 0,
			      opts->new_branch_log, opts->track);
		new->name = opts->new_branch;
		setup_branch_path(new);
	}

	old_desc = old->name;
492
	if (!old_desc && old->commit)
D
Daniel Barkalow 已提交
493 494
		old_desc = sha1_to_hex(old->commit->object.sha1);
	strbuf_addf(&msg, "checkout: moving from %s to %s",
495
		    old_desc ? old_desc : "(invalid)", new->name);
D
Daniel Barkalow 已提交
496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518

	if (new->path) {
		create_symref("HEAD", new->path, msg.buf);
		if (!opts->quiet) {
			if (old->path && !strcmp(new->path, old->path))
				fprintf(stderr, "Already on \"%s\"\n",
					new->name);
			else
				fprintf(stderr, "Switched to%s branch \"%s\"\n",
					opts->new_branch ? " a new" : "",
					new->name);
		}
	} else if (strcmp(new->name, "HEAD")) {
		update_ref(msg.buf, "HEAD", new->commit->object.sha1, NULL,
			   REF_NODEREF, DIE_ON_ERR);
		if (!opts->quiet) {
			if (old->path)
				fprintf(stderr, "Note: moving to \"%s\" which isn't a local branch\nIf you want to create a new branch from this checkout, you may do so\n(now or later) by using -b with the checkout command again. Example:\n  git checkout -b <new_branch_name>\n", new->name);
			describe_detached_head("HEAD is now at", new->commit);
		}
	}
	remove_branch_state();
	strbuf_release(&msg);
519
	if (!opts->quiet && (new->path || !strcmp(new->name, "HEAD")))
520
		report_tracking(new);
D
Daniel Barkalow 已提交
521 522
}

523
static int switch_branches(struct checkout_opts *opts, struct branch_info *new)
D
Daniel Barkalow 已提交
524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546
{
	int ret = 0;
	struct branch_info old;
	unsigned char rev[20];
	int flag;
	memset(&old, 0, sizeof(old));
	old.path = resolve_ref("HEAD", rev, 0, &flag);
	old.commit = lookup_commit_reference_gently(rev, 1);
	if (!(flag & REF_ISSYMREF))
		old.path = NULL;

	if (old.path && !prefixcmp(old.path, "refs/heads/"))
		old.name = old.path + strlen("refs/heads/");

	if (!new->name) {
		new->name = "HEAD";
		new->commit = old.commit;
		if (!new->commit)
			die("You are on a branch yet to be born");
		parse_commit(new->commit);
	}

	/*
547 548 549
	 * If we were on a detached HEAD, but we are now moving to
	 * a new commit, we want to mention the old commit once more
	 * to remind the user that it might be lost.
D
Daniel Barkalow 已提交
550
	 */
551
	if (!opts->quiet && !old.path && old.commit && new->commit != old.commit)
D
Daniel Barkalow 已提交
552 553
		describe_detached_head("Previous HEAD position was", old.commit);

554
	if (!old.commit && !opts->force) {
D
Daniel Barkalow 已提交
555 556 557 558 559 560 561
		if (!opts->quiet) {
			fprintf(stderr, "warning: You appear to be on a branch yet to be born.\n");
			fprintf(stderr, "warning: Forcing checkout of %s.\n", new->name);
		}
		opts->force = 1;
	}

562
	ret = merge_working_tree(opts, &old, new);
D
Daniel Barkalow 已提交
563 564 565 566 567
	if (ret)
		return ret;

	update_refs_for_switch(opts, &old, new);

568 569
	ret = post_checkout_hook(old.commit, new->commit, 1);
	return ret || opts->writeout_error;
D
Daniel Barkalow 已提交
570 571
}

572 573 574 575 576
static int git_checkout_config(const char *var, const char *value, void *cb)
{
	return git_xmerge_config(var, value, cb);
}

D
Daniel Barkalow 已提交
577 578 579 580 581 582 583
int cmd_checkout(int argc, const char **argv, const char *prefix)
{
	struct checkout_opts opts;
	unsigned char rev[20];
	const char *arg;
	struct branch_info new;
	struct tree *source_tree = NULL;
584
	char *conflict_style = NULL;
D
Daniel Barkalow 已提交
585 586 587 588
	struct option options[] = {
		OPT__QUIET(&opts.quiet),
		OPT_STRING('b', NULL, &opts.new_branch, "new branch", "branch"),
		OPT_BOOLEAN('l', NULL, &opts.new_branch_log, "log for new branch"),
589
		OPT_SET_INT('t', "track",  &opts.track, "track",
590
			BRANCH_TRACK_EXPLICIT),
591 592 593 594
		OPT_SET_INT('2', "ours", &opts.writeout_stage, "stage",
			    2),
		OPT_SET_INT('3', "theirs", &opts.writeout_stage, "stage",
			    3),
D
Daniel Barkalow 已提交
595
		OPT_BOOLEAN('f', NULL, &opts.force, "force"),
596 597 598
		OPT_BOOLEAN('m', "merge", &opts.merge, "merge"),
		OPT_STRING(0, "conflict", &conflict_style, "style",
			   "conflict style (merge or diff3)"),
599
		OPT_END(),
D
Daniel Barkalow 已提交
600
	};
601
	int has_dash_dash;
D
Daniel Barkalow 已提交
602 603 604 605

	memset(&opts, 0, sizeof(opts));
	memset(&new, 0, sizeof(new));

606
	git_config(git_checkout_config, NULL);
D
Daniel Barkalow 已提交
607

608
	opts.track = BRANCH_TRACK_UNSPECIFIED;
D
Daniel Barkalow 已提交
609

610 611
	argc = parse_options(argc, argv, options, checkout_usage,
			     PARSE_OPT_KEEP_DASHDASH);
612

613
	/* --track without -b should DWIM */
614 615 616
	if (0 < opts.track && !opts.new_branch) {
		const char *argv0 = argv[0];
		if (!argc || !strcmp(argv0, "--"))
617
			die ("--track needs a branch name");
618 619 620 621 622 623
		if (!prefixcmp(argv0, "refs/"))
			argv0 += 5;
		if (!prefixcmp(argv0, "remotes/"))
			argv0 += 8;
		argv0 = strchr(argv0, '/');
		if (!argv0 || !argv0[1])
624
			die ("Missing branch name; try -b");
625
		opts.new_branch = argv0 + 1;
626 627
	}

628
	if (opts.track == BRANCH_TRACK_UNSPECIFIED)
629
		opts.track = git_branch_track;
630 631 632 633 634
	if (conflict_style) {
		opts.merge = 1; /* implied */
		git_xmerge_config("merge.conflictstyle", conflict_style, NULL);
	}

635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658
	if (opts.force && opts.merge)
		die("git checkout: -f and -m are incompatible");

	/*
	 * case 1: git checkout <ref> -- [<paths>]
	 *
	 *   <ref> must be a valid tree, everything after the '--' must be
	 *   a path.
	 *
	 * case 2: git checkout -- [<paths>]
	 *
	 *   everything after the '--' must be paths.
	 *
	 * case 3: git checkout <something> [<paths>]
	 *
	 *   With no paths, if <something> is a commit, that is to
	 *   switch to the branch or detach HEAD at it.
	 *
	 *   Otherwise <something> shall not be ambiguous.
	 *   - If it's *only* a reference, treat it like case (1).
	 *   - If it's only a path, treat it like case (2).
	 *   - else: fail.
	 *
	 */
D
Daniel Barkalow 已提交
659
	if (argc) {
660 661 662 663 664 665
		if (!strcmp(argv[0], "--")) {       /* case (2) */
			argv++;
			argc--;
			goto no_reference;
		}

D
Daniel Barkalow 已提交
666
		arg = argv[0];
667 668
		has_dash_dash = (argc > 1) && !strcmp(argv[1], "--");

669 670 671
		if (!strcmp(arg, "-"))
			arg = "@{-1}";

672 673 674 675 676 677 678 679 680 681
		if (get_sha1(arg, rev)) {
			if (has_dash_dash)          /* case (1) */
				die("invalid reference: %s", arg);
			goto no_reference;          /* case (3 -> 2) */
		}

		/* we can't end up being in (2) anymore, eat the argument */
		argv++;
		argc--;

682
		new.name = arg;
683
		if ((new.commit = lookup_commit_reference_gently(rev, 1))) {
D
Daniel Barkalow 已提交
684 685 686 687 688 689 690
			setup_branch_path(&new);
			if (resolve_ref(new.path, rev, 1, NULL))
				new.commit = lookup_commit_reference(rev);
			else
				new.path = NULL;
			parse_commit(new.commit);
			source_tree = new.commit->tree;
691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706
		} else
			source_tree = parse_tree_indirect(rev);

		if (!source_tree)                   /* case (1): want a tree */
			die("reference is not a tree: %s", arg);
		if (!has_dash_dash) {/* case (3 -> 1) */
			/*
			 * Do not complain the most common case
			 *	git checkout branch
			 * even if there happen to be a file called 'branch';
			 * it would be extremely annoying.
			 */
			if (argc)
				verify_non_filename(NULL, arg);
		}
		else {
D
Daniel Barkalow 已提交
707 708 709 710 711
			argv++;
			argc--;
		}
	}

712
no_reference:
D
Daniel Barkalow 已提交
713 714
	if (argc) {
		const char **pathspec = get_pathspec(prefix, argv);
715 716 717 718

		if (!pathspec)
			die("invalid path specification");

D
Daniel Barkalow 已提交
719
		/* Checkout paths */
720
		if (opts.new_branch) {
D
Daniel Barkalow 已提交
721
			if (argc == 1) {
722
				die("git checkout: updating paths is incompatible with switching branches.\nDid you intend to checkout '%s' which can not be resolved as commit?", argv[0]);
D
Daniel Barkalow 已提交
723
			} else {
724
				die("git checkout: updating paths is incompatible with switching branches.");
D
Daniel Barkalow 已提交
725 726 727
			}
		}

728 729 730
		if (1 < !!opts.writeout_stage + !!opts.force + !!opts.merge)
			die("git checkout: --ours/--theirs, --force and --merge are incompatible when\nchecking out of the index.");

731
		return checkout_paths(source_tree, pathspec, &opts);
D
Daniel Barkalow 已提交
732 733
	}

734
	if (opts.new_branch) {
735
		struct strbuf buf = STRBUF_INIT;
736 737 738 739 740 741 742 743 744
		strbuf_addstr(&buf, "refs/heads/");
		strbuf_addstr(&buf, opts.new_branch);
		if (!get_sha1(buf.buf, rev))
			die("git checkout: branch %s already exists", opts.new_branch);
		if (check_ref_format(buf.buf))
			die("git checkout: we do not like '%s' as a branch name.", opts.new_branch);
		strbuf_release(&buf);
	}

D
Daniel Barkalow 已提交
745 746 747
	if (new.name && !new.commit) {
		die("Cannot switch branch to a non-commit.");
	}
748 749
	if (opts.writeout_stage)
		die("--ours/--theirs is incompatible with switching branches.");
D
Daniel Barkalow 已提交
750

751
	return switch_branches(&opts, &new);
D
Daniel Barkalow 已提交
752
}