status: add status.aheadbehind setting
The --[no-]ahead-behind option was introduced in fd9b544a
(status: add --[no-]ahead-behind to status and commit for V2
format, 2018-01-09). This is a necessary change of behavior
in repos where the remote tracking branches can move very
quickly ahead of the local branches. However, users need to
remember to provide the command-line argument every time.
Add a new "status.aheadBehind" config setting to change the
default behavior of all git status formats.
Signed-off-by: Jeff Hostetler <jeffhost@microsoft.com>
Signed-off-by: Derrick Stolee <dstolee@microsoft.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
a6a95cd1b4
commit
06b324c1d7
@ -1078,9 +1078,11 @@ static const char *read_commit_message(const char *name)
|
||||
static struct status_deferred_config {
|
||||
enum wt_status_format status_format;
|
||||
int show_branch;
|
||||
enum ahead_behind_flags ahead_behind;
|
||||
} status_deferred_config = {
|
||||
STATUS_FORMAT_UNSPECIFIED,
|
||||
-1 /* unspecified */
|
||||
-1, /* unspecified */
|
||||
AHEAD_BEHIND_UNSPECIFIED,
|
||||
};
|
||||
|
||||
static void finalize_deferred_config(struct wt_status *s)
|
||||
@ -1107,6 +1109,15 @@ static void finalize_deferred_config(struct wt_status *s)
|
||||
if (s->show_branch < 0)
|
||||
s->show_branch = 0;
|
||||
|
||||
/*
|
||||
* If the user did not give a "--[no]-ahead-behind" command
|
||||
* line argument, then we inherit the a/b config setting.
|
||||
* If is not set, then we inherit _FULL for backwards
|
||||
* compatibility.
|
||||
*/
|
||||
if (s->ahead_behind_flags == AHEAD_BEHIND_UNSPECIFIED)
|
||||
s->ahead_behind_flags = status_deferred_config.ahead_behind;
|
||||
|
||||
if (s->ahead_behind_flags == AHEAD_BEHIND_UNSPECIFIED)
|
||||
s->ahead_behind_flags = AHEAD_BEHIND_FULL;
|
||||
}
|
||||
@ -1246,6 +1257,10 @@ static int git_status_config(const char *k, const char *v, void *cb)
|
||||
status_deferred_config.show_branch = git_config_bool(k, v);
|
||||
return 0;
|
||||
}
|
||||
if (!strcmp(k, "status.aheadbehind")) {
|
||||
status_deferred_config.ahead_behind = git_config_bool(k, v);
|
||||
return 0;
|
||||
}
|
||||
if (!strcmp(k, "status.showstash")) {
|
||||
s->show_stash = git_config_bool(k, v);
|
||||
return 0;
|
||||
|
Reference in New Issue
Block a user