diff options
Diffstat (limited to 'builtin/reset.c')
| -rw-r--r-- | builtin/reset.c | 12 | 
1 files changed, 9 insertions, 3 deletions
| diff --git a/builtin/reset.c b/builtin/reset.c index 43e855cb88..7393595349 100644 --- a/builtin/reset.c +++ b/builtin/reset.c @@ -67,12 +67,18 @@ static int reset_index(const char *ref, const struct object_id *oid, int reset_t  	case KEEP:  	case MERGE:  		opts.update = 1; +		opts.preserve_ignored = 0; /* FIXME: !overwrite_ignore */  		break;  	case HARD:  		opts.update = 1; -		/* fallthrough */ +		opts.reset = UNPACK_RESET_OVERWRITE_UNTRACKED; +		break; +	case MIXED: +		opts.reset = UNPACK_RESET_PROTECT_UNTRACKED; +		/* but opts.update=0, so working tree not updated */ +		break;  	default: -		opts.reset = 1; +		BUG("invalid reset_type passed to reset_index");  	}  	read_cache_unmerged(); @@ -412,7 +418,7 @@ int cmd_reset(int argc, const char **argv, const char *prefix)  				refresh_index(&the_index, flags, NULL, NULL,  					      _("Unstaged changes after reset:"));  				t_delta_in_ms = (getnanotime() - t_begin) / 1000000; -				if (advice_reset_quiet_warning && t_delta_in_ms > REFRESH_INDEX_DELAY_WARNING_IN_MS) { +				if (advice_enabled(ADVICE_RESET_QUIET_WARNING) && t_delta_in_ms > REFRESH_INDEX_DELAY_WARNING_IN_MS) {  					printf(_("\nIt took %.2f seconds to enumerate unstaged changes after reset.  You can\n"  						"use '--quiet' to avoid this.  Set the config setting reset.quiet to true\n"  						"to make this the default.\n"), t_delta_in_ms / 1000.0); | 
