我知道我可以做git分支——所有,它显示了本地和远程分支,但它在显示它们之间的关系时并不是那么有用。

如何以显示哪个本地分支正在跟踪哪个远程的方式列出分支?


当前回答

对于当前的分支,这里有两个不错的选择:

% git rev-parse --abbrev-ref --symbolic-full-name @{u}
origin/mainline

or

% git for-each-ref --format='%(upstream:short)' $(git symbolic-ref -q HEAD)
origin/mainline

答案也在这里,对一个稍微不同的问题,被(错误地)标记为重复。

其他回答

如果你查看git-rev-parse的手册页,你会看到下面描述的语法:

<branchname>@{upstream},例如master@{upstream}, @{u} 分支名的后缀@{upstream} <branchname>@{u})指由指定的分支所指定的分支 Branchname设置为构建在。缺省情况下缺少分支名 到当前这个。

因此,要找到分支master的上游,你可以这样做:

git rev-parse --abbrev-ref master@{upstream}
# => origin/master

要打印出每个分支的信息,你可以这样做:

while read branch; do
  upstream=$(git rev-parse --abbrev-ref $branch@{upstream} 2>/dev/null)
  if [[ $? == 0 ]]; then
    echo $branch tracks $upstream
  else
    echo $branch has no upstream configured
  fi
done < <(git for-each-ref --format='%(refname:short)' refs/heads/*)

# Output:
# master tracks origin/master
# ...

这比手动解析引用和配置更简洁。

根据奥利维尔·雷法洛的回答

if [ $# -eq 2 ] 
then
    echo "Setting tracking for branch " $1 " -> " $2
    git branch --set-upstream $1 $2
else
    echo "-- Local --" 
    git for-each-ref --shell --format="[ %(upstream:short) != '' ] && echo -e '\t%(refname:short) <--> %(upstream:short)'" refs/heads | sh
    echo "-- Remote --" 
    REMOTES=$(git remote -v) 
    if [ "$REMOTES" != '' ]
    then
        echo $REMOTES
    fi  
fi

它只显示配置了轨道的本地。

把它写在你的路径上一个叫做git-track的脚本上,你会得到一个git track命令

https://github.com/albfan/git-showupstream上有更详细的版本

git for-each-ref --format='%(refname:short) <- %(upstream:short)' refs/heads

将为每个本地分支显示一行。一个跟踪分支看起来像这样:

master <- origin/master

一个非跟踪的是这样的:

test <- 

我用这个别名

git config --global alias.track '!f() { ([ $# -eq 2 ] && ( echo "Setting tracking for branch " $1 " -> " $2;git branch --set-upstream $1 $2; ) || ( git for-each-ref --format="local: %(refname:short) <--sync--> remote: %(upstream:short)" refs/heads && echo --Remotes && git remote -v)); }; f'

then

git track

这是一个非常瓷的命令,如果你想用它来编写脚本,那就不好了:

git branch -vv   # doubly verbose!

注意,在git 1.8.3中,上游分支显示为蓝色(参见“git中这个分支跟踪(如果有的话)是什么?”)


如果你想要干净的输出,请参阅Carl Suster的答案——它使用了一个瓷器命令,我不相信在我最初写这个答案的时候还存在这个命令,所以它更简洁一点,并且可以与配置为rebase的分支一起工作,而不仅仅是合并。