Skip to content

Commit edd8ad1

Browse files
jonatan-holmgrengitster
authored andcommitted
completion: fix zsh alias listing for subsection aliases
The zsh completion function __git_zsh_cmd_alias() uses 'git config --get-regexp' to enumerate aliases and then strips the "alias." prefix from each key. For subsection-style aliases (alias.name.command), this leaves "name.command" as the completion candidate instead of just "name". The bash completion does not have this problem because it goes through 'git --list-cmds=alias', which calls list_aliases() in C and already handles both alias syntaxes correctly. However, zsh needs both the alias name and its value for descriptive completion, which --list-cmds=alias does not provide. Add a hidden --aliases-for-completion option to 'git help', following the existing --config-for-completion pattern. It outputs NUL-separated "name\nvalue" pairs using list_aliases(), which correctly resolves both the traditional (alias.name) and subsection (alias.name.command) formats. Update __git_zsh_cmd_alias() to use it. Signed-off-by: Jonatan Holmgren <jonatan@jontes.page> Signed-off-by: Junio C Hamano <gitster@pobox.com>
1 parent ac1f12a commit edd8ad1

2 files changed

Lines changed: 14 additions & 1 deletion

File tree

builtin/help.c

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -54,6 +54,7 @@ static enum help_action {
5454
HELP_ACTION_DEVELOPER_INTERFACES,
5555
HELP_ACTION_CONFIG_FOR_COMPLETION,
5656
HELP_ACTION_CONFIG_SECTIONS_FOR_COMPLETION,
57+
HELP_ACTION_ALIASES_FOR_COMPLETION,
5758
} cmd_mode;
5859

5960
static char *html_path;
@@ -90,6 +91,8 @@ static struct option builtin_help_options[] = {
9091
HELP_ACTION_CONFIG_FOR_COMPLETION, PARSE_OPT_HIDDEN),
9192
OPT_CMDMODE_F(0, "config-sections-for-completion", &cmd_mode, "",
9293
HELP_ACTION_CONFIG_SECTIONS_FOR_COMPLETION, PARSE_OPT_HIDDEN),
94+
OPT_CMDMODE_F(0, "aliases-for-completion", &cmd_mode, "",
95+
HELP_ACTION_ALIASES_FOR_COMPLETION, PARSE_OPT_HIDDEN),
9396

9497
OPT_END(),
9598
};
@@ -691,6 +694,16 @@ int cmd_help(int argc,
691694
help_format);
692695
list_config_help(SHOW_CONFIG_SECTIONS);
693696
return 0;
697+
case HELP_ACTION_ALIASES_FOR_COMPLETION: {
698+
struct string_list alias_list = STRING_LIST_INIT_DUP;
699+
opt_mode_usage(argc, "--aliases-for-completion", help_format);
700+
list_aliases(&alias_list);
701+
for (size_t i = 0; i < alias_list.nr; i++)
702+
printf("%s%c%s%c", alias_list.items[i].string, '\n',
703+
(char *)alias_list.items[i].util, '\0');
704+
string_list_clear(&alias_list, 1);
705+
return 0;
706+
}
694707
case HELP_ACTION_CONFIG:
695708
opt_mode_usage(argc, "--config", help_format);
696709
setup_pager(the_repository);

contrib/completion/git-completion.zsh

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -202,7 +202,7 @@ __git_zsh_cmd_common ()
202202
__git_zsh_cmd_alias ()
203203
{
204204
local -a list
205-
list=(${${(0)"$(git config -z --get-regexp '^alias\.*')"}#alias.})
205+
list=(${(0)"$(git help --aliases-for-completion)"})
206206
list=(${(f)"$(printf "%s:alias for '%s'\n" ${(f@)list})"})
207207
_describe -t alias-commands 'aliases' list && _ret=0
208208
}

0 commit comments

Comments
 (0)