]> git.ipfire.org Git - thirdparty/git.git/commitdiff
help: convert git_cmd to page in one place
authorAndrei Rybak <rybak.a.v@gmail.com>
Sun, 4 Jul 2021 15:39:12 +0000 (17:39 +0200)
committerJunio C Hamano <gitster@pobox.com>
Tue, 6 Jul 2021 20:09:20 +0000 (13:09 -0700)
Depending on the chosen format of help pages, git-help uses function
show_man_page, show_info_page, or show_html_page.  The first thing all
three functions do is to convert given `git_cmd` to a `page` using
function cmd_to_page.

Move the common part of these three functions to function cmd_help to
avoid code duplication.

Signed-off-by: Andrei Rybak <rybak.a.v@gmail.com>
Reviewed-by: Felipe Contreras <felipe.contreras@gmail.com>
Acked-by: Ævar Arnfjörð Bjarmason <avarab@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/help.c

index bb339f0fc80298185f330fe6fbff9dd385da5e0d..b7eec06c3de8a943fdbd22ba83502d69335726d0 100644 (file)
@@ -436,10 +436,9 @@ static void exec_viewer(const char *name, const char *page)
                warning(_("'%s': unknown man viewer."), name);
 }
 
-static void show_man_page(const char *git_cmd)
+static void show_man_page(const char *page)
 {
        struct man_viewer_list *viewer;
-       const char *page = cmd_to_page(git_cmd);
        const char *fallback = getenv("GIT_MAN_VIEWER");
 
        setup_man_path();
@@ -453,9 +452,8 @@ static void show_man_page(const char *git_cmd)
        die(_("no man viewer handled the request"));
 }
 
-static void show_info_page(const char *git_cmd)
+static void show_info_page(const char *page)
 {
-       const char *page = cmd_to_page(git_cmd);
        setenv("INFOPATH", system_path(GIT_INFO_PATH), 1);
        execlp("info", "info", "gitman", page, (char *)NULL);
        die(_("no info viewer handled the request"));
@@ -486,9 +484,8 @@ static void open_html(const char *path)
        execl_git_cmd("web--browse", "-c", "help.browser", path, (char *)NULL);
 }
 
-static void show_html_page(const char *git_cmd)
+static void show_html_page(const char *page)
 {
-       const char *page = cmd_to_page(git_cmd);
        struct strbuf page_path; /* it leaks but we exec bellow */
 
        get_html_page_path(&page_path, page);
@@ -548,6 +545,7 @@ int cmd_help(int argc, const char **argv, const char *prefix)
 {
        int nongit;
        enum help_format parsed_help_format;
+       const char *page;
 
        argc = parse_options(argc, argv, prefix, builtin_help_options,
                        builtin_help_usage, 0);
@@ -606,16 +604,17 @@ int cmd_help(int argc, const char **argv, const char *prefix)
 
        argv[0] = check_git_cmd(argv[0]);
 
+       page = cmd_to_page(argv[0]);
        switch (help_format) {
        case HELP_FORMAT_NONE:
        case HELP_FORMAT_MAN:
-               show_man_page(argv[0]);
+               show_man_page(page);
                break;
        case HELP_FORMAT_INFO:
-               show_info_page(argv[0]);
+               show_info_page(page);
                break;
        case HELP_FORMAT_WEB:
-               show_html_page(argv[0]);
+               show_html_page(page);
                break;
        }