github 修改fork的代码之后如何提交代码并pull request

Posted 朝阳的向日葵

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了github 修改fork的代码之后如何提交代码并pull request相关的知识,希望对你有一定的参考价值。

官方的解释还是有点模糊,我是参照这篇文章来的。

http://www.linuxidc.com/Linux/2012-12/76922.htm

关于Git的版本管理的原理,我是从这篇文章里面学习的。

http://wenku.baidu.com/view/78898a1fa76e58fafab00377.html

下面我来总结一下如何在github上面将他人的项目拷贝到自己的本地,修改代码之后重新上传到自己的项目主页,同时通知原项目开发者。

1.安装git工具

    

  1. >sudo apt-get update  
  2. >sudo apt-get install git  

2.Fork一个项目到自己的主页

   在想要fork的页面fork一个。

3.克隆一个拷贝到自己的主机上

   在我们fork出来的自己的主页上拷贝http clone的地址,在本地的机子上运行如下命令将自己主页代码库中的代码文件拷贝到本机上的文件夹来。

   

  1. >git clone ‘http clone 的地址‘  
   一般clone下来的文件夹都会在本地的用户的主目录下面。所以直接在终端输入cd命令加上项目名称即可进入项目文件夹中。

4.配置本地库与原始库的关联

    进入我们的项目文件夹:

    

  1. >cd projectName  
    添加与原始库的关联,命名为upstream,此地址是原项目开发者的项目主页上的clone的地址:这是专门用来与主开发者保持相同进度的方法:

    

  1. >git remote add upstream ’clone地址‘  
     从原始库中抓取最新的更新
  1. >git fetch upstream  

5.在本地修改代码文件并PUSH

    在本地修改完文件测试完成之后,将代码提交到我们自己的fork出来的项目主页。

  1. git commit -a -m ’更新原因‘  
  2.   
  3. git push ‘fork出来的地址‘  
    通过这两个命令就可以将我们的修改发送到我们的fork主页上去,但是,这个时候项目的开发者还不知道我们的修改,通过下面的步骤可以通知开发者。

6.发送pull request给主开发者

    在项目主页上技术分享

    代码目录左上方有如图所示的图表,点击绿色的图标,然后就可以比较你的版本和源中代码的差别,然后就可以选择发送一个Pull request给主开发者,添加修改的原因描述。然后就等待主开发者去merge了。

  技术分享

7.抓取原始库最新的更新

    抓取原数据库的更新,我们需要使用是git fetch upstream命令。这命令会自动选择更改过的代码文件进行更新。



以上是关于github 修改fork的代码之后如何提交代码并pull request的主要内容,如果未能解决你的问题,请参考以下文章

github fork代码后提交

Ⅲ. 通过git管理github上托管的代码

如何向Github开源项目提交代码

使用git/github进行团队协作

一篇文章教会你拉取别人的GitHub代码,修改后提交成为贡献者!!!

github fork项目同步更新