2011-02-18 167 views
1

我想获取远程分支的远程分支。提取远程远程分支和远程分支

因此,例如,在这种情况下 -

$ cd alpha 
$ git remote 
beta 
$ git branch -a 
master 
remotes/alpha/master 
$ cd ../beta 
$ git remote 
gamma 
$ git branch -a 
master 
remotes/gamma/slave 

- 我想通过beta去取水gammaslave支进alpha库。这可能会增加gamma作为alpha的远程,并使用gamma/slave作为新分支的参考。我不一定要创建一个本地跟踪分支。与示例中不同的是,我也不一定有文件系统访问betagamma

这样的事情可以用$ git clone --mirror完成,但有没有办法在已经存在的回购中做到这一点?

+0

我有点相同的情况;从上游获取一个回购,然后在本地克隆相同的回购。上游回购是巨大的,我在移动互联网上,所以我不想从上游获取所有分支机构。有几个问题“我如何获取所有远程分支机构?”有很多upvotes,简单的答案通常是普通的克隆/获取会做到这一点 - 但只有在使用“中央存储库”时才是这种情况。 – tobixen 2015-02-21 10:38:15

回答

0

它看起来像设置一个非默认的refspec会让我在那里。

例如,考虑这设置

  • 初始化gamma

    $ (mkdir gamma; cd gamma; git init; touch README; git add README; 
        git commit -m 'Initialized slave.'; git branch -m slave; echo) 
    Initialized empty Git repository in /tmp/test-git/gamma/.git/ 
    [master (root-commit) 0cebd50] Initialized slave. 
    0 files changed, 0 insertions(+), 0 deletions(-) 
    create mode 100644 README 
    
  • beta初始化并添加gamma作为远程:

    $ (mkdir beta; cd beta; git init; touch README; git add README; 
        git commit -m 'Initialized master.'; 
        git remote add gamma ../gamma; git fetch gamma 
        echo; echo "In repo $(basename $PWD):"; git branch -a; echo) 
    Initialized empty Git repository in /tmp/test-git/beta/.git/ 
    [master (root-commit) f6512e1] Initialized master. 
    0 files changed, 0 insertions(+), 0 deletions(-) 
    create mode 100644 README 
    warning: no common commits 
    remote: Counting objects: 3, done. 
    remote: Total 3 (delta 0), reused 0 (delta 0) 
    Unpacking objects: 100% (3/3), done. 
    From ../gamma 
    * [new branch]  slave  -> gamma/slave 
    
    In repo beta: 
    * master 
        remotes/gamma/slave 
    
  • 克隆beta使alpha

    $ git clone beta alpha 
    Initialized empty Git repository in /tmp/test-git/alpha/.git/ 
    $ cd alpha; git branch -a 
    * master 
        remotes/origin/HEAD -> origin/master 
        remotes/origin/master 
    

现在得到激烈:

# Avoid errors from pulling into active branch. 
$ git checkout origin/master | head -3 # intentionally acquire severed HEAD 
Note: checking out 'origin/master'. 

You are in 'detached HEAD' state. You can look around, make experimental 
$ git fetch origin '+refs/*:refs/*'  # pour steroids into open esophagus 
From /tmp/test-git/beta 
* [new branch]  gamma/slave -> gamma/slave 
$ git branch -a 
* (no branch) 
    master 
    remotes/gamma/slave 
    remotes/origin/HEAD -> origin/master 
    remotes/origin/master 
$ git remote 
origin 

所以做了`$混帐取 '+参/ :裁判/' 会拉在分支本身,但不会更新构成它所属远程的配置项。

有趣的是,设定追踪分支的remoteless远程分支将导致其开始跟踪自己的回购:

$ git branch --track slave gamma/slave 
Branch slave set up to track local ref refs/remotes/gamma/slave. 
$ git config -l | grep '^remote\|^branch' 
remote.origin.fetch=+refs/heads/*:refs/remotes/origin/* 
remote.origin.url=/tmp/test-git/beta 
branch.master.remote=origin 
branch.master.merge=refs/heads/master 
branch.slave.remote=. 
branch.slave.merge=refs/remotes/gamma/slave 

我觉得这并不真正发挥作用。

$ git checkout slave 
Switched to branch 'slave' 
$ git fetch 
From . 
* remote branch  gamma/slave -> FETCH_HEAD 
$ git fetch 
From . 
* remote branch  gamma/slave -> FETCH_HEAD