Merge branch 'js/help-commands-verbose-by-default-fix' into maint

"git help -a" did not work well when an overly long alias is
defined, which has been corrected.

* js/help-commands-verbose-by-default-fix:
  help -a: handle aliases with long names gracefully
  help.h: fix coding style
This commit is contained in:
Junio C Hamano 2018-12-15 12:24:33 +09:00
commit 916f56d38b
2 changed files with 10 additions and 2 deletions

10
help.c
View File

@ -83,8 +83,9 @@ static void print_command_list(const struct cmdname_help *cmds,
for (i = 0; cmds[i].name; i++) { for (i = 0; cmds[i].name; i++) {
if (cmds[i].category & mask) { if (cmds[i].category & mask) {
size_t len = strlen(cmds[i].name);
printf(" %s ", cmds[i].name); printf(" %s ", cmds[i].name);
mput_char(' ', longest - strlen(cmds[i].name)); mput_char(' ', longest > len ? longest - len : 1);
puts(_(cmds[i].help)); puts(_(cmds[i].help));
} }
} }
@ -526,6 +527,13 @@ void list_all_cmds_help(void)
git_config(get_alias, &alias_list); git_config(get_alias, &alias_list);
string_list_sort(&alias_list); string_list_sort(&alias_list);
for (i = 0; i < alias_list.nr; i++) {
size_t len = strlen(alias_list.items[i].string);
if (longest < len)
longest = len;
}
if (alias_list.nr) { if (alias_list.nr) {
printf("\n%s\n", _("Command aliases")); printf("\n%s\n", _("Command aliases"));
ALLOC_ARRAY(aliases, alias_list.nr + 1); ALLOC_ARRAY(aliases, alias_list.nr + 1);

2
help.h
View File

@ -15,7 +15,7 @@ struct cmdnames {
static inline void mput_char(char c, unsigned int num) static inline void mput_char(char c, unsigned int num)
{ {
while(num--) while (num--)
putchar(c); putchar(c);
} }