2005-05-22 22:03:24 +04:00
|
|
|
#!/bin/sh
|
|
|
|
#
|
2005-06-23 19:59:00 +04:00
|
|
|
destination=FETCH_HEAD
|
|
|
|
|
2005-05-22 22:03:24 +04:00
|
|
|
merge_repo=$1
|
|
|
|
merge_name=${2:-HEAD}
|
2005-06-23 19:59:00 +04:00
|
|
|
if [ "$2" = "tag" ]; then
|
|
|
|
merge_name="refs/tags/$3"
|
|
|
|
destination="$merge_name"
|
|
|
|
fi
|
2005-05-22 22:03:24 +04:00
|
|
|
|
|
|
|
: ${GIT_DIR=.git}
|
|
|
|
: ${GIT_OBJECT_DIRECTORY="${SHA1_FILE_DIRECTORY-"$GIT_DIR/objects"}"}
|
2005-07-05 22:38:37 +04:00
|
|
|
TMP_HEAD="$GIT_DIR/TMP_HEAD"
|
2005-05-22 22:03:24 +04:00
|
|
|
|
2005-07-05 22:38:37 +04:00
|
|
|
case "$merge_repo" in
|
|
|
|
http://*)
|
|
|
|
head=$(wget -q -O - "$merge_repo/$merge_name") || exit 1
|
2005-07-05 23:02:10 +04:00
|
|
|
echo Fetching $head using http
|
|
|
|
git-http-pull -v -a "$head" "$merge_repo/"
|
2005-07-05 22:38:37 +04:00
|
|
|
;;
|
|
|
|
rsync://*)
|
|
|
|
rsync -L "$merge_repo/$merge_name" "$TMP_HEAD" || exit 1
|
|
|
|
head=$(git-rev-parse TMP_HEAD)
|
|
|
|
rm -f "$TMP_HEAD"
|
|
|
|
rsync -avz --ignore-existing "$merge_repo/objects/" "$GIT_OBJECT_DIRECTORY/"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
head=$(git-fetch-pack "$merge_repo" "$merge_name")
|
|
|
|
;;
|
|
|
|
esac || exit 1
|
|
|
|
git-rev-parse --verify "$head" > /dev/null || exit 1
|
|
|
|
echo "$head" > "$GIT_DIR/$destination"
|