Configuring the new help.format = usage makes git foo --help exactly
equivalent to git foo -h, displaying brief command-line usage info
instead of full documentation in the form of a man/html page.
This is useful on stripped-down servers where man pages and viewer
aren't present, or if your fingers are trained to type COMMAND --help
instead of COMMAND -h to get usage info and the man page behaviour is
disturbing.
Signed-off-by: Chris Webb <chris@xxxxxxxxxxxx>
---
builtin/help.c | 16 ++++++++++++++--
1 file changed, 14 insertions(+), 2 deletions(-)
diff --git a/builtin/help.c b/builtin/help.c
index 60b3251..d4c3f5d 100644
--- a/builtin/help.c
+++ b/builtin/help.c
@@ -31,7 +31,8 @@ enum help_format {
HELP_FORMAT_NONE,
HELP_FORMAT_MAN,
HELP_FORMAT_INFO,
- HELP_FORMAT_WEB
+ HELP_FORMAT_WEB,
+ HELP_FORMAT_USAGE
};
static char *html_path = NULL;
@@ -46,11 +47,12 @@ static struct option builtin_help_options[] = {
HELP_FORMAT_WEB),
OPT_SET_INT('i', "info", &help_format, "show info page",
HELP_FORMAT_INFO),
+ OPT_SET_INT('u', "usage", &help_format, "show usage", HELP_FORMAT_USAGE),
OPT_END(),
};
static const char * const builtin_help_usage[] = {
- "git help [--all] [--man|--web|--info] [command]",
+ "git help [--all] [--man|--web|--info|--usage] [command]",
NULL
};
@@ -62,6 +64,8 @@ static enum help_format parse_help_format(const char *format)
return HELP_FORMAT_INFO;
if (!strcmp(format, "web") || !strcmp(format, "html"))
return HELP_FORMAT_WEB;
+ if (!strcmp(format, "usage"))
+ return HELP_FORMAT_USAGE;
die(_("unrecognized help format '%s'"), format);
}
@@ -431,6 +435,11 @@ static void show_html_page(const char *git_cmd)
open_html(page_path.buf);
}
+static void show_usage(const char *git_cmd)
+{
+ execl_git_cmd(git_cmd, "-h", NULL);
+}
+
int cmd_help(int argc, const char **argv, const char *prefix)
{
int nongit;
@@ -482,6 +491,9 @@ int cmd_help(int argc, const char **argv, const char *prefix)
case HELP_FORMAT_WEB:
show_html_page(argv[0]);
break;
+ case HELP_FORMAT_USAGE:
+ show_usage(argv[0]);
+ break;
}
return 0;
--
1.7.10
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
[Newbies FAQ] [Linux Kernel Development] [Free Online Dating] [Gcc Help] [IETF Annouce] [DCCP] [Netdev] [Networking] [Security] [V4L] [Bugtraq] [Free Online Dating] [Photo] [Yosemite] [MIPS Linux] [ARM Linux] [Linux Security] [Linux RAID] [Linux SCSI] [Fedora Users] [Linux Resources]