更新github上fork的项目
Github Fork 过程概述
在Github上有很多优秀的开源项目,相信每一位热衷于技术的朋友都会在Github上Fork一些感兴趣的项目,然后在本地修改并提交。本文以spring-framework为例,在Github上Fork该项目,更新提交的一个完整过程如下图所示:
- Fork一个项目,比如spring-framework,该操作会复制该项目的所有历史提交内容到个人仓库中,并生成一个相同的项目;
- Clone之前Fork的项目到本地计算机中;
- 在本地仓库中更新某些文件;
- 提交更新的文件到本地仓库;
- 将本地仓库的更改内容推送push到个人github远程仓库;
- 创建pull请求,既可以同步更新fork的原始项目中别人的更新到自己的github仓库中,也可以提交个人更新的内容到fork的原始项目。
Fork问题
我Fork的 spring-framework项目如下:
spring-framework项目最新进展如下:
可以看到在我Fork以后spring-framework有了很大新的代码提交,本文就是想简单介绍一下,如何同被Fork的项目保持同步更新,将以spring-framework项目为例。
保持Fork同步更新
1.打开自己的github中Fork的项目,打开Code选项卡,点击下面的New pull request创建一个新的pull请求;
2.打开Comparing chanages,默认如下图所示,这时base fork是你fork的项目,二head fork是你自己的仓库。
3.在上图中进行选择,前面选择base-fork选择自己的github仓库的spring-framework项目,会出现下图所示,这时需要点击compare across forks,并进行选择。
4.具体选择如下:base:master是自己仓库和分支,后面选择head fork,compare:master是你fork项目来源的仓库和分支,可以对比两个项目前后的变化情况。然后点击Create pull request,创建新的pull请求。
5.填写标题Title和评论Comment,并点击Create pull request。Preview可以预览评论效果,右侧有5个选项可以设置Reviewers检阅用户、Assignees分配给哪个用户、Labels标签(bug、duplocate、enhancement、help wanted、invalid、question、wontfix,也支持自定义)、Projects项目、Milestone里程碑事件。
6.点击Create pull request之后,就可以在Pull request中看到刚才提交的comment,如下所示:
可以期间有很多更新,往下翻可以找到如下图所示,点击Merge pull request即可。
填写Merge的评论并且提交,如果有冲突一定要先解决冲突,然后就全部OK了。
最后,再次打开自己仓库的spring-framework项目,可以看到项目已更新到最新版本,和最开始spring-framework原始项目内容一致了。
总结
本文详细讲解了同步更新Github上Fork项目的其中一种方法,还有其他的方法比如可以删除个人github中fork的该项目然后重新fork,这种方式不能合并自己已更新的代码;还有另外一种方式是在本地建立两个仓库,把两个远程库都clone到本地,然后拉取原fork项目更新到本地,合并更新,最后push到你个人的github即可。
版权声明:
作者:xiaoniba
链接:https://blog.xiaoniba.com/2019/09/17/%e6%9b%b4%e6%96%b0github%e4%b8%8afork%e7%9a%84%e9%a1%b9%e7%9b%ae/
来源:小泥吧的博客
文章版权归作者所有,未经允许请勿转载。
共有 0 条评论