diff options
| author | Junio C Hamano <gitster@pobox.com> | 2008-07-01 16:22:19 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-07-01 16:22:19 -0700 | 
| commit | 24cd49f627ab0d313f8f7925e1f6f855563fea43 (patch) | |
| tree | 57e84d18b0469e5eda3d8646b6d70da9e6b50a09 | |
| parent | e74776b0d82326cd1cd09b01189105f323bef0ec (diff) | |
| parent | dfc8f39e4346d000052c39ef7cb6bfe8fdb48c51 (diff) | |
| download | git-24cd49f627ab0d313f8f7925e1f6f855563fea43.tar.gz | |
Merge branch 'jc/maint-reset'
* jc/maint-reset:
  Allow "git-reset path" when unambiguous
| -rw-r--r-- | builtin-reset.c | 39 | ||||
| -rwxr-xr-x | t/t7102-reset.sh | 47 | 
2 files changed, 81 insertions, 5 deletions
| diff --git a/builtin-reset.c b/builtin-reset.c index f34acb1915..a0321694c5 100644 --- a/builtin-reset.c +++ b/builtin-reset.c @@ -194,8 +194,40 @@ int cmd_reset(int argc, const char **argv, const char *prefix)  	reflog_action = args_to_str(argv);  	setenv("GIT_REFLOG_ACTION", reflog_action, 0); -	if (i < argc && strcmp(argv[i], "--")) -		rev = argv[i++]; +	/* +	 * Possible arguments are: +	 * +	 * git reset [-opts] <rev> <paths>... +	 * git reset [-opts] <rev> -- <paths>... +	 * git reset [-opts] -- <paths>... +	 * git reset [-opts] <paths>... +	 * +	 * At this point, argv[i] points immediately after [-opts]. +	 */ + +	if (i < argc) { +		if (!strcmp(argv[i], "--")) { +			i++; /* reset to HEAD, possibly with paths */ +		} else if (i + 1 < argc && !strcmp(argv[i+1], "--")) { +			rev = argv[i]; +			i += 2; +		} +		/* +		 * Otherwise, argv[i] could be either <rev> or <paths> and +		 * has to be unambigous. +		 */ +		else if (!get_sha1(argv[i], sha1)) { +			/* +			 * Ok, argv[i] looks like a rev; it should not +			 * be a filename. +			 */ +			verify_non_filename(prefix, argv[i]); +			rev = argv[i++]; +		} else { +			/* Otherwise we treat this as a filename */ +			verify_filename(prefix, argv[i]); +		} +	}  	if (get_sha1(rev, sha1))  		die("Failed to resolve '%s' as a valid ref.", rev); @@ -205,9 +237,6 @@ int cmd_reset(int argc, const char **argv, const char *prefix)  		die("Could not parse object '%s'.", rev);  	hashcpy(sha1, commit->object.sha1); -	if (i < argc && !strcmp(argv[i], "--")) -		i++; -  	/* git reset tree [--] paths... can be used to  	 * load chosen paths from the tree into the index without  	 * affecting the working tree nor HEAD. */ diff --git a/t/t7102-reset.sh b/t/t7102-reset.sh index 39ba14148c..96d15083fb 100755 --- a/t/t7102-reset.sh +++ b/t/t7102-reset.sh @@ -428,4 +428,51 @@ test_expect_success '--mixed refreshes the index' '  	test_cmp expect output  ' +test_expect_success 'disambiguation (1)' ' + +	git reset --hard && +	>secondfile && +	git add secondfile && +	test_must_fail git reset secondfile && +	test -z "$(git diff --cached --name-only)" && +	test -f secondfile && +	test ! -s secondfile + +' + +test_expect_success 'disambiguation (2)' ' + +	git reset --hard && +	>secondfile && +	git add secondfile && +	rm -f secondfile && +	test_must_fail git reset secondfile && +	test -n "$(git diff --cached --name-only -- secondfile)" && +	test ! -f secondfile + +' + +test_expect_success 'disambiguation (3)' ' + +	git reset --hard && +	>secondfile && +	git add secondfile && +	rm -f secondfile && +	test_must_fail git reset HEAD secondfile && +	test -z "$(git diff --cached --name-only)" && +	test ! -f secondfile + +' + +test_expect_success 'disambiguation (4)' ' + +	git reset --hard && +	>secondfile && +	git add secondfile && +	rm -f secondfile && +	test_must_fail git reset -- secondfile && +	test -z "$(git diff --cached --name-only)" && +	test ! -f secondfile +' +  test_done | 
