Junio suggested: > How about allowing multi-valued man.viewer like this: > > [man] > viewer = woman > viewer = konqueror > viewer = man > > and have: > > static struct man_viewer { > char *name; > void (*exec)(const char *); > } viewers[] = { > { "woman", exec_woman }, > { "konqueror", exec_konqueror }, > { "man", exec_man }, > { NULL, }, > }; > > Then you can iterate the man.viewer values, ask the viewer's > exec() function to show the page (or return when it is not > in an environment that it can be useful). > > show_man_page() would become: > > for (each viewer in user's config) > viewer.exec(page); /* will return when unable */ > die("no man viewer handled the request"); This patch implements the above using a list of exec functions that is filled when reading the config. To do that the exec functions have been moved before reading the config. This makes the patch much longer than it would be otherwise. Signed-off-by: Christian Couder <chriscool@xxxxxxxxxxxxx> Tested-by: Xavier Maillard <xma@xxxxxxx> Though, I thought that when one entry had failed we would have switched to the next until none could be found thus I (voluntary) made a typo in my .git/config file as reflected by: [xma@localhost 23:57:18 git]$ git config --get-all man.viewer woma <- TYPO HERE konqueror man and I then tried git config --help. I thought it would have tried all entries and as a last resort would have failed back to man but it did not act like this: [xma@localhost 23:57:11 git]$ git config --help error: 'woma': unsupported man viewer. fatal: bad config file line 16 in .git/config Ok, woma in not supported here and it is reported like this but would it be possible to just throw an error on stdout and try another viewer ? We could even imagine something even more general like the possibility for the user to write his own man viewer (a bash script for example) and set it as a candidate. By the way, I do not see any reason to put man as a candidate. "man" should be the default when nothing is specified or when all candidates have failed. Anyway, thank you for this implementation. Xavier -- http://www.gnu.org http://www.april.org http://www.lolica.org -- 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