Merge branch 'cc/help'
* cc/help: RPM spec: Adjust htmldir git-help -w: do not require to be in git repository git.spec.in: remove python_path Documentation: rename git.texi to user-manual.texi Add git-browse-help to .gitignore git-help -i: show info documentation from matching version of git git-help -i: invoke info with document and node name Documentation: add gitman.info target Documentation: describe -w/--web option to "git-help". Use {web,instaweb,help}.browser config options. git-help: add -w|--web option to display html man page in a browser. Documentation: describe -i/--info option to "git-help" git-help: add -i|--info option to display info page.maint
commit
467f42cfa1
|
@ -12,6 +12,7 @@ git-archive
|
||||||
git-bisect
|
git-bisect
|
||||||
git-blame
|
git-blame
|
||||||
git-branch
|
git-branch
|
||||||
|
git-browse-help
|
||||||
git-bundle
|
git-bundle
|
||||||
git-cat-file
|
git-cat-file
|
||||||
git-check-attr
|
git-check-attr
|
||||||
|
|
|
@ -5,7 +5,11 @@ MAN1_TXT= \
|
||||||
MAN5_TXT=gitattributes.txt gitignore.txt gitmodules.txt
|
MAN5_TXT=gitattributes.txt gitignore.txt gitmodules.txt
|
||||||
MAN7_TXT=git.txt
|
MAN7_TXT=git.txt
|
||||||
|
|
||||||
DOC_HTML=$(patsubst %.txt,%.html,$(MAN1_TXT) $(MAN5_TXT) $(MAN7_TXT))
|
MAN_TXT = $(MAN1_TXT) $(MAN5_TXT) $(MAN7_TXT)
|
||||||
|
MAN_XML=$(patsubst %.txt,%.xml,$(MAN_TXT))
|
||||||
|
MAN_HTML=$(patsubst %.txt,%.html,$(MAN_TXT))
|
||||||
|
|
||||||
|
DOC_HTML=$(MAN_HTML)
|
||||||
|
|
||||||
ARTICLES = tutorial
|
ARTICLES = tutorial
|
||||||
ARTICLES += tutorial-2
|
ARTICLES += tutorial-2
|
||||||
|
@ -29,6 +33,7 @@ DOC_MAN7=$(patsubst %.txt,%.7,$(MAN7_TXT))
|
||||||
|
|
||||||
prefix?=$(HOME)
|
prefix?=$(HOME)
|
||||||
bindir?=$(prefix)/bin
|
bindir?=$(prefix)/bin
|
||||||
|
htmldir?=$(prefix)/share/doc/git-doc
|
||||||
mandir?=$(prefix)/share/man
|
mandir?=$(prefix)/share/man
|
||||||
man1dir=$(mandir)/man1
|
man1dir=$(mandir)/man1
|
||||||
man5dir=$(mandir)/man5
|
man5dir=$(mandir)/man5
|
||||||
|
@ -79,7 +84,7 @@ man1: $(DOC_MAN1)
|
||||||
man5: $(DOC_MAN5)
|
man5: $(DOC_MAN5)
|
||||||
man7: $(DOC_MAN7)
|
man7: $(DOC_MAN7)
|
||||||
|
|
||||||
info: git.info
|
info: git.info gitman.info
|
||||||
|
|
||||||
install: man
|
install: man
|
||||||
$(INSTALL) -d -m 755 $(DESTDIR)$(man1dir)
|
$(INSTALL) -d -m 755 $(DESTDIR)$(man1dir)
|
||||||
|
@ -91,13 +96,17 @@ install: man
|
||||||
|
|
||||||
install-info: info
|
install-info: info
|
||||||
$(INSTALL) -d -m 755 $(DESTDIR)$(infodir)
|
$(INSTALL) -d -m 755 $(DESTDIR)$(infodir)
|
||||||
$(INSTALL) -m 644 git.info $(DESTDIR)$(infodir)
|
$(INSTALL) -m 644 git.info gitman.info $(DESTDIR)$(infodir)
|
||||||
if test -r $(DESTDIR)$(infodir)/dir; then \
|
if test -r $(DESTDIR)$(infodir)/dir; then \
|
||||||
$(INSTALL_INFO) --info-dir=$(DESTDIR)$(infodir) git.info ;\
|
$(INSTALL_INFO) --info-dir=$(DESTDIR)$(infodir) git.info ;\
|
||||||
|
$(INSTALL_INFO) --info-dir=$(DESTDIR)$(infodir) gitman.info ;\
|
||||||
else \
|
else \
|
||||||
echo "No directory found in $(DESTDIR)$(infodir)" >&2 ; \
|
echo "No directory found in $(DESTDIR)$(infodir)" >&2 ; \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
install-html: html
|
||||||
|
sh ./install-webdoc.sh $(DESTDIR)$(htmldir)
|
||||||
|
|
||||||
../GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE
|
../GIT-VERSION-FILE: .FORCE-GIT-VERSION-FILE
|
||||||
$(MAKE) -C ../ GIT-VERSION-FILE
|
$(MAKE) -C ../ GIT-VERSION-FILE
|
||||||
|
|
||||||
|
@ -161,12 +170,27 @@ XSLTOPTS = --xinclude --stringparam html.stylesheet docbook-xsl.css
|
||||||
user-manual.html: user-manual.xml
|
user-manual.html: user-manual.xml
|
||||||
xsltproc $(XSLTOPTS) -o $@ $(XSLT) $<
|
xsltproc $(XSLTOPTS) -o $@ $(XSLT) $<
|
||||||
|
|
||||||
git.info: user-manual.xml
|
git.info: user-manual.texi
|
||||||
$(RM) $@ $*.texi $*.texi+
|
$(MAKEINFO) --no-split -o $@ user-manual.texi
|
||||||
$(DOCBOOK2X_TEXI) user-manual.xml --to-stdout >$*.texi+
|
|
||||||
$(PERL_PATH) fix-texi.perl <$*.texi+ >$*.texi
|
user-manual.texi: user-manual.xml
|
||||||
|
$(RM) $@+ $@
|
||||||
|
$(DOCBOOK2X_TEXI) user-manual.xml --to-stdout | $(PERL_PATH) fix-texi.perl >$@+
|
||||||
|
mv $@+ $@
|
||||||
|
|
||||||
|
gitman.texi: $(MAN_XML) cat-texi.perl
|
||||||
|
$(RM) $@+ $@
|
||||||
|
($(foreach xml,$(MAN_XML),$(DOCBOOK2X_TEXI) --to-stdout $(xml);)) | \
|
||||||
|
$(PERL_PATH) cat-texi.perl $@ >$@+
|
||||||
|
mv $@+ $@
|
||||||
|
|
||||||
|
gitman.info: gitman.texi
|
||||||
$(MAKEINFO) --no-split $*.texi
|
$(MAKEINFO) --no-split $*.texi
|
||||||
$(RM) $*.texi $*.texi+
|
|
||||||
|
$(patsubst %.txt,%.texi,$(MAN_TXT)): %.texi : %.xml
|
||||||
|
$(RM) $@+ $@
|
||||||
|
$(DOCBOOK2X_TEXI) --to-stdout $*.xml >$@+
|
||||||
|
mv $@+ $@
|
||||||
|
|
||||||
howto-index.txt: howto-index.sh $(wildcard howto/*.txt)
|
howto-index.txt: howto-index.sh $(wildcard howto/*.txt)
|
||||||
$(RM) $@+ $@
|
$(RM) $@+ $@
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
#!/usr/bin/perl -w
|
||||||
|
|
||||||
|
my @menu = ();
|
||||||
|
my $output = $ARGV[0];
|
||||||
|
|
||||||
|
open TMP, '>', "$output.tmp";
|
||||||
|
|
||||||
|
while (<STDIN>) {
|
||||||
|
next if (/^\\input texinfo/../\@node Top/);
|
||||||
|
next if (/^\@bye/ || /^\.ft/);
|
||||||
|
if (s/^\@top (.*)/\@node $1,,,Top/) {
|
||||||
|
push @menu, $1;
|
||||||
|
}
|
||||||
|
s/\(\@pxref{\[URLS\]}\)//;
|
||||||
|
print TMP;
|
||||||
|
}
|
||||||
|
close TMP;
|
||||||
|
|
||||||
|
printf '\input texinfo
|
||||||
|
@setfilename gitman.info
|
||||||
|
@documentencoding us-ascii
|
||||||
|
@node Top,,%s
|
||||||
|
@top Git Manual Pages
|
||||||
|
@documentlanguage en
|
||||||
|
@menu
|
||||||
|
', $menu[0];
|
||||||
|
|
||||||
|
for (@menu) {
|
||||||
|
print "* ${_}::\n";
|
||||||
|
}
|
||||||
|
print "\@end menu\n";
|
||||||
|
open TMP, '<', "$output.tmp";
|
||||||
|
while (<TMP>) {
|
||||||
|
print;
|
||||||
|
}
|
||||||
|
close TMP;
|
||||||
|
print "\@bye\n";
|
||||||
|
unlink "$output.tmp";
|
|
@ -7,7 +7,7 @@ git-help - display help information about git
|
||||||
|
|
||||||
SYNOPSIS
|
SYNOPSIS
|
||||||
--------
|
--------
|
||||||
'git help' [-a|--all] [COMMAND]
|
'git help' [-a|--all|-i|--info|-w|--web] [COMMAND]
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
-----------
|
-----------
|
||||||
|
@ -20,7 +20,8 @@ If the option '--all' or '-a' is given, then all available commands are
|
||||||
printed on the standard output.
|
printed on the standard output.
|
||||||
|
|
||||||
If a git command is named, a manual page for that command is brought
|
If a git command is named, a manual page for that command is brought
|
||||||
up. The 'man' program is used by default for this purpose.
|
up. The 'man' program is used by default for this purpose, but this
|
||||||
|
can be overriden by other options.
|
||||||
|
|
||||||
Note that 'git --help ...' is identical as 'git help ...' because the
|
Note that 'git --help ...' is identical as 'git help ...' because the
|
||||||
former is internally converted into the latter.
|
former is internally converted into the latter.
|
||||||
|
@ -28,10 +29,31 @@ former is internally converted into the latter.
|
||||||
OPTIONS
|
OPTIONS
|
||||||
-------
|
-------
|
||||||
-a|--all::
|
-a|--all::
|
||||||
|
|
||||||
Prints all the available commands on the standard output. This
|
Prints all the available commands on the standard output. This
|
||||||
option superseeds any other option.
|
option superseeds any other option.
|
||||||
|
|
||||||
|
-i|--info::
|
||||||
|
Use the 'info' program to display the manual page, instead of
|
||||||
|
the 'man' program that is used by default.
|
||||||
|
|
||||||
|
-w|--web::
|
||||||
|
Use a web browser to display the HTML manual page, instead of
|
||||||
|
the 'man' program that is used by default.
|
||||||
|
+
|
||||||
|
The web browser can be specified using the configuration variable
|
||||||
|
'help.browser', or 'web.browser' if the former is not set. If none of
|
||||||
|
these config variables is set, the 'git-browse-help' script (called by
|
||||||
|
'git-help') will pick a suitable default.
|
||||||
|
+
|
||||||
|
You can explicitly provide a full path to your prefered browser by
|
||||||
|
setting the configuration variable 'browser.<tool>.path'. For example,
|
||||||
|
you can configure the absolute path to firefox by setting
|
||||||
|
'browser.firefox.path'. Otherwise, 'git-browse-help' assumes the tool
|
||||||
|
is available in PATH.
|
||||||
|
+
|
||||||
|
Note that the script tries, as much as possible, to display the HTML
|
||||||
|
page in a new tab on an already opened browser.
|
||||||
|
|
||||||
Author
|
Author
|
||||||
------
|
------
|
||||||
Written by Junio C Hamano <gitster@pobox.com> and the git-list
|
Written by Junio C Hamano <gitster@pobox.com> and the git-list
|
||||||
|
|
|
@ -71,6 +71,9 @@ You may specify configuration in your .git/config
|
||||||
|
|
||||||
-----------------------------------------------------------------------
|
-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
If the configuration variable 'instaweb.browser' is not set,
|
||||||
|
'web.browser' will be used instead if it is defined.
|
||||||
|
|
||||||
Author
|
Author
|
||||||
------
|
------
|
||||||
Written by Eric Wong <normalperson@yhbt.net>
|
Written by Eric Wong <normalperson@yhbt.net>
|
||||||
|
|
|
@ -104,6 +104,11 @@ OPTIONS
|
||||||
commands. If the option '--all' or '-a' is given then all
|
commands. If the option '--all' or '-a' is given then all
|
||||||
available commands are printed. If a git command is named this
|
available commands are printed. If a git command is named this
|
||||||
option will bring up the manual page for that command.
|
option will bring up the manual page for that command.
|
||||||
|
+
|
||||||
|
Other options are available to control how the manual page is
|
||||||
|
displayed. See gitlink:git-help[1] for more information,
|
||||||
|
because 'git --help ...' is converted internally into 'git
|
||||||
|
help ...'.
|
||||||
|
|
||||||
--exec-path::
|
--exec-path::
|
||||||
Path to wherever your core git programs are installed.
|
Path to wherever your core git programs are installed.
|
||||||
|
|
14
Makefile
14
Makefile
|
@ -155,9 +155,11 @@ STRIP ?= strip
|
||||||
prefix = $(HOME)
|
prefix = $(HOME)
|
||||||
bindir = $(prefix)/bin
|
bindir = $(prefix)/bin
|
||||||
mandir = $(prefix)/share/man
|
mandir = $(prefix)/share/man
|
||||||
|
infodir = $(prefix)/share/info
|
||||||
gitexecdir = $(bindir)
|
gitexecdir = $(bindir)
|
||||||
sharedir = $(prefix)/share
|
sharedir = $(prefix)/share
|
||||||
template_dir = $(sharedir)/git-core/templates
|
template_dir = $(sharedir)/git-core/templates
|
||||||
|
htmldir=$(sharedir)/doc/git-doc
|
||||||
ifeq ($(prefix),/usr)
|
ifeq ($(prefix),/usr)
|
||||||
sysconfdir = /etc
|
sysconfdir = /etc
|
||||||
else
|
else
|
||||||
|
@ -184,7 +186,7 @@ GITWEB_FAVICON = git-favicon.png
|
||||||
GITWEB_SITE_HEADER =
|
GITWEB_SITE_HEADER =
|
||||||
GITWEB_SITE_FOOTER =
|
GITWEB_SITE_FOOTER =
|
||||||
|
|
||||||
export prefix bindir gitexecdir sharedir template_dir sysconfdir
|
export prefix bindir gitexecdir sharedir template_dir htmldir sysconfdir
|
||||||
|
|
||||||
CC = gcc
|
CC = gcc
|
||||||
AR = ar
|
AR = ar
|
||||||
|
@ -224,7 +226,8 @@ SCRIPT_SH = \
|
||||||
git-merge-resolve.sh \
|
git-merge-resolve.sh \
|
||||||
git-lost-found.sh git-quiltimport.sh git-submodule.sh \
|
git-lost-found.sh git-quiltimport.sh git-submodule.sh \
|
||||||
git-filter-branch.sh \
|
git-filter-branch.sh \
|
||||||
git-stash.sh
|
git-stash.sh \
|
||||||
|
git-browse-help.sh
|
||||||
|
|
||||||
SCRIPT_PERL = \
|
SCRIPT_PERL = \
|
||||||
git-add--interactive.perl \
|
git-add--interactive.perl \
|
||||||
|
@ -748,8 +751,10 @@ ETC_GITCONFIG_SQ = $(subst ','\'',$(ETC_GITCONFIG))
|
||||||
DESTDIR_SQ = $(subst ','\'',$(DESTDIR))
|
DESTDIR_SQ = $(subst ','\'',$(DESTDIR))
|
||||||
bindir_SQ = $(subst ','\'',$(bindir))
|
bindir_SQ = $(subst ','\'',$(bindir))
|
||||||
mandir_SQ = $(subst ','\'',$(mandir))
|
mandir_SQ = $(subst ','\'',$(mandir))
|
||||||
|
infodir_SQ = $(subst ','\'',$(infodir))
|
||||||
gitexecdir_SQ = $(subst ','\'',$(gitexecdir))
|
gitexecdir_SQ = $(subst ','\'',$(gitexecdir))
|
||||||
template_dir_SQ = $(subst ','\'',$(template_dir))
|
template_dir_SQ = $(subst ','\'',$(template_dir))
|
||||||
|
htmldir_SQ = $(subst ','\'',$(htmldir))
|
||||||
prefix_SQ = $(subst ','\'',$(prefix))
|
prefix_SQ = $(subst ','\'',$(prefix))
|
||||||
|
|
||||||
SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
|
SHELL_PATH_SQ = $(subst ','\'',$(SHELL_PATH))
|
||||||
|
@ -795,7 +800,9 @@ git$X: git.o $(BUILTIN_OBJS) $(GITLIBS)
|
||||||
$(BUILTIN_OBJS) $(ALL_LDFLAGS) $(LIBS)
|
$(BUILTIN_OBJS) $(ALL_LDFLAGS) $(LIBS)
|
||||||
|
|
||||||
help.o: help.c common-cmds.h GIT-CFLAGS
|
help.o: help.c common-cmds.h GIT-CFLAGS
|
||||||
$(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) '-DGIT_MAN_PATH="$(mandir_SQ)"' $<
|
$(QUIET_CC)$(CC) -o $*.o -c $(ALL_CFLAGS) \
|
||||||
|
'-DGIT_MAN_PATH="$(mandir_SQ)"' \
|
||||||
|
'-DGIT_INFO_PATH="$(infodir_SQ)"' $<
|
||||||
|
|
||||||
git-merge-subtree$X: git-merge-recursive$X
|
git-merge-subtree$X: git-merge-recursive$X
|
||||||
$(QUIET_BUILT_IN)$(RM) $@ && ln git-merge-recursive$X $@
|
$(QUIET_BUILT_IN)$(RM) $@ && ln git-merge-recursive$X $@
|
||||||
|
@ -814,6 +821,7 @@ $(patsubst %.sh,%,$(SCRIPT_SH)) : % : %.sh
|
||||||
-e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \
|
-e 's|@@PERL@@|$(PERL_PATH_SQ)|g' \
|
||||||
-e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
|
-e 's/@@GIT_VERSION@@/$(GIT_VERSION)/g' \
|
||||||
-e 's/@@NO_CURL@@/$(NO_CURL)/g' \
|
-e 's/@@NO_CURL@@/$(NO_CURL)/g' \
|
||||||
|
-e 's|@@HTMLDIR@@|$(htmldir_SQ)|g' \
|
||||||
$@.sh >$@+ && \
|
$@.sh >$@+ && \
|
||||||
chmod +x $@+ && \
|
chmod +x $@+ && \
|
||||||
mv $@+ $@
|
mv $@+ $@
|
||||||
|
|
|
@ -0,0 +1,149 @@
|
||||||
|
#!/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] [cmd to display] ...'
|
||||||
|
|
||||||
|
# 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
|
||||||
|
|
||||||
|
# Install data.
|
||||||
|
html_dir="@@HTMLDIR@@"
|
||||||
|
|
||||||
|
test -f "$html_dir/git.html" || die "No documentation directory found."
|
||||||
|
|
||||||
|
valid_tool() {
|
||||||
|
case "$1" in
|
||||||
|
firefox | iceweasel | konqueror | w3m | links | lynx | dillo)
|
||||||
|
;; # happy
|
||||||
|
*)
|
||||||
|
return 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
init_browser_path() {
|
||||||
|
test -z "$GIT_DIR" || 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
|
||||||
|
;;
|
||||||
|
--)
|
||||||
|
break
|
||||||
|
;;
|
||||||
|
-*)
|
||||||
|
usage
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
break
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
|
||||||
|
if test -z "$browser" && test -n "$GIT_DIR"
|
||||||
|
then
|
||||||
|
for opt in "help.browser" "web.browser"
|
||||||
|
do
|
||||||
|
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
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
pages=$(for p in "$@"; do echo "$html_dir/$p.html" ; done)
|
||||||
|
test -z "$pages" && pages="$html_dir/git.html"
|
||||||
|
|
||||||
|
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=''
|
||||||
|
nohup "$browser_path" $NEWTAB $pages &
|
||||||
|
;;
|
||||||
|
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 $pages
|
||||||
|
;;
|
||||||
|
kfmclient)
|
||||||
|
eval "$browser_path" newTab $pages
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
nohup "$browser_path" $pages &
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
;;
|
||||||
|
w3m|links|lynx)
|
||||||
|
eval "$browser_path" $pages
|
||||||
|
;;
|
||||||
|
dillo)
|
||||||
|
nohup "$browser_path" $pages &
|
||||||
|
;;
|
||||||
|
esac
|
|
@ -24,6 +24,7 @@ fqgitdir="$GIT_DIR"
|
||||||
local="`git config --bool --get instaweb.local`"
|
local="`git config --bool --get instaweb.local`"
|
||||||
httpd="`git config --get instaweb.httpd`"
|
httpd="`git config --get instaweb.httpd`"
|
||||||
browser="`git config --get instaweb.browser`"
|
browser="`git config --get instaweb.browser`"
|
||||||
|
test -z "$browser" && browser="`git config --get web.browser`"
|
||||||
port=`git config --get instaweb.port`
|
port=`git config --get instaweb.port`
|
||||||
module_path="`git config --get instaweb.modulepath`"
|
module_path="`git config --get instaweb.modulepath`"
|
||||||
|
|
||||||
|
|
|
@ -122,26 +122,33 @@ get_author_ident_from_commit () {
|
||||||
LANG=C LC_ALL=C sed -ne "$pick_author_script"
|
LANG=C LC_ALL=C sed -ne "$pick_author_script"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Make sure we are in a valid repository of a vintage we understand.
|
# Make sure we are in a valid repository of a vintage we understand,
|
||||||
if [ -z "$SUBDIRECTORY_OK" ]
|
# if we require to be in a git repository.
|
||||||
|
if test -n "$NONGIT_OK"
|
||||||
then
|
then
|
||||||
|
if git rev-parse --git-dir >/dev/null 2>&1
|
||||||
|
then
|
||||||
|
: ${GIT_DIR=.git}
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
if [ -z "$SUBDIRECTORY_OK" ]
|
||||||
|
then
|
||||||
: ${GIT_DIR=.git}
|
: ${GIT_DIR=.git}
|
||||||
test -z "$(git rev-parse --show-cdup)" || {
|
test -z "$(git rev-parse --show-cdup)" || {
|
||||||
exit=$?
|
exit=$?
|
||||||
echo >&2 "You need to run this command from the toplevel of the working tree."
|
echo >&2 "You need to run this command from the toplevel of the working tree."
|
||||||
exit $exit
|
exit $exit
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
GIT_DIR=$(git rev-parse --git-dir) || {
|
GIT_DIR=$(git rev-parse --git-dir) || {
|
||||||
exit=$?
|
exit=$?
|
||||||
echo >&2 "Failed to find a valid git directory."
|
echo >&2 "Failed to find a valid git directory."
|
||||||
exit $exit
|
exit $exit
|
||||||
}
|
}
|
||||||
fi
|
fi
|
||||||
|
test -n "$GIT_DIR" && GIT_DIR=$(cd "$GIT_DIR" && pwd) || {
|
||||||
test -n "$GIT_DIR" && GIT_DIR=$(cd "$GIT_DIR" && pwd) || {
|
|
||||||
echo >&2 "Unable to determine absolute path of git directory"
|
echo >&2 "Unable to determine absolute path of git directory"
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
: ${GIT_OBJECT_DIRECTORY="$GIT_DIR/objects"}
|
||||||
: ${GIT_OBJECT_DIRECTORY="$GIT_DIR/objects"}
|
fi
|
||||||
|
|
15
git.spec.in
15
git.spec.in
|
@ -1,7 +1,5 @@
|
||||||
# Pass --without docs to rpmbuild if you don't want the documentation
|
# Pass --without docs to rpmbuild if you don't want the documentation
|
||||||
|
|
||||||
%define python_path /usr/bin/python
|
|
||||||
|
|
||||||
Name: git
|
Name: git
|
||||||
Version: @@VERSION@@
|
Version: @@VERSION@@
|
||||||
Release: 1%{?dist}
|
Release: 1%{?dist}
|
||||||
|
@ -85,20 +83,20 @@ BuildRequires: perl(Error)
|
||||||
%description -n perl-Git
|
%description -n perl-Git
|
||||||
Perl interface to Git
|
Perl interface to Git
|
||||||
|
|
||||||
|
%define path_settings ETC_GITCONFIG=/etc/gitconfig prefix=%{_prefix} mandir=%{_mandir} htmldir=%{_docdir}/%{name}-core-%{version}
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%setup -q
|
%setup -q
|
||||||
|
|
||||||
%build
|
%build
|
||||||
make %{_smp_mflags} CFLAGS="$RPM_OPT_FLAGS" \
|
make %{_smp_mflags} CFLAGS="$RPM_OPT_FLAGS" \
|
||||||
ETC_GITCONFIG=/etc/gitconfig \
|
%{path_settings} \
|
||||||
prefix=%{_prefix} all %{!?_without_docs: doc}
|
all %{!?_without_docs: doc}
|
||||||
|
|
||||||
%install
|
%install
|
||||||
rm -rf $RPM_BUILD_ROOT
|
rm -rf $RPM_BUILD_ROOT
|
||||||
make %{_smp_mflags} CFLAGS="$RPM_OPT_FLAGS" DESTDIR=$RPM_BUILD_ROOT \
|
make %{_smp_mflags} CFLAGS="$RPM_OPT_FLAGS" DESTDIR=$RPM_BUILD_ROOT \
|
||||||
prefix=%{_prefix} mandir=%{_mandir} \
|
%{path_settings} \
|
||||||
ETC_GITCONFIG=/etc/gitconfig \
|
|
||||||
PYTHON_PATH=%{python_path} \
|
|
||||||
INSTALLDIRS=vendor install %{!?_without_docs: install-doc}
|
INSTALLDIRS=vendor install %{!?_without_docs: install-doc}
|
||||||
find $RPM_BUILD_ROOT -type f -name .packlist -exec rm -f {} ';'
|
find $RPM_BUILD_ROOT -type f -name .packlist -exec rm -f {} ';'
|
||||||
find $RPM_BUILD_ROOT -type f -name '*.bs' -empty -exec rm -f {} ';'
|
find $RPM_BUILD_ROOT -type f -name '*.bs' -empty -exec rm -f {} ';'
|
||||||
|
@ -174,6 +172,9 @@ rm -rf $RPM_BUILD_ROOT
|
||||||
%{!?_without_docs: %doc Documentation/technical}
|
%{!?_without_docs: %doc Documentation/technical}
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Wed Dec 12 2007 Junio C Hamano <gitster@pobox.com>
|
||||||
|
- Adjust htmldir to point at /usr/share/doc/git-core-$version/
|
||||||
|
|
||||||
* Sun Jul 15 2007 Sean Estabrooks <seanlkml@sympatico.ca>
|
* Sun Jul 15 2007 Sean Estabrooks <seanlkml@sympatico.ca>
|
||||||
- Removed p4import.
|
- Removed p4import.
|
||||||
|
|
||||||
|
|
58
help.c
58
help.c
|
@ -239,6 +239,22 @@ void list_common_cmds_help(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *cmd_to_page(const char *git_cmd)
|
||||||
|
{
|
||||||
|
if (!git_cmd)
|
||||||
|
return "git";
|
||||||
|
else if (!prefixcmp(git_cmd, "git"))
|
||||||
|
return git_cmd;
|
||||||
|
else {
|
||||||
|
int page_len = strlen(git_cmd) + 4;
|
||||||
|
char *p = xmalloc(page_len + 1);
|
||||||
|
strcpy(p, "git-");
|
||||||
|
strcpy(p + 4, git_cmd);
|
||||||
|
p[page_len] = 0;
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void setup_man_path(void)
|
static void setup_man_path(void)
|
||||||
{
|
{
|
||||||
struct strbuf new_path;
|
struct strbuf new_path;
|
||||||
|
@ -262,23 +278,24 @@ static void setup_man_path(void)
|
||||||
|
|
||||||
static void show_man_page(const char *git_cmd)
|
static void show_man_page(const char *git_cmd)
|
||||||
{
|
{
|
||||||
const char *page;
|
const char *page = cmd_to_page(git_cmd);
|
||||||
|
|
||||||
if (!prefixcmp(git_cmd, "git"))
|
|
||||||
page = git_cmd;
|
|
||||||
else {
|
|
||||||
int page_len = strlen(git_cmd) + 4;
|
|
||||||
char *p = xmalloc(page_len + 1);
|
|
||||||
strcpy(p, "git-");
|
|
||||||
strcpy(p + 4, git_cmd);
|
|
||||||
p[page_len] = 0;
|
|
||||||
page = p;
|
|
||||||
}
|
|
||||||
|
|
||||||
setup_man_path();
|
setup_man_path();
|
||||||
execlp("man", "man", page, NULL);
|
execlp("man", "man", page, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void show_info_page(const char *git_cmd)
|
||||||
|
{
|
||||||
|
const char *page = cmd_to_page(git_cmd);
|
||||||
|
setenv("INFOPATH", GIT_INFO_PATH, 1);
|
||||||
|
execlp("info", "info", "gitman", page, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void show_html_page(const char *git_cmd)
|
||||||
|
{
|
||||||
|
const char *page = cmd_to_page(git_cmd);
|
||||||
|
execl_git_cmd("browse-help", page, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
void help_unknown_cmd(const char *cmd)
|
void help_unknown_cmd(const char *cmd)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "git: '%s' is not a git-command. See 'git --help'.\n", cmd);
|
fprintf(stderr, "git: '%s' is not a git-command. See 'git --help'.\n", cmd);
|
||||||
|
@ -293,18 +310,25 @@ int cmd_version(int argc, const char **argv, const char *prefix)
|
||||||
|
|
||||||
int cmd_help(int argc, const char **argv, const char *prefix)
|
int cmd_help(int argc, const char **argv, const char *prefix)
|
||||||
{
|
{
|
||||||
const char *help_cmd = argc > 1 ? argv[1] : NULL;
|
const char *help_cmd = argv[1];
|
||||||
|
|
||||||
if (!help_cmd) {
|
if (argc < 2) {
|
||||||
printf("usage: %s\n\n", git_usage_string);
|
printf("usage: %s\n\n", git_usage_string);
|
||||||
list_common_cmds_help();
|
list_common_cmds_help();
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (!strcmp(help_cmd, "--all") || !strcmp(help_cmd, "-a")) {
|
if (!strcmp(help_cmd, "--all") || !strcmp(help_cmd, "-a")) {
|
||||||
printf("usage: %s\n\n", git_usage_string);
|
printf("usage: %s\n\n", git_usage_string);
|
||||||
list_commands();
|
list_commands();
|
||||||
exit(0);
|
}
|
||||||
|
|
||||||
|
else if (!strcmp(help_cmd, "--web") || !strcmp(help_cmd, "-w")) {
|
||||||
|
show_html_page(argc > 2 ? argv[2] : NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (!strcmp(help_cmd, "--info") || !strcmp(help_cmd, "-i")) {
|
||||||
|
show_info_page(argc > 2 ? argv[2] : NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in New Issue