Junio C Hamano | ac4b0cf | 2005-08-20 02:52:24 -0700 | [diff] [blame] | 1 | #!/bin/sh |
| 2 | |
Junio C Hamano | e8cc80d | 2005-11-23 23:46:13 -0800 | [diff] [blame] | 3 | # git-ls-remote could be called from outside a git managed repository; |
| 4 | # this would fail in that case and would issue an error message. |
Dan Loewenherz | 7bd93c1 | 2009-04-22 21:46:02 -0400 | [diff] [blame] | 5 | GIT_DIR=$(git rev-parse -q --git-dir) || :; |
Junio C Hamano | ac4b0cf | 2005-08-20 02:52:24 -0700 | [diff] [blame] | 6 | |
| 7 | get_data_source () { |
| 8 | case "$1" in |
| 9 | */*) |
Junio C Hamano | ea560e6 | 2006-12-22 15:37:48 -0800 | [diff] [blame] | 10 | echo '' |
Junio C Hamano | ac4b0cf | 2005-08-20 02:52:24 -0700 | [diff] [blame] | 11 | ;; |
Paolo Bonzini | 9debc32 | 2007-03-15 09:23:20 +0100 | [diff] [blame] | 12 | .) |
| 13 | echo self |
| 14 | ;; |
Junio C Hamano | ac4b0cf | 2005-08-20 02:52:24 -0700 | [diff] [blame] | 15 | *) |
Junio C Hamano | 5be6007 | 2007-07-02 22:52:14 -0700 | [diff] [blame] | 16 | if test "$(git config --get "remote.$1.url")" |
Johannes Schindelin | 73136b2 | 2006-05-03 15:20:21 +0200 | [diff] [blame] | 17 | then |
| 18 | echo config |
| 19 | elif test -f "$GIT_DIR/remotes/$1" |
Junio C Hamano | ac4b0cf | 2005-08-20 02:52:24 -0700 | [diff] [blame] | 20 | then |
| 21 | echo remotes |
| 22 | elif test -f "$GIT_DIR/branches/$1" |
| 23 | then |
| 24 | echo branches |
| 25 | else |
| 26 | echo '' |
| 27 | fi ;; |
| 28 | esac |
| 29 | } |
| 30 | |
| 31 | get_remote_url () { |
| 32 | data_source=$(get_data_source "$1") |
| 33 | case "$data_source" in |
| 34 | '') |
Junio C Hamano | ea560e6 | 2006-12-22 15:37:48 -0800 | [diff] [blame] | 35 | echo "$1" |
Johannes Schindelin | 73136b2 | 2006-05-03 15:20:21 +0200 | [diff] [blame] | 36 | ;; |
Paolo Bonzini | 9debc32 | 2007-03-15 09:23:20 +0100 | [diff] [blame] | 37 | self) |
| 38 | echo "$1" |
| 39 | ;; |
Johannes Schindelin | 73136b2 | 2006-05-03 15:20:21 +0200 | [diff] [blame] | 40 | config) |
Junio C Hamano | 5be6007 | 2007-07-02 22:52:14 -0700 | [diff] [blame] | 41 | git config --get "remote.$1.url" |
Johannes Schindelin | 73136b2 | 2006-05-03 15:20:21 +0200 | [diff] [blame] | 42 | ;; |
Junio C Hamano | ac4b0cf | 2005-08-20 02:52:24 -0700 | [diff] [blame] | 43 | remotes) |
| 44 | sed -ne '/^URL: */{ |
| 45 | s///p |
| 46 | q |
Junio C Hamano | ea560e6 | 2006-12-22 15:37:48 -0800 | [diff] [blame] | 47 | }' "$GIT_DIR/remotes/$1" |
| 48 | ;; |
Junio C Hamano | ac4b0cf | 2005-08-20 02:52:24 -0700 | [diff] [blame] | 49 | branches) |
Junio C Hamano | ea560e6 | 2006-12-22 15:37:48 -0800 | [diff] [blame] | 50 | sed -e 's/#.*//' "$GIT_DIR/branches/$1" |
Junio C Hamano | ac4b0cf | 2005-08-20 02:52:24 -0700 | [diff] [blame] | 51 | ;; |
| 52 | *) |
| 53 | die "internal error: get-remote-url $1" ;; |
| 54 | esac |
| 55 | } |
| 56 | |
Santi Béjar | 648ad18 | 2006-09-23 12:05:43 +0200 | [diff] [blame] | 57 | get_default_remote () { |
Junio C Hamano | 5be6007 | 2007-07-02 22:52:14 -0700 | [diff] [blame] | 58 | curr_branch=$(git symbolic-ref -q HEAD | sed -e 's|^refs/heads/||') |
| 59 | origin=$(git config --get "branch.$curr_branch.remote") |
Santi Béjar | 648ad18 | 2006-09-23 12:05:43 +0200 | [diff] [blame] | 60 | echo ${origin:-origin} |
| 61 | } |
| 62 | |
Santi Béjar | 97af7ff | 2009-06-12 00:39:18 +0200 | [diff] [blame] | 63 | get_remote_merge_branch () { |
| 64 | case "$#" in |
| 65 | 0|1) |
Santi Béjar | e9460a6 | 2009-06-12 00:39:19 +0200 | [diff] [blame] | 66 | origin="$1" |
| 67 | default=$(get_default_remote) |
| 68 | test -z "$origin" && origin=$default |
| 69 | curr_branch=$(git symbolic-ref -q HEAD) |
| 70 | [ "$origin" = "$default" ] && |
| 71 | echo $(git for-each-ref --format='%(upstream)' $curr_branch) |
| 72 | ;; |
Santi Béjar | 97af7ff | 2009-06-12 00:39:18 +0200 | [diff] [blame] | 73 | *) |
| 74 | repo=$1 |
| 75 | shift |
| 76 | ref=$1 |
| 77 | # FIXME: It should return the tracking branch |
| 78 | # Currently only works with the default mapping |
| 79 | case "$ref" in |
| 80 | +*) |
| 81 | ref=$(expr "z$ref" : 'z+\(.*\)') |
| 82 | ;; |
| 83 | esac |
| 84 | expr "z$ref" : 'z.*:' >/dev/null || ref="${ref}:" |
| 85 | remote=$(expr "z$ref" : 'z\([^:]*\):') |
| 86 | case "$remote" in |
| 87 | '' | HEAD ) remote=HEAD ;; |
| 88 | heads/*) remote=${remote#heads/} ;; |
| 89 | refs/heads/*) remote=${remote#refs/heads/} ;; |
| 90 | refs/* | tags/* | remotes/* ) remote= |
| 91 | esac |
| 92 | |
| 93 | [ -n "$remote" ] && echo "refs/remotes/$repo/$remote" |
| 94 | esac |
| 95 | } |