author | Junio C Hamano <gitster@pobox.com> | |
Sun, 17 Feb 2008 01:57:47 +0000 (17:57 -0800) | ||
committer | Junio 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
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 | patch | | | | diff2 | | blob | history |
help.c | patch | | diff1 | | diff2 | | blob | history |
diff --cc git-web--browse.sh
index 0000000000000000000000000000000000000000,fbf29cbe16a4c6b5fd78b12e130e4b06199ead71..1023b9085989aecfdcdc161232ee22de866d5f57
mode 000000,100755..100755
mode 000000,100755..100755
--- /dev/null
--- 2/git-web--browse.sh
+++ b/git-web--browse.sh
- 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