如何在同一个文件系统中‘git reemote Add’并跟踪分支?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (15)

我在/a和in/b中有两个本地的git档案,它们是从远程/原点克隆的。

在/b上有一个新的分支

如何从归档/a跟踪和获取分支z?

我试过这个:

cd /a
git remote add b /b

这将创建2个配置条目,但我没有设法获取某些内容,也没有列出/a上显示/b上分支的远程分支。

在尝试了不同的事情之后,我发现以下几种方法有效:

1)git remote show b列出b中的所有远程分支。

2)我可以使用以下语法获取:

git fetch file:///a/ z

其他同样有效的事情:

$ cd /b
$ git checkout -b z
Switched to a new branch 'z'
$ git pull b z

但是这些命令仍然不起作用,我不明白为什么:

git branch -a 

不列出b中的远程分支(如原图所示)

git checkout -t b/z

不签出任何内容,但返回错误消息。

提问于
用户回答回答于

到目前为止,你只添加了b作为遥控器。你可以试试git branch -a在获取远程分支后列出它们。

下面是从b中签出z分支的命令:

git remote add b /b              # you've already done
git fetch b                      # get it so we can see it
git checkout -t b/z              # check out a local tracking branch

-t(或--track)创建跟踪分支,否则将处于分离头状态。

那么你应该看到:

/a$ git branch
  master
* z

对于那些不清楚所涉及的步骤的人,我做了以下的事情:

创造本源

$ mkdir origin
$ cd origin/
/origin$ git init --bare
Initialized empty Git repository in /origin/
/origin$ cd ..

克隆‘a’并添加一些内容

$ git clone origin/ a
Initialized empty Git repository in /a/.git/
warning: You appear to have cloned an empty repository.
$ cd a
/a$ echo hi there > hello
/a$ git add hello
/a$ git ci -m'first commit'
[master (root-commit) 0867b93] first commit
 1 files changed, 1 insertions(+), 0 deletions(-)
 create mode 100644 hello
/a$ git push origin master 
Counting objects: 3, done.
Writing objects: 100% (3/3), 210 bytes, done.
Total 3 (delta 0), reused 0 (delta 0)
Unpacking objects: 100% (3/3), done.
To /origin/
 * [new branch]      master -> master

克隆“b”并在新分支上添加更多内容

/a$ cd ..
$ git clone origin/ b
Initialized empty Git repository in /b/.git/
$ cd b
/b$ git checkout -b z
Switched to a new branch 'z'
/b$ echo new guy reporting in >> hello 
/b$ git ci -am "new recruits"
[z 81044ee] new recruits
 1 files changed, 1 insertions(+), 0 deletions(-)

在“a”中添加“b”作为遥控器

/b$ cd ../a
/a$ git remote add b ../b
/a$ git fetch b
remote: Counting objects: 5, done.
remote: Total 3 (delta 0), reused 0 (delta 0)
Unpacking objects: 100% (3/3), done.
From ../b
 * [new branch]      master     -> b/master
 * [new branch]      z          -> b/z
/a$ git br
* master
/a$ git checkout -t b/z
Branch z set up to track remote branch z from b.
Switched to a new branch 'z'
/a$ git br
  master
* z
用户回答回答于

我不认为你能做到。

我想你需要把分支z推到b的原点,然后从a处取出来。

cd /b
git push origin z

最后一个命令将本地分支z推送到远程(所以按z->原产地/z)

然后你可以在回购a中本地跟踪它:

cd /a
git checkout -b z origin/z

最后一个命令创建(并签出)一个局部跟踪起源/z的分支z

扫码关注云+社区