| Linus Torvalds | 3f571e0 | 2005-06-23 01:49:43 | [diff] [blame] | 1 | #!/bin/sh |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 2 | # |
| 3 | # Copyright (c) 2005, Linus Torvalds |
| 4 | # Copyright (c) 2005, Junio C Hamano |
| 5 | # |
| 6 | # Clone a repository into a different directory that does not yet exist. |
| 7 | |
| Junio C Hamano | 365527a | 2005-09-13 02:47:07 | [diff] [blame] | 8 | # See git-sh-setup why. |
| 9 | unset CDPATH |
| 10 | |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 11 | usage() { |
| Yasushi SHOJI | 98a4fef | 2006-03-30 17:00:43 | [diff] [blame] | 12 | echo >&2 "Usage: $0 [--use-separate-remote] [--reference <reference-repo>] [--bare] [-l [-s]] [-q] [-u <upload-pack>] [--origin <name>] [-n] <repo> [<dir>]" |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 13 | exit 1 |
| 14 | } |
| 15 | |
| Linus Torvalds | ba375ac | 2005-07-08 22:46:33 | [diff] [blame] | 16 | get_repo_base() { |
| 17 | (cd "$1" && (cd .git ; pwd)) 2> /dev/null |
| 18 | } |
| 19 | |
| Junio C Hamano | 0516de3 | 2005-09-05 07:47:39 | [diff] [blame] | 20 | if [ -n "$GIT_SSL_NO_VERIFY" ]; then |
| 21 | curl_extra_args="-k" |
| 22 | fi |
| 23 | |
| 24 | http_fetch () { |
| 25 | # $1 = Remote, $2 = Local |
| Josef Weidendorfer | 66c9ec2 | 2005-11-10 13:12:19 | [diff] [blame] | 26 | curl -nsfL $curl_extra_args "$1" >"$2" |
| Junio C Hamano | 0516de3 | 2005-09-05 07:47:39 | [diff] [blame] | 27 | } |
| 28 | |
| 29 | clone_dumb_http () { |
| 30 | # $1 - remote, $2 - local |
| 31 | cd "$2" && |
| 32 | clone_tmp='.git/clone-tmp' && |
| 33 | mkdir -p "$clone_tmp" || exit 1 |
| Junio C Hamano | 0562110 | 2005-12-23 00:01:46 | [diff] [blame] | 34 | http_fetch "$1/info/refs" "$clone_tmp/refs" || { |
| Junio C Hamano | 0516de3 | 2005-09-05 07:47:39 | [diff] [blame] | 35 | echo >&2 "Cannot get remote repository information. |
| 36 | Perhaps git-update-server-info needs to be run there?" |
| 37 | exit 1; |
| 38 | } |
| Junio C Hamano | 0516de3 | 2005-09-05 07:47:39 | [diff] [blame] | 39 | while read sha1 refname |
| 40 | do |
| Mark Wooding | f327dbc | 2006-04-13 22:01:24 | [diff] [blame] | 41 | name=`expr "z$refname" : 'zrefs/\(.*\)'` && |
| Junio C Hamano | cdb3950 | 2005-10-18 04:47:06 | [diff] [blame] | 42 | case "$name" in |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 43 | *^*) continue;; |
| Junio C Hamano | cdb3950 | 2005-10-18 04:47:06 | [diff] [blame] | 44 | esac |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 45 | if test -n "$use_separate_remote" && |
| Mark Wooding | f327dbc | 2006-04-13 22:01:24 | [diff] [blame] | 46 | branch_name=`expr "z$name" : 'zheads/\(.*\)'` |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 47 | then |
| Junio C Hamano | 5ceb05f | 2006-03-21 09:58:26 | [diff] [blame] | 48 | tname="remotes/$origin/$branch_name" |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 49 | else |
| 50 | tname=$name |
| 51 | fi |
| 52 | git-http-fetch -v -a -w "$tname" "$name" "$1/" || exit 1 |
| Junio C Hamano | 0516de3 | 2005-09-05 07:47:39 | [diff] [blame] | 53 | done <"$clone_tmp/refs" |
| 54 | rm -fr "$clone_tmp" |
| Junio C Hamano | c72112e | 2006-04-02 23:25:01 | [diff] [blame] | 55 | http_fetch "$1/HEAD" "$GIT_DIR/REMOTE_HEAD" || |
| 56 | rm -f "$GIT_DIR/REMOTE_HEAD" |
| Junio C Hamano | 0516de3 | 2005-09-05 07:47:39 | [diff] [blame] | 57 | } |
| 58 | |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 59 | # Read git-fetch-pack -k output and store the remote branches. |
| 60 | copy_refs=' |
| 61 | use File::Path qw(mkpath); |
| 62 | use File::Basename qw(dirname); |
| 63 | my $git_dir = $ARGV[0]; |
| 64 | my $use_separate_remote = $ARGV[1]; |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 65 | my $origin = $ARGV[2]; |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 66 | |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 67 | my $branch_top = ($use_separate_remote ? "remotes/$origin" : "heads"); |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 68 | my $tag_top = "tags"; |
| 69 | |
| 70 | sub store { |
| 71 | my ($sha1, $name, $top) = @_; |
| 72 | $name = "$git_dir/refs/$top/$name"; |
| 73 | mkpath(dirname($name)); |
| 74 | open O, ">", "$name"; |
| 75 | print O "$sha1\n"; |
| 76 | close O; |
| 77 | } |
| 78 | |
| 79 | open FH, "<", "$git_dir/CLONE_HEAD"; |
| 80 | while (<FH>) { |
| 81 | my ($sha1, $name) = /^([0-9a-f]{40})\s(.*)$/; |
| 82 | next if ($name =~ /\^\173/); |
| 83 | if ($name eq "HEAD") { |
| 84 | open O, ">", "$git_dir/REMOTE_HEAD"; |
| 85 | print O "$sha1\n"; |
| 86 | close O; |
| 87 | next; |
| 88 | } |
| 89 | if ($name =~ s/^refs\/heads\///) { |
| 90 | store($sha1, $name, $branch_top); |
| 91 | next; |
| 92 | } |
| 93 | if ($name =~ s/^refs\/tags\///) { |
| 94 | store($sha1, $name, $tag_top); |
| 95 | next; |
| 96 | } |
| 97 | } |
| 98 | close FH; |
| 99 | ' |
| 100 | |
| Linus Torvalds | 167a4a3 | 2005-07-09 17:52:35 | [diff] [blame] | 101 | quiet= |
| Yasushi SHOJI | ef5b4ea | 2006-03-30 17:01:23 | [diff] [blame] | 102 | local=no |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 103 | use_local=no |
| Junio C Hamano | aae4f42 | 2005-08-15 00:25:57 | [diff] [blame] | 104 | local_shared=no |
| Junio C Hamano | 036a72d | 2005-09-27 00:17:09 | [diff] [blame] | 105 | no_checkout= |
| Junio C Hamano | 6ec311d | 2005-07-14 03:25:54 | [diff] [blame] | 106 | upload_pack= |
| Junio C Hamano | 87e80c4 | 2006-01-23 01:24:22 | [diff] [blame] | 107 | bare= |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 108 | reference= |
| 109 | origin= |
| Junio C Hamano | e6489a1 | 2006-01-23 01:28:49 | [diff] [blame] | 110 | origin_override= |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 111 | use_separate_remote= |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 112 | while |
| 113 | case "$#,$1" in |
| 114 | 0,*) break ;; |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 115 | *,-n|*,--no|*,--no-|*,--no-c|*,--no-ch|*,--no-che|*,--no-chec|\ |
| 116 | *,--no-check|*,--no-checko|*,--no-checkou|*,--no-checkout) |
| 117 | no_checkout=yes ;; |
| Junio C Hamano | 87e80c4 | 2006-01-23 01:24:22 | [diff] [blame] | 118 | *,--na|*,--nak|*,--nake|*,--naked|\ |
| 119 | *,-b|*,--b|*,--ba|*,--bar|*,--bare) bare=yes ;; |
| Junio C Hamano | 1cadb5a | 2005-07-23 02:11:22 | [diff] [blame] | 120 | *,-l|*,--l|*,--lo|*,--loc|*,--loca|*,--local) use_local=yes ;; |
| Junio C Hamano | aae4f42 | 2005-08-15 00:25:57 | [diff] [blame] | 121 | *,-s|*,--s|*,--sh|*,--sha|*,--shar|*,--share|*,--shared) |
| Pavel Roskin | 2c4ed38 | 2005-11-29 06:20:49 | [diff] [blame] | 122 | local_shared=yes; use_local=yes ;; |
| Linus Torvalds | 167a4a3 | 2005-07-09 17:52:35 | [diff] [blame] | 123 | *,-q|*,--quiet) quiet=-q ;; |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 124 | *,--use-separate-remote) |
| 125 | use_separate_remote=t ;; |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 126 | 1,--reference) usage ;; |
| 127 | *,--reference) |
| 128 | shift; reference="$1" ;; |
| 129 | *,--reference=*) |
| 130 | reference=`expr "$1" : '--reference=\(.*\)'` ;; |
| Yasushi SHOJI | 98a4fef | 2006-03-30 17:00:43 | [diff] [blame] | 131 | *,-o|*,--or|*,--ori|*,--orig|*,--origi|*,--origin) |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 132 | case "$2" in |
| Yasushi SHOJI | 98a4fef | 2006-03-30 17:00:43 | [diff] [blame] | 133 | '') |
| 134 | usage ;; |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 135 | */*) |
| 136 | echo >&2 "'$2' is not suitable for an origin name" |
| 137 | exit 1 |
| 138 | esac |
| 139 | git-check-ref-format "heads/$2" || { |
| Johannes Schindelin | e6c310f | 2005-12-22 22:37:24 | [diff] [blame] | 140 | echo >&2 "'$2' is not suitable for a branch name" |
| 141 | exit 1 |
| 142 | } |
| Junio C Hamano | e6489a1 | 2006-01-23 01:28:49 | [diff] [blame] | 143 | test -z "$origin_override" || { |
| Yasushi SHOJI | 98a4fef | 2006-03-30 17:00:43 | [diff] [blame] | 144 | echo >&2 "Do not give more than one --origin options." |
| Junio C Hamano | e6489a1 | 2006-01-23 01:28:49 | [diff] [blame] | 145 | exit 1 |
| 146 | } |
| 147 | origin_override=yes |
| Johannes Schindelin | e6c310f | 2005-12-22 22:37:24 | [diff] [blame] | 148 | origin="$2"; shift |
| 149 | ;; |
| Junio C Hamano | 1cadb5a | 2005-07-23 02:11:22 | [diff] [blame] | 150 | 1,-u|1,--upload-pack) usage ;; |
| Junio C Hamano | 6ec311d | 2005-07-14 03:25:54 | [diff] [blame] | 151 | *,-u|*,--upload-pack) |
| 152 | shift |
| Junio C Hamano | 1cadb5a | 2005-07-23 02:11:22 | [diff] [blame] | 153 | upload_pack="--exec=$1" ;; |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 154 | *,-*) usage ;; |
| 155 | *) break ;; |
| 156 | esac |
| 157 | do |
| 158 | shift |
| 159 | done |
| 160 | |
| Yasushi SHOJI | ef5b4ea | 2006-03-30 17:01:23 | [diff] [blame] | 161 | repo="$1" |
| 162 | if test -z "$repo" |
| 163 | then |
| 164 | echo >&2 'you must specify a repository to clone.' |
| 165 | exit 1 |
| 166 | fi |
| 167 | |
| Junio C Hamano | 87e80c4 | 2006-01-23 01:24:22 | [diff] [blame] | 168 | # --bare implies --no-checkout |
| Junio C Hamano | e6489a1 | 2006-01-23 01:28:49 | [diff] [blame] | 169 | if test yes = "$bare" |
| 170 | then |
| 171 | if test yes = "$origin_override" |
| 172 | then |
| Yasushi SHOJI | 98a4fef | 2006-03-30 17:00:43 | [diff] [blame] | 173 | echo >&2 '--bare and --origin $origin options are incompatible.' |
| Junio C Hamano | e6489a1 | 2006-01-23 01:28:49 | [diff] [blame] | 174 | exit 1 |
| 175 | fi |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 176 | if test t = "$use_separate_remote" |
| 177 | then |
| 178 | echo >&2 '--bare and --use-separate-remote options are incompatible.' |
| 179 | exit 1 |
| 180 | fi |
| Junio C Hamano | e6489a1 | 2006-01-23 01:28:49 | [diff] [blame] | 181 | no_checkout=yes |
| 182 | fi |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 183 | |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 184 | if test -z "$origin" |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 185 | then |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 186 | origin=origin |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 187 | fi |
| 188 | |
| Linus Torvalds | ba375ac | 2005-07-08 22:46:33 | [diff] [blame] | 189 | # Turn the source into an absolute path if |
| 190 | # it is local |
| Linus Torvalds | ba375ac | 2005-07-08 22:46:33 | [diff] [blame] | 191 | if base=$(get_repo_base "$repo"); then |
| 192 | repo="$base" |
| 193 | local=yes |
| 194 | fi |
| 195 | |
| Linus Torvalds | 3f571e0 | 2005-06-23 01:49:43 | [diff] [blame] | 196 | dir="$2" |
| Andreas Ericsson | 0879aa2 | 2005-11-10 11:58:08 | [diff] [blame] | 197 | # Try using "humanish" part of source repo if user didn't specify one |
| Uwe Zeisberger | e755578 | 2006-01-20 06:47:39 | [diff] [blame] | 198 | [ -z "$dir" ] && dir=$(echo "$repo" | sed -e 's|/$||' -e 's|:*/*\.git$||' -e 's|.*[/:]||g') |
| Josef Weidendorfer | b0c698a | 2005-11-13 14:03:31 | [diff] [blame] | 199 | [ -e "$dir" ] && echo "$dir already exists." && usage |
| Andreas Ericsson | 7f10f7c | 2005-11-10 11:58:08 | [diff] [blame] | 200 | mkdir -p "$dir" && |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 201 | D=$(cd "$dir" && pwd) && |
| Alex Riesen | edd3ebf | 2006-02-23 11:25:20 | [diff] [blame] | 202 | trap 'err=$?; cd ..; rm -r "$D"; exit $err' exit |
| Junio C Hamano | 87e80c4 | 2006-01-23 01:24:22 | [diff] [blame] | 203 | case "$bare" in |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 204 | yes) GIT_DIR="$D" ;; |
| 205 | *) GIT_DIR="$D/.git" ;; |
| 206 | esac && export GIT_DIR && git-init-db || usage |
| Junio C Hamano | 87e80c4 | 2006-01-23 01:24:22 | [diff] [blame] | 207 | case "$bare" in |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 208 | yes) |
| 209 | GIT_DIR="$D" ;; |
| 210 | *) |
| 211 | GIT_DIR="$D/.git" ;; |
| 212 | esac |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 213 | |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 214 | if test -n "$reference" |
| 215 | then |
| 216 | if test -d "$reference" |
| 217 | then |
| 218 | if test -d "$reference/.git/objects" |
| 219 | then |
| 220 | reference="$reference/.git" |
| 221 | fi |
| 222 | reference=$(cd "$reference" && pwd) |
| 223 | echo "$reference/objects" >"$GIT_DIR/objects/info/alternates" |
| 224 | (cd "$reference" && tar cf - refs) | |
| 225 | (cd "$GIT_DIR/refs" && |
| 226 | mkdir reference-tmp && |
| 227 | cd reference-tmp && |
| 228 | tar xf -) |
| 229 | else |
| 230 | echo >&2 "$reference: not a local directory." && usage |
| 231 | fi |
| 232 | fi |
| 233 | |
| 234 | rm -f "$GIT_DIR/CLONE_HEAD" |
| 235 | |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 236 | # We do local magic only when the user tells us to. |
| Linus Torvalds | ba375ac | 2005-07-08 22:46:33 | [diff] [blame] | 237 | case "$local,$use_local" in |
| 238 | yes,yes) |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 239 | ( cd "$repo/objects" ) || { |
| Junio C Hamano | ab6625e | 2005-07-11 20:30:54 | [diff] [blame] | 240 | echo >&2 "-l flag seen but $repo is not local." |
| 241 | exit 1 |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 242 | } |
| 243 | |
| Junio C Hamano | aae4f42 | 2005-08-15 00:25:57 | [diff] [blame] | 244 | case "$local_shared" in |
| 245 | no) |
| 246 | # See if we can hardlink and drop "l" if not. |
| 247 | sample_file=$(cd "$repo" && \ |
| 248 | find objects -type f -print | sed -e 1q) |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 249 | |
| Junio C Hamano | aae4f42 | 2005-08-15 00:25:57 | [diff] [blame] | 250 | # objects directory should not be empty since we are cloning! |
| 251 | test -f "$repo/$sample_file" || exit |
| Junio C Hamano | e95ab1e | 2005-07-06 20:04:21 | [diff] [blame] | 252 | |
| Junio C Hamano | aae4f42 | 2005-08-15 00:25:57 | [diff] [blame] | 253 | l= |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 254 | if ln "$repo/$sample_file" "$GIT_DIR/objects/sample" 2>/dev/null |
| Junio C Hamano | aae4f42 | 2005-08-15 00:25:57 | [diff] [blame] | 255 | then |
| 256 | l=l |
| 257 | fi && |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 258 | rm -f "$GIT_DIR/objects/sample" && |
| Junio C Hamano | aae4f42 | 2005-08-15 00:25:57 | [diff] [blame] | 259 | cd "$repo" && |
| Johannes Schindelin | 8e1618f | 2006-02-17 14:22:45 | [diff] [blame] | 260 | find objects -depth -print | cpio -pumd$l "$GIT_DIR/" || exit 1 |
| Junio C Hamano | aae4f42 | 2005-08-15 00:25:57 | [diff] [blame] | 261 | ;; |
| 262 | yes) |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 263 | mkdir -p "$GIT_DIR/objects/info" |
| Junio C Hamano | 0f87f89 | 2005-08-17 22:18:41 | [diff] [blame] | 264 | { |
| 265 | test -f "$repo/objects/info/alternates" && |
| 266 | cat "$repo/objects/info/alternates"; |
| 267 | echo "$repo/objects" |
| Martin Waitz | cf9dc65 | 2006-05-07 18:19:09 | [diff] [blame] | 268 | } >>"$GIT_DIR/objects/info/alternates" |
| Junio C Hamano | aae4f42 | 2005-08-15 00:25:57 | [diff] [blame] | 269 | ;; |
| 270 | esac |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 271 | git-ls-remote "$repo" >"$GIT_DIR/CLONE_HEAD" |
| Linus Torvalds | 7558ef8 | 2005-07-09 00:07:12 | [diff] [blame] | 272 | ;; |
| 273 | *) |
| Junio C Hamano | 1cadb5a | 2005-07-23 02:11:22 | [diff] [blame] | 274 | case "$repo" in |
| 275 | rsync://*) |
| Junio C Hamano | 4447bad | 2005-09-17 18:56:41 | [diff] [blame] | 276 | rsync $quiet -av --ignore-existing \ |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 277 | --exclude info "$repo/objects/" "$GIT_DIR/objects/" || |
| 278 | exit |
| Junio C Hamano | 4447bad | 2005-09-17 18:56:41 | [diff] [blame] | 279 | # Look at objects/info/alternates for rsync -- http will |
| 280 | # support it natively and git native ones will do it on the |
| 281 | # remote end. Not having that file is not a crime. |
| Junio C Hamano | 89d844d | 2005-09-20 06:52:33 | [diff] [blame] | 282 | rsync -q "$repo/objects/info/alternates" \ |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 283 | "$GIT_DIR/TMP_ALT" 2>/dev/null || |
| 284 | rm -f "$GIT_DIR/TMP_ALT" |
| 285 | if test -f "$GIT_DIR/TMP_ALT" |
| Junio C Hamano | 4447bad | 2005-09-17 18:56:41 | [diff] [blame] | 286 | then |
| Pavel Roskin | 0e9ab02 | 2005-11-11 05:19:04 | [diff] [blame] | 287 | ( cd "$D" && |
| Junio C Hamano | 4447bad | 2005-09-17 18:56:41 | [diff] [blame] | 288 | . git-parse-remote && |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 289 | resolve_alternates "$repo" <"$GIT_DIR/TMP_ALT" ) | |
| Junio C Hamano | 4447bad | 2005-09-17 18:56:41 | [diff] [blame] | 290 | while read alt |
| 291 | do |
| 292 | case "$alt" in 'bad alternate: '*) die "$alt";; esac |
| 293 | case "$quiet" in |
| 294 | '') echo >&2 "Getting alternate: $alt" ;; |
| 295 | esac |
| 296 | rsync $quiet -av --ignore-existing \ |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 297 | --exclude info "$alt" "$GIT_DIR/objects" || exit |
| Junio C Hamano | 4447bad | 2005-09-17 18:56:41 | [diff] [blame] | 298 | done |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 299 | rm -f "$GIT_DIR/TMP_ALT" |
| Junio C Hamano | 4447bad | 2005-09-17 18:56:41 | [diff] [blame] | 300 | fi |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 301 | git-ls-remote "$repo" >"$GIT_DIR/CLONE_HEAD" |
| Junio C Hamano | 1cadb5a | 2005-07-23 02:11:22 | [diff] [blame] | 302 | ;; |
| 303 | http://*) |
| Fernando J. Pereda | 6c5c62f | 2006-02-15 11:37:30 | [diff] [blame] | 304 | if test -z "@@NO_CURL@@" |
| 305 | then |
| 306 | clone_dumb_http "$repo" "$D" |
| 307 | else |
| 308 | echo >&2 "http transport not supported, rebuild Git with curl support" |
| 309 | exit 1 |
| 310 | fi |
| Junio C Hamano | 1cadb5a | 2005-07-23 02:11:22 | [diff] [blame] | 311 | ;; |
| 312 | *) |
| 313 | cd "$D" && case "$upload_pack" in |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 314 | '') git-fetch-pack --all -k $quiet "$repo" ;; |
| 315 | *) git-fetch-pack --all -k $quiet "$upload_pack" "$repo" ;; |
| 316 | esac >"$GIT_DIR/CLONE_HEAD" || { |
| 317 | echo >&2 "fetch-pack from '$repo' failed." |
| Junio C Hamano | 0a8b4de | 2005-12-13 23:58:00 | [diff] [blame] | 318 | exit 1 |
| 319 | } |
| Junio C Hamano | 1cadb5a | 2005-07-23 02:11:22 | [diff] [blame] | 320 | ;; |
| Junio C Hamano | 6ec311d | 2005-07-14 03:25:54 | [diff] [blame] | 321 | esac |
| Linus Torvalds | 7558ef8 | 2005-07-09 00:07:12 | [diff] [blame] | 322 | ;; |
| 323 | esac |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 324 | test -d "$GIT_DIR/refs/reference-tmp" && rm -fr "$GIT_DIR/refs/reference-tmp" |
| 325 | |
| 326 | if test -f "$GIT_DIR/CLONE_HEAD" |
| 327 | then |
| Junio C Hamano | c72112e | 2006-04-02 23:25:01 | [diff] [blame] | 328 | # Read git-fetch-pack -k output and store the remote branches. |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 329 | perl -e "$copy_refs" "$GIT_DIR" "$use_separate_remote" "$origin" |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 330 | fi |
| Junio C Hamano | 1cadb5a | 2005-07-23 02:11:22 | [diff] [blame] | 331 | |
| Pavel Roskin | 0e9ab02 | 2005-11-11 05:19:04 | [diff] [blame] | 332 | cd "$D" || exit |
| Junio C Hamano | 036a72d | 2005-09-27 00:17:09 | [diff] [blame] | 333 | |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 334 | if test -z "$bare" && test -f "$GIT_DIR/REMOTE_HEAD" |
| Junio C Hamano | 036a72d | 2005-09-27 00:17:09 | [diff] [blame] | 335 | then |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 336 | # Figure out which remote branch HEAD points at. |
| 337 | case "$use_separate_remote" in |
| 338 | '') remote_top=refs/heads ;; |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 339 | *) remote_top="refs/remotes/$origin" ;; |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 340 | esac |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 341 | |
| Junio C Hamano | c72112e | 2006-04-02 23:25:01 | [diff] [blame] | 342 | head_sha1=`cat "$GIT_DIR/REMOTE_HEAD"` |
| 343 | case "$head_sha1" in |
| 344 | 'ref: refs/'*) |
| 345 | # Uh-oh, the remote told us (http transport done against |
| 346 | # new style repository with a symref HEAD). |
| 347 | # Ideally we should skip the guesswork but for now |
| 348 | # opt for minimum change. |
| Mark Wooding | f327dbc | 2006-04-13 22:01:24 | [diff] [blame] | 349 | head_sha1=`expr "z$head_sha1" : 'zref: refs/heads/\(.*\)'` |
| Junio C Hamano | c72112e | 2006-04-02 23:25:01 | [diff] [blame] | 350 | head_sha1=`cat "$GIT_DIR/$remote_top/$head_sha1"` |
| 351 | ;; |
| 352 | esac |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 353 | |
| Junio C Hamano | c72112e | 2006-04-02 23:25:01 | [diff] [blame] | 354 | # The name under $remote_top the remote HEAD seems to point at. |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 355 | head_points_at=$( |
| 356 | ( |
| 357 | echo "master" |
| 358 | cd "$GIT_DIR/$remote_top" && |
| 359 | find . -type f -print | sed -e 's/^\.\///' |
| 360 | ) | ( |
| 361 | done=f |
| 362 | while read name |
| 363 | do |
| 364 | test t = $done && continue |
| 365 | branch_tip=`cat "$GIT_DIR/$remote_top/$name"` |
| 366 | if test "$head_sha1" = "$branch_tip" |
| 367 | then |
| 368 | echo "$name" |
| 369 | done=t |
| 370 | fi |
| 371 | done |
| 372 | ) |
| 373 | ) |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 374 | |
| Junio C Hamano | c72112e | 2006-04-02 23:25:01 | [diff] [blame] | 375 | # Write out remotes/$origin file, and update our "$head_points_at". |
| Junio C Hamano | e125c1a | 2005-11-02 06:19:36 | [diff] [blame] | 376 | case "$head_points_at" in |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 377 | ?*) |
| Junio C Hamano | 8a1a120 | 2006-01-15 00:00:32 | [diff] [blame] | 378 | mkdir -p "$GIT_DIR/remotes" && |
| Junio C Hamano | c72112e | 2006-04-02 23:25:01 | [diff] [blame] | 379 | git-symbolic-ref HEAD "refs/heads/$head_points_at" && |
| 380 | case "$use_separate_remote" in |
| 381 | t) origin_track="$remote_top/$head_points_at" |
| 382 | git-update-ref HEAD "$head_sha1" ;; |
| 383 | *) origin_track="$remote_top/$origin" |
| 384 | git-update-ref "refs/heads/$origin" "$head_sha1" ;; |
| 385 | esac && |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 386 | echo >"$GIT_DIR/remotes/$origin" \ |
| Junio C Hamano | e125c1a | 2005-11-02 06:19:36 | [diff] [blame] | 387 | "URL: $repo |
| Junio C Hamano | c72112e | 2006-04-02 23:25:01 | [diff] [blame] | 388 | Pull: refs/heads/$head_points_at:$origin_track" && |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 389 | (cd "$GIT_DIR/$remote_top" && find . -type f -print) | |
| 390 | while read dotslref |
| Junio C Hamano | 95d117b | 2005-11-06 08:52:57 | [diff] [blame] | 391 | do |
| Junio C Hamano | 47874d6 | 2006-03-21 08:14:13 | [diff] [blame] | 392 | name=`expr "$dotslref" : './\(.*\)'` && |
| Junio C Hamano | c72112e | 2006-04-02 23:25:01 | [diff] [blame] | 393 | test "$use_separate_remote" = '' && { |
| 394 | test "$head_points_at" = "$name" || |
| 395 | test "$origin" = "$name" |
| 396 | } || |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 397 | echo "Pull: refs/heads/${name}:$remote_top/${name}" |
| Junio C Hamano | 5ceb05f | 2006-03-21 09:58:26 | [diff] [blame] | 398 | done >>"$GIT_DIR/remotes/$origin" && |
| 399 | case "$use_separate_remote" in |
| 400 | t) |
| 401 | rm -f "refs/remotes/$origin/HEAD" |
| 402 | git-symbolic-ref "refs/remotes/$origin/HEAD" \ |
| 403 | "refs/remotes/$origin/$head_points_at" |
| 404 | esac |
| Junio C Hamano | e125c1a | 2005-11-02 06:19:36 | [diff] [blame] | 405 | esac |
| 406 | |
| Junio C Hamano | 036a72d | 2005-09-27 00:17:09 | [diff] [blame] | 407 | case "$no_checkout" in |
| 408 | '') |
| Junio C Hamano | 744633c | 2006-02-23 03:02:39 | [diff] [blame] | 409 | git-read-tree -m -u -v HEAD HEAD |
| Junio C Hamano | 036a72d | 2005-09-27 00:17:09 | [diff] [blame] | 410 | esac |
| 411 | fi |
| Junio C Hamano | dfeff66 | 2006-03-20 08:21:10 | [diff] [blame] | 412 | rm -f "$GIT_DIR/CLONE_HEAD" "$GIT_DIR/REMOTE_HEAD" |
| Carl Worth | 41ff7a1 | 2006-02-17 21:33:24 | [diff] [blame] | 413 | |
| 414 | trap - exit |
| 415 | |