Code

Merge branch 'cc/browser'
authorJunio C Hamano <gitster@pobox.com>
Sun, 17 Feb 2008 01:57:47 +0000 (17:57 -0800)
committerJunio C Hamano <gitster@pobox.com>
Sun, 17 Feb 2008 01:57:47 +0000 (17:57 -0800)
* cc/browser:
  Documentation: add 'git-web--browse.txt' and simplify other docs.
  git-web--browse: fix misplaced quote in init_browser_path()
  web--browse: Add a few quotes in 'init_browser_path'.
  Documentation: instaweb: add 'git-web--browse' information.
  Adjust .gitignore for 5884f1(Rename 'git-help--browse.sh'...)
  git-web--browse: do not start the browser with nohup
  instaweb: use 'git-web--browse' to launch browser.
  Rename 'git-help--browse.sh' to 'git-web--browse.sh'.
  help--browse: add '--config' option to check a config option for a browser.
  help: make 'git-help--browse' usable outside 'git-help'.

Conflicts:

git-web--browse.sh

1  2 
git-web--browse.sh
help.c

index 0000000000000000000000000000000000000000,fbf29cbe16a4c6b5fd78b12e130e4b06199ead71..1023b9085989aecfdcdc161232ee22de866d5f57
mode 000000,100755..100755
--- /dev/null
@@@ -1,0 -1,156 +1,160 @@@
 -              firefox | iceweasel | konqueror | w3m | links | lynx | dillo)
+ #!/bin/sh
+ #
+ # This program launch a web browser on the html page
+ # describing a git command.
+ #
+ # Copyright (c) 2007 Christian Couder
+ # Copyright (c) 2006 Theodore Y. Ts'o
+ #
+ # This file is heavily stolen from git-mergetool.sh, by
+ # Theodore Y. Ts'o (thanks) that is:
+ #
+ # Copyright (c) 2006 Theodore Y. Ts'o
+ #
+ # This file is licensed under the GPL v2, or a later version
+ # at the discretion of Junio C Hamano or any other official
+ # git maintainer.
+ #
+ USAGE='[--browser=browser|--tool=browser] [--config=conf.var] url/file ...'
+ # This must be capable of running outside of git directory, so
+ # the vanilla git-sh-setup should not be used.
+ NONGIT_OK=Yes
+ . git-sh-setup
+ valid_tool() {
+       case "$1" in
 -    w3m|links|lynx)
++              firefox | iceweasel | konqueror | w3m | links | lynx | dillo | open)
+                       ;; # happy
+               *)
+                       return 1
+                       ;;
+       esac
+ }
+ init_browser_path() {
+       browser_path=$(git config "browser.$1.path")
+       test -z "$browser_path" && browser_path="$1"
+ }
+ while test $# != 0
+ do
+     case "$1" in
+       -b|--browser*|-t|--tool*)
+           case "$#,$1" in
+               *,*=*)
+                   browser=`expr "z$1" : 'z-[^=]*=\(.*\)'`
+                   ;;
+               1,*)
+                   usage ;;
+               *)
+                   browser="$2"
+                   shift ;;
+           esac
+           ;;
+       -c|--config*)
+           case "$#,$1" in
+               *,*=*)
+                   conf=`expr "z$1" : 'z-[^=]*=\(.*\)'`
+                   ;;
+               1,*)
+                   usage ;;
+               *)
+                   conf="$2"
+                   shift ;;
+           esac
+           ;;
+       --)
+           break
+           ;;
+       -*)
+           usage
+           ;;
+       *)
+           break
+           ;;
+     esac
+     shift
+ done
+ test $# = 0 && usage
+ if test -z "$browser"
+ then
+     for opt in "$conf" "web.browser"
+     do
+       test -z "$opt" && continue
+       browser="`git config $opt`"
+       test -z "$browser" || break
+     done
+     if test -n "$browser" && ! valid_tool "$browser"; then
+       echo >&2 "git config option $opt set to unknown browser: $browser"
+       echo >&2 "Resetting to default..."
+       unset browser
+     fi
+ fi
+ if test -z "$browser" ; then
+     if test -n "$DISPLAY"; then
+       browser_candidates="firefox iceweasel konqueror w3m links lynx dillo"
+       if test "$KDE_FULL_SESSION" = "true"; then
+           browser_candidates="konqueror $browser_candidates"
+       fi
+     else
+       browser_candidates="w3m links lynx"
+     fi
++    # SECURITYSESSIONID indicates an OS X GUI login session
++    if test -n "$SECURITYSESSIONID"; then
++      browser_candidates="open $browser_candidates"
++    fi
+     for i in $browser_candidates; do
+       init_browser_path $i
+       if type "$browser_path" > /dev/null 2>&1; then
+           browser=$i
+           break
+       fi
+     done
+     test -z "$browser" && die "No known browser available."
+ else
+     valid_tool "$browser" || die "Unknown browser '$browser'."
+     init_browser_path "$browser"
+     if ! type "$browser_path" > /dev/null 2>&1; then
+       die "The browser $browser is not available as '$browser_path'."
+     fi
+ fi
+ case "$browser" in
+     firefox|iceweasel)
+       # Check version because firefox < 2.0 does not support "-new-tab".
+       vers=$(expr "$($browser_path -version)" : '.* \([0-9][0-9]*\)\..*')
+       NEWTAB='-new-tab'
+       test "$vers" -lt 2 && NEWTAB=''
+       "$browser_path" $NEWTAB "$@" &
+       ;;
+     konqueror)
+       case "$(basename "$browser_path")" in
+           konqueror)
+               # It's simpler to use kfmclient to open a new tab in konqueror.
+               browser_path="$(echo "$browser_path" | sed -e 's/konqueror$/kfmclient/')"
+               type "$browser_path" > /dev/null 2>&1 || die "No '$browser_path' found."
+               eval "$browser_path" newTab "$@"
+               ;;
+           kfmclient)
+               eval "$browser_path" newTab "$@"
+               ;;
+           *)
+               "$browser_path" "$@" &
+               ;;
+       esac
+       ;;
++    w3m|links|lynx|open)
+       eval "$browser_path" "$@"
+       ;;
+     dillo)
+       "$browser_path" "$@" &
+       ;;
+ esac
diff --cc help.c
Simple merge