github上fork别人的代码之后,如何保持和原作者同步的更新
1.从自己fork之后的版本库clone
$ git clone -o chucklu https://github.com/chucklu/Hearthstone-Deck-Tracker.git
参数说明:
-o <name>
Instead of using the remote name origin to keep track of the upstream repository, use <name>.
2.再将别人的版本库git remote add
2.1 $git remote add epix37 https://github.com/Epix37/Hearthstone-Deck-Tracker.git
2.2 $ git remote -v
chucklu https://github.com/chucklu/Hearthstone-Deck-Tracker.git (fetch)
chucklu https://github.com/chucklu/Hearthstone-Deck-Tracker.git (push)
epix37 https://github.com/Epix37/Hearthstone-Deck-Tracker.git (fetch)
epix37 https://github.com/Epix37/Hearthstone-Deck-Tracker.git (push)
3.本地分支和远端分支映射处理
$ git branch
chucklu_master
*master
chucklu_master分支用来对应自己远端的master分支
master分支用来对应原作者的master分支
(1)切换到master分支
git checkout master
首先确保目前处于master分支,上面的git branch就是查看本地分支的命令,master前面的*表示当前分支是master分支
(2)同步原作者的代码
git pull
(3)切换到chucklu_master分支
git checkout chucklu_master
(4)变基或者合并
git rebase master
git merge master
(5)推送代码到自己的版本库
git push chucklu HEAD:master或者
git push chucklu chucklu_master:master
假如自己fork版本库之后,已经在某个分支上进行了修改的话。
那么rebase就不适用,需要使用cherry-pick来处理。
为了确保cherry pick之后的代码,确实是自己所期望的,那么只需要对比一次,自己的分支的最后一次提交和原作者的分支的最后一次提交,看看差异,是否是自己额外修改导致的
使用tortoisegit-->diff with previous version
使用cherry-pick的注意事项,如果其中有某一个commit是合并导致的,那么这个commit就不需要进行cherry-pick
今天看到一篇文章,貌似cherry-pick不推荐使用
====9月13日更新====
如果你仅仅是同步原作者的master分支,而不需要进行合并操作的话,本地仅有一个分支也够用了
不过,需要添加2个remote
扩展:
重新命名远端git remote rename oldname newname
更多关于操作remote的命令,请参考http://www.ruanyifeng.com/blog/2014/06/git_remote.html
相关文章
- APICloud Github 5大开源项目集合展示
- 使用github与Octopress 搭建GitHub Pages博客
- GitHub如何使用
- eclipse 代码上传github 笔记
- [WebStrom] Create new project from GitHub
- [Github] Create a GitHub PR Template
- 搭建一个免费的,无限流量的Blog----github Pages和Jekyll入门
- 141. 如何在 SAP UI5 应用里安全存储一些敏感的数据,避免被上传到 Github 去的风险
- GitHub上那些值得一试的Java开源库
- GitHub 优秀的 Android 开源项目
- VScode 使用git Github
- Git----以github和gitee为例实现两个代码仓库同步
- 将Gitee项目导入到Github
- Github在开启2FA(双重身份验证)的时候Country- code 没有中国区+86的解决办法
- [Git & GitHub] 解决办法:error: failed to push some refs to 'https://github.com/xxxx.git'