diff options
Diffstat (limited to 'Documentation/install-doc-quick.sh')
-rwxr-xr-x | Documentation/install-doc-quick.sh | 54 |
1 files changed, 31 insertions, 23 deletions
diff --git a/Documentation/install-doc-quick.sh b/Documentation/install-doc-quick.sh index a64054948a..327f69bcf5 100755 --- a/Documentation/install-doc-quick.sh +++ b/Documentation/install-doc-quick.sh @@ -1,31 +1,39 @@ #!/bin/sh -# This requires a branch named in $head -# (usually 'man' or 'html', provided by the git.git repository) -set -e -head="$1" -mandir="$2" -SUBDIRECTORY_OK=t -USAGE='<refname> <target directory>' -. git-sh-setup -export GIT_DIR +# This requires git-manpages and/or git-htmldocs repositories -test -z "$mandir" && usage -if ! git-rev-parse --verify "$head^0" >/dev/null; then - echo >&2 "head: $head does not exist in the current repository" - usage +repository=${1?repository} +destdir=${2?destination} + +head=master GIT_DIR= +for d in "$repository/.git" "$repository" +do + if GIT_DIR="$d" git rev-parse refs/heads/master >/dev/null 2>&1 + then + GIT_DIR="$d" + export GIT_DIR + break + fi +done + +if test -z "$GIT_DIR" +then + echo >&2 "Neither $repository nor $repository/.git is a repository" + exit 1 fi -GIT_INDEX_FILE=`pwd`/.quick-doc.index -export GIT_INDEX_FILE +GIT_WORK_TREE=$(pwd) +GIT_INDEX_FILE=$(pwd)/.quick-doc.$$ +export GIT_INDEX_FILE GIT_WORK_TREE rm -f "$GIT_INDEX_FILE" -git-read-tree $head -git-checkout-index -a -f --prefix="$mandir"/ +trap 'rm -f "$GIT_INDEX_FILE"' 0 + +git read-tree $head +git checkout-index -a -f --prefix="$destdir"/ -if test -n "$GZ"; then - cd "$mandir" - for i in `git-ls-tree -r --name-only $head` - do - gzip < $i > $i.gz && rm $i - done +if test -n "$GZ" +then + git ls-tree -r --name-only $head | + xargs printf "$destdir/%s\n" | + xargs gzip -f fi rm -f "$GIT_INDEX_FILE" |