From: Romain Francoise Date: Fri, 29 Aug 2008 15:00:43 +0000 (+0200) Subject: builtin-help: fallback to GIT_MAN_VIEWER before man X-Git-Tag: v1.6.1-rc1~277^2 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=5059a427804f9fefaf75dd1aa92cb620ce9219c7;p=git.git builtin-help: fallback to GIT_MAN_VIEWER before man In some situations it is useful to be able to switch viewers via the environment, e.g. in Emacs shell buffers. So check the GIT_MAN_VIEWER environment variable and try it before falling back to "man". Signed-off-by: Romain Francoise Signed-off-by: Junio C Hamano --- diff --git a/Documentation/git-help.txt b/Documentation/git-help.txt index f414583fc..d9b9c34b3 100644 --- a/Documentation/git-help.txt +++ b/Documentation/git-help.txt @@ -112,7 +112,9 @@ For example, this configuration: will try to use konqueror first. But this may fail (for example if DISPLAY is not set) and in that case emacs' woman mode will be tried. -If everything fails the 'man' program will be tried anyway. +If everything fails, or if no viewer is configured, the viewer specified +in the GIT_MAN_VIEWER environment variable will be tried. If that +fails too, the 'man' program will be tried anyway. man..path ~~~~~~~~~~~~~~~ diff --git a/builtin-help.c b/builtin-help.c index 721038e4f..64207cbfe 100644 --- a/builtin-help.c +++ b/builtin-help.c @@ -361,12 +361,15 @@ static void show_man_page(const char *git_cmd) { struct man_viewer_list *viewer; const char *page = cmd_to_page(git_cmd); + const char *fallback = getenv("GIT_MAN_VIEWER"); setup_man_path(); for (viewer = man_viewer_list; viewer; viewer = viewer->next) { exec_viewer(viewer->name, page); /* will return when unable */ } + if (fallback) + exec_viewer(fallback, page); exec_viewer("man", page); die("no man viewer handled the request"); }