git似乎没有拉出所有更新 - HEAD和origin / HEAD在不同的位置

时间:2013-05-11 02:03:33

标签: git github git-pull

我最终得到的git存储库处于一个我不知道如何处理的状态,我需要一些帮助来理解a)发生了什么,存储库处于这种状态的方式和原因,以及b)如何我应该对此做出反应。基本上,当从遥控器拉出时,即使我重置所有更改并重试,我也会在遥控器前面结束。

这就是我所做的:

我已经分叉了一个git存储库,克隆了上游版本(我没有写访问权限),然后将我自己的fork添加到远程列表中,以便git remote -v显示以下内容:

$ git remote -v
mine    git@github.com:tlycken/julia.git (fetch)
mine    git@github.com:tlycken/julia.git (push)
origin  git://github.com/JuliaLang/julia.git (fetch)
origin  git://github.com/JuliaLang/julia.git (push)

我现在想确保我的本地版本与上游仓库中的所有内容保持同步,所以我运行

$ git pull origin master
From git://github.com/JuliaLang/julia
 * branch            master     -> FETCH_HEAD
Already up-to-date.
tlycken$ git status
# On branch master
# Your branch is ahead of 'origin/master' by 4 commits.
#   (use "git push" to publish your local commits)
#
nothing to commit, working directory clean

这让我很困惑。为什么我的分支领先于原点大师?我没有改变任何事情。

为了了解我是否可以采取行动,我运行git lggit log --graph的别名,带有一些漂亮的印记)。输出的顶部如下所示:

*   6912a42 - (HEAD, mine/master, master) Merge pull request #3052 from daviddelaat/linalgnumber (2013-05-10 11:23:09 -0700) <Viral B. Shah>
|\  
| * 8116d51 - Use Number instead of Integer in some linalg operations (2013-05-10 19:12:45 +0200) <David de Laat>
* | 6cc1532 - Update .travis.yml configuration in the manual. (2013-05-10 21:41:59 +0530) <Viral B. Shah>
* | fa1e3fe - Update logdet. Close #3070. (2013-05-10 19:35:37 +0530) <Viral B. Shah>
* |   a182f7f - (origin/master, origin/HEAD, mine/contrib-base) Merge branch 'master' of github.com:JuliaLang/julia (2013-05-10 03:10:38 -0400) <Jeff Bezanson>

显然,HEAD处于不同的位置。为了确保在开始分支之前我在本地存储库中获得了正确的代码,我git reset --hard origin/HEAD删除了我前面的任何内容,然后git pull origin master以确保我是最新的(即没有重置太远或什么的):

$ git pull origin master
From git://github.com/JuliaLang/julia
 * branch            master     -> FETCH_HEAD
Updating a182f7f..6912a42
Fast-forward
 base/linalg/dense.jl         |  2 +-
 base/linalg/factorization.jl | 44 ++++++++++++++++++++++----------------------
 doc/manual/packages.rst      |  3 +--
 3 files changed, 24 insertions(+), 25 deletions(-)
$ git status
# On branch master
# Your branch is ahead of 'origin/master' by 4 commits.
#   (use "git push" to publish your local commits)
#
nothing to commit, working directory clean

我回到了我开始的地方。

这里发生了什么?我该怎么做才能进入我的本地主人从上游获得最新更新的状态?

1 个答案:

答案 0 :(得分:11)

git pull不会更新跟踪裁判(origin/ ...),以跟踪各种遥控器“HEAD的位置。

运行git fetch origin,它会更新所有origin/ ...跟踪参考号,git status将不再认为您处于领先地位。


git pull <remote> <branch>相当于:

  1. git fetch <remote> <branch>:FETCH_HEAD
  2. git merge FETCH_HEAD
  3. 因为它只显式指定了一个要获取的分支,并将其提取到特殊的本地引用FETCH_HEAD中,所以它不会在本地更新任何其他内容 - 只有FETCH_HEAD和你要拉的分支成。

    运行git fetch <remote>将更新与该远程存储库关联的所有引用。