blob: 7a455beeb725e267946b1ac2c4d91ba9fee2a8c1 [file] [log] [blame]
Miklos Vajna940208a2008-07-30 01:16:58 +02001#ifndef HELP_H
2#define HELP_H
3
Nguyễn Thái Ngọc Duy3ac68a92018-05-26 15:55:24 +02004#include "string-list.h"
5#include "strbuf.h"
Nguyễn Thái Ngọc Duy6bb2dc02018-05-20 20:39:59 +02006
Miklos Vajna940208a2008-07-30 01:16:58 +02007struct cmdnames {
8 int alloc;
9 int cnt;
10 struct cmdname {
Johannes Schindelin8af84da2008-08-31 15:50:23 +020011 size_t len; /* also used for similarity index in help.c */
Miklos Vajna940208a2008-07-30 01:16:58 +020012 char name[FLEX_ARRAY];
13 } **names;
14};
15
Miklos Vajna3d78d1f2008-08-02 10:08:38 +020016static inline void mput_char(char c, unsigned int num)
17{
Johannes Schindelin5acea872018-12-11 06:58:10 -080018 while (num--)
Miklos Vajna3d78d1f2008-08-02 10:08:38 +020019 putchar(c);
20}
21
Denton Liu55454422019-04-29 04:28:14 -040022void list_common_cmds_help(void);
23void list_all_cmds_help(void);
24void list_common_guides_help(void);
25void list_config_help(int for_human);
Nguyễn Thái Ngọc Duy63eae832018-05-20 20:40:01 +020026
Denton Liu55454422019-04-29 04:28:14 -040027void list_all_main_cmds(struct string_list *list);
28void list_all_other_cmds(struct string_list *list);
29void list_cmds_by_category(struct string_list *list,
Denton Liuad6dad02019-04-29 04:28:23 -040030 const char *category);
Denton Liu55454422019-04-29 04:28:14 -040031void list_cmds_by_config(struct string_list *list);
32const char *help_unknown_cmd(const char *cmd);
33void load_command_list(const char *prefix,
Denton Liuad6dad02019-04-29 04:28:23 -040034 struct cmdnames *main_cmds,
35 struct cmdnames *other_cmds);
Denton Liu55454422019-04-29 04:28:14 -040036void add_cmdname(struct cmdnames *cmds, const char *name, int len);
Miklos Vajna940208a2008-07-30 01:16:58 +020037/* Here we require that excludes is a sorted list. */
Denton Liu55454422019-04-29 04:28:14 -040038void exclude_cmds(struct cmdnames *cmds, struct cmdnames *excludes);
39int is_in_cmdlist(struct cmdnames *cmds, const char *name);
40void list_commands(unsigned int colopts, struct cmdnames *main_cmds, struct cmdnames *other_cmds);
Miklos Vajna940208a2008-07-30 01:16:58 +020041
Vikrant Varmae5618102013-05-04 05:34:19 +053042/*
43 * call this to die(), when it is suspected that the user mistyped a
44 * ref to the command, to give suggested "correct" refs.
45 */
René Scharfe80e36582019-08-29 21:13:16 +020046NORETURN void help_unknown_ref(const char *ref, const char *cmd, const char *error);
Nguyễn Thái Ngọc Duy3ac68a92018-05-26 15:55:24 +020047
48static inline void list_config_item(struct string_list *list,
49 const char *prefix,
50 const char *str)
51{
52 string_list_append_nodup(list, xstrfmt("%s.%s", prefix, str));
53}
54
55#define define_list_config_array(array) \
56void list_config_##array(struct string_list *list, const char *prefix) \
57{ \
58 int i; \
59 for (i = 0; i < ARRAY_SIZE(array); i++) \
60 if (array[i]) \
61 list_config_item(list, prefix, array[i]); \
62} \
63struct string_list
64
65#define define_list_config_array_extra(array, values) \
66void list_config_##array(struct string_list *list, const char *prefix) \
67{ \
68 int i; \
69 static const char *extra[] = values; \
70 for (i = 0; i < ARRAY_SIZE(extra); i++) \
71 list_config_item(list, prefix, extra[i]); \
72 for (i = 0; i < ARRAY_SIZE(array); i++) \
73 if (array[i]) \
74 list_config_item(list, prefix, array[i]); \
75} \
76struct string_list
77
78/* These are actually scattered over many C files */
79void list_config_advices(struct string_list *list, const char *prefix);
80void list_config_color_branch_slots(struct string_list *list, const char *prefix);
81void list_config_color_decorate_slots(struct string_list *list, const char *prefix);
82void list_config_color_diff_slots(struct string_list *list, const char *prefix);
83void list_config_color_grep_slots(struct string_list *list, const char *prefix);
84void list_config_color_interactive_slots(struct string_list *list, const char *prefix);
85void list_config_color_status_slots(struct string_list *list, const char *prefix);
Han-Wen Nienhuysbf1a11f2018-08-07 14:51:08 +020086void list_config_color_sideband_slots(struct string_list *list, const char *prefix);
Nguyễn Thái Ngọc Duy3ac68a92018-05-26 15:55:24 +020087void list_config_fsck_msg_ids(struct string_list *list, const char *prefix);
88
Miklos Vajna940208a2008-07-30 01:16:58 +020089#endif /* HELP_H */