Victoria Dye <vdye@xxxxxxxxxx> writes: > Junio C Hamano wrote: >> Junio C Hamano <gitster@xxxxxxxxx> writes: >> >>> ... as you suggested, I think mimicking how existing commands with >>> "--no-<option>" are shown, e.g. builtlin/update-ref.c does >>> "--no-deref", >>> >>> $ git update-ref -h 2>&1 | grep deref >>> --no-deref update <refname> not the one it points to >>> $ git grep 'OPT_BOOL.*"no-deref"' >>> builtin/update-ref.c: OPT_BOOL( 0 , "no-deref", &no_deref, >>> >>> would be a good approach. >>> >>>> The range-diff for the other changes looks good >>> >>> Thanks. >>> >>> #leftoverbit: we may want to discuss if it is a good idea to teach >>> OPT_BOOL() to list "--[no-]<option>" in "git cmd -h", instead of >>> just "--<option>". >> >> >> Unfortunately, I merged these already to 'next' before seeing your >> comment, so we'd need to go incremental. >> >> How about this? >> >> ----- >8 --------- >8 --------- >8 --------- >8 ----- >> Subject: [PATCH] reset: show --no-refresh in the short-help >> >> In the short help output from "git reset -h", the recently added >> "--[no-]refresh" option is shown like so: >> >> --refresh skip refreshing the index after reset >> >> which explains what happens when the option is given in the negative >> form, i.e. "--no-refresh". We could rephrase the explanation to >> read "refresh the index after reset (default)" to hint that the user >> can say "--no-refresh" to override the default, but listing the >> "--no-refresh" form in the list of options would be more helpful. >> >> Helped-by: Phillip Wood <phillip.wood@xxxxxxxxxxxxx> >> Signed-off-by: Junio C Hamano <gitster@xxxxxxxxx> >> --- >> builtin/reset.c | 6 +++--- >> 1 file changed, 3 insertions(+), 3 deletions(-) >> >> diff --git c/builtin/reset.c w/builtin/reset.c >> index 1d89faef5e..344fff8f3a 100644 >> --- c/builtin/reset.c >> +++ w/builtin/reset.c >> @@ -392,7 +392,7 @@ static int git_reset_config(const char *var, const char *value, void *cb) >> int cmd_reset(int argc, const char **argv, const char *prefix) >> { >> int reset_type = NONE, update_ref_status = 0, quiet = 0; >> - int refresh = 1; >> + int no_refresh = 0; >> int patch_mode = 0, pathspec_file_nul = 0, unborn; >> const char *rev, *pathspec_from_file = NULL; >> struct object_id oid; >> @@ -400,7 +400,7 @@ int cmd_reset(int argc, const char **argv, const char *prefix) >> int intent_to_add = 0; >> const struct option options[] = { >> OPT__QUIET(&quiet, N_("be quiet, only report errors")), >> - OPT_BOOL(0, "refresh", &refresh, >> + OPT_BOOL(0, "no-refresh", &no_refresh, >> N_("skip refreshing the index after reset")), >> OPT_SET_INT(0, "mixed", &reset_type, >> N_("reset HEAD and index"), MIXED), >> @@ -519,7 +519,7 @@ int cmd_reset(int argc, const char **argv, const char *prefix) >> if (read_from_tree(&pathspec, &oid, intent_to_add)) >> return 1; >> the_index.updated_skipworktree = 1; >> - if (refresh && get_git_work_tree()) { >> + if (!no_refresh && get_git_work_tree()) { >> uint64_t t_begin, t_delta_in_ms; >> >> t_begin = getnanotime(); > > This looks good to me, and it's passing all of the relevant tests. Thank you > both for your help with this! OK, will queue this on top. Thanks.