我最终得到了一个处于我不知道如何处理的状态的 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
这让我很困惑。为什么我的分支在 origin master 之前?我没有改变任何东西。
为了看看我能不能做点什么,我跑了git lg
(git 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
我又回到了我开始的地方。
这里发生了什么?我应该怎么做才能使我的本地 master 拥有来自上游的最新更新?