blob: b24119d69c092e3bd345cff1b6bafd48f5fd1e1b [file] [log] [blame]
Junio C Hamanoac4b0cf2005-08-20 02:52:24 -07001#!/bin/sh
2
Junio C Hamanoe8cc80d2005-11-23 23:46:13 -08003# 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 Loewenherz7bd93c12009-04-22 21:46:02 -04005GIT_DIR=$(git rev-parse -q --git-dir) || :;
Junio C Hamanoac4b0cf2005-08-20 02:52:24 -07006
Santi Béjar648ad182006-09-23 12:05:43 +02007get_default_remote () {
Stephen Boyd9ecd3ad2011-03-30 01:48:40 -07008 curr_branch=$(git symbolic-ref -q HEAD)
Junio C Hamano23525702011-03-30 19:33:33 -07009 curr_branch="${curr_branch#refs/heads/}"
Junio C Hamano5be60072007-07-02 22:52:14 -070010 origin=$(git config --get "branch.$curr_branch.remote")
Santi Béjar648ad182006-09-23 12:05:43 +020011 echo ${origin:-origin}
12}
13
Santi Béjar97af7ff2009-06-12 00:39:18 +020014get_remote_merge_branch () {
15 case "$#" in
16 0|1)
Santi Béjare9460a62009-06-12 00:39:19 +020017 origin="$1"
18 default=$(get_default_remote)
19 test -z "$origin" && origin=$default
Santi Béjarf864f262010-12-06 11:20:11 +010020 curr_branch=$(git symbolic-ref -q HEAD) &&
Santi Béjare9460a62009-06-12 00:39:19 +020021 [ "$origin" = "$default" ] &&
22 echo $(git for-each-ref --format='%(upstream)' $curr_branch)
23 ;;
Santi Béjar97af7ff2009-06-12 00:39:18 +020024 *)
25 repo=$1
26 shift
27 ref=$1
28 # FIXME: It should return the tracking branch
29 # Currently only works with the default mapping
30 case "$ref" in
31 +*)
32 ref=$(expr "z$ref" : 'z+\(.*\)')
33 ;;
34 esac
35 expr "z$ref" : 'z.*:' >/dev/null || ref="${ref}:"
36 remote=$(expr "z$ref" : 'z\([^:]*\):')
37 case "$remote" in
38 '' | HEAD ) remote=HEAD ;;
39 heads/*) remote=${remote#heads/} ;;
40 refs/heads/*) remote=${remote#refs/heads/} ;;
41 refs/* | tags/* | remotes/* ) remote=
42 esac
Martin von Zweigbergkfe249b42010-11-13 23:58:22 +010043 [ -n "$remote" ] && case "$repo" in
44 .)
45 echo "refs/heads/$remote"
46 ;;
47 *)
48 echo "refs/remotes/$repo/$remote"
49 ;;
50 esac
Santi Béjar97af7ff2009-06-12 00:39:18 +020051 esac
52}
Martin von Zweigbergk15a147e2011-02-09 20:54:02 -050053
54error_on_missing_default_upstream () {
55 cmd="$1"
56 op_type="$2"
57 op_prep="$3"
58 example="$4"
59 branch_name=$(git symbolic-ref -q HEAD)
60 if test -z "$branch_name"
61 then
62 echo "You are not currently on a branch, so I cannot use any
63'branch.<branchname>.merge' in your configuration file.
64Please specify which branch you want to $op_type $op_prep on the command
65line and try again (e.g. '$example').
66See git-${cmd}(1) for details."
67 else
68 echo "You asked me to $cmd without telling me which branch you
69want to $op_type $op_prep, and 'branch.${branch_name#refs/heads/}.merge' in
70your configuration file does not tell me, either. Please
71specify which branch you want to use on the command line and
72try again (e.g. '$example').
73See git-${cmd}(1) for details.
74
75If you often $op_type $op_prep the same branch, you may want to
76use something like the following in your configuration file:
77 [branch \"${branch_name#refs/heads/}\"]
78 remote = <nickname>
79 merge = <remote-ref>"
80 test rebase = "$op_type" &&
81 echo " rebase = true"
82 echo "
83 [remote \"<nickname>\"]
84 url = <url>
85 fetch = <refspec>
86
87See git-config(1) for details."
88 fi
89 exit 1
90}