`

Pull Request的正确打开方式(如何在GitHub上贡献开源项目)

    博客分类:
  • Git
 
阅读更多

GitHub的官方帮助如下:

发现这个官方文档写得比较简单,并没有提到开源项目协作方式的一些必要的trick(比如建立topic branch),还有Pull Request的运作细节也没有提到。写个简单的总结补充一下。

Step 1: Fork原项目

这个不解释了,单击一下鼠标就能做到的事情。参见GitHub帮助的原文

记得用git remote add添加上游远程库的地址,否则无法追踪上游库的更新。

Step 2: 创建你的主题(topic)branch

这一步非常重要。GitHub的帮助里没有提到创建主题branch的必要性,你当然可以直接在原项目的默认branch(如master)上进行工作,但实际上:

如果打算为原项目作贡献,强烈建议你为每个主题创建一个单独的branch。

举例:如果需要修复原项目的一个和Unicode相关的issue:

$ git branch fix-unicode-error
$ git checkout fix-unicode-error

然后在自己的主题branch(这里是fix-unicode-error)下进行工作。

Step 3: 在主题branch下完成需要的工作

记得push相应的主题branch到GitHub。

*(针对贡献者)rebase还是merge

从实用的角度来讲,

  • 当你在主题branch下工作,想要导入来自上游库的(与你当前的工作不冲突的情况下)更新时,使用git rebase

例如,(假设上游branch为upstream/master)

$ git rebase upstream/master fix-unicode-error

或者直接(如果当前branch已经是fix-unicode-error):

$ git rebase upstream/master

这将把当前branch的开发“base(基础)”推进到一个新的起点,而不会引入多余的commits。

  • 当你在某个branch下工作时,git merge可以用来合并来自其他branch的更新。

如果merge的branch来自远程库,一次merge操作会增加一个额外的commit(“Merge branch 'master' of something”)。如果在一个需要发送Pull Request的主题branch下面进行这种操作,(我个人觉得)这不是一种干净的手段。

当你在主线branch(例如master)下进行开发时,git merge可以用来吸收其他开发branch引入的新特性(包括主项目维护者用来直接merge Pull Requests),很恰当。

Step 4: 发送第一个Pull Request

GitHub的界面:左边选择base branch,右边选择head branch。

  • base branch:相当于target branch,你希望Pull Request被merge到上游项目的哪个branch里。

    • 为什么要叫base branch:base可以理解为你在进行git rebase操作时的那个“base”,也就是你的主题branch所基于的开发base(基础)。
  • head branch:相当于source branch,你希望自己开发库里的哪个branch被用来进行Pull Request(当然也就是你的主题branch)。

    • 为什么要叫head branch:参见下面关于head的定义。

注意head与HEAD(大写)的区别:

  • head:简单地理解,就是指向某个commit对象的一个reference。它可以是一个branch的名称(例如,默认的master),也可以是一个tag的名称。一个库可以同时有任意多个head。

  • HEAD当前活动的head。在任意时刻,存在且仅存在一个HEAD。它可以是指向当前branch的head(比如,指向master,假如master是当前branch的话);也可以不指向任何特定的branch(这叫做detached HEAD)。

系统会从你选择的head branch(在这里,是主题branch)的这个head开始匹配所有不包含在base branch中的commits,然后自动视作你的主题branch相对于base所增加的新特性,放进同一个Pull Request中提交。

Step 5: Pull Request发送之后……

一旦你从自己的主题branch(例如fix-unicode-error)推送了一条Pull Request,那么在这条Pull Request被关闭之前,再次向这个branch里push代码,所有的commits都会被自动追加到这个Pull Request后面(不需要再另开Pull Request)。

这个功能尤其有用,比如你最初提交的Pull Request里存在某些问题,项目维护者要求你打回去修改;或者要求你给你的新feature添加一条相应的unit test(这种情况简直太常见了)。只要追加commits到你的这个主题branch中即可。

(题外话:如果原项目有Travis CI,那么它也会在每次追加push之后对Pull Request重新执行一遍测试)

*(针对项目维护者)cherry-pickformat-patcham

这几条命令主要针对项目的维护者,稍微提一下。

git pullgit merge是GitHub上最常用的merge Pull Requests的方式,在命令行下merge之后,GitHub上面的Pull Request也会相应地自动关闭。

如果贡献者一次提交了多条commits,有些是维护者并不想要的,可以用这几条命令来选择性地手动commit。(这也适用于某些项目不是借助于GitHub的Pull Request,而是通过邮件列表和patch文件来进行协作开发的情形)

在这种情况下,GitHub上面的Pull Request并不能自动关闭,需要维护者手工操作。

Step 6: Pull Request关闭之后

如果是已经被merge后关闭的Pull Request,你可以在页面的最下方找到一个“Delete this branch”的蓝色按钮。

这表明这个主题branch的历史使命已经完成(fix-unicode-error的commit已经被合并到主项目中),可以安全地从远程库中删除了。

在本地库中亦可删除这个branch:

$ git branch -d fix-unicode-error

反之,如果你的主题branch并没有被merge就被维护者关掉的话,你还可以继续再拿它来开新的Pull Request去骚扰主项目(´▽` )。

总结

在哪些情况下可以直接使用master branch来提交Pull Request:

  • 你只想为主项目贡献某一处代码,贡献完自己的repo就可以扔的那种。
  • 你打算为主项目长期贡献代码,而且希望追随原项目的主线开发,不保留自己的特性。
  • 你打算为主项目长期贡献代码,默认master branch追随原项目主线,把自己的特性放到别的branch中。

在哪种情况下应该使用主题branch来提交Pull Request:

  • 想用master branch完全来做自己的开发。在这种情形下:
    • 会从上游库合并更新,但是这些merge本身的commits显然不可能作为返还到上游库的Pull Request的一部分。
    • 存在自己的(未被merge或者不想被merge到上游库的)commits。

鉴于Git的分布式开发哲学,每一个库均可以看作是一个独立的项目,显然是后一种(为每一个新特性建立一个专门的主题branch来向主项目推送Pull Request)的贡献方式更可取。

解释完毕(`・ω・´)

分享到:
评论

相关推荐

    github 开源中国项目

    在GitHub上探索开源中国项目,首先需要熟悉GitHub的基本操作,如浏览仓库、查看源码、阅读项目文档、提交问题和拉取请求。以下是一些关键知识点: 1. **搜索技巧**:学会使用GitHub的高级搜索功能,可以根据语言、...

    JavaScript_一个项目,旨在帮助您熟悉GitHub上的开源贡献工作流程.zip

    这个项目的目的是帮助用户熟悉在GitHub上进行开源贡献的工作流程,通过实际操作JavaScript项目来学习这一过程。 在GitHub上进行开源贡献,首先你需要了解的是Forking。Forking允许你创建一个原始项目(Repository)...

    前端开源库-pull-request

    "前端开源库-pull-request"的主题聚焦于如何利用GitHub API进行版本控制操作,特别是关于拉取请求(Pull Request,简称PR)的工作流程。拉取请求是GitHub上用于协同开发的核心功能,它允许开发者从一个分支(通常为...

    在 GitHub 上玩转开源项目的 Code Review.doc

    在本文中,我们将探讨如何在 GitHub 上玩转开源项目的 Code Review。首先,我们需要了解 Code Review 的概念和 importance。Code Review 是一个过程,其中其他开发者检查和评估代码的质量和可维护性。通过 Code ...

    Better Pull Request for GitHub-1.0.37.zip

    名称:Better Pull Request for GitHub -------------------- 版本:1.0.37 作者:Tal Bereznitskey 分类:开发者工具 -------------------- 概述:将文件树添加到 GitHub 拉取请求。 通过文件树视图和其他 UX 改进...

    PullIt从GitHubpull请求展示和拉取分支

    1. **GitHub Pull Request**:GitHub上的Pull Request是一种协作模式,允许开发者发起一个请求,将他们的修改(在新的或已有的分支上)合并到项目的主要分支(通常是`master`或`main`)。通过这种方式,团队成员可以...

    开源项目-github-hub.zip

    2. **创建拉取请求**:`hub pull-request`命令允许你在本地分支上创建一个新的拉取请求,直接推送到远程仓库,无需通过GitHub网页界面操作。 3. **浏览仓库**:`hub browse`命令会打开浏览器并导航到指定的GitHub...

    GitHub入门教程:从账号注册到发起Pull Request全流程详解

    内容概要:本文详细介绍了 GitHub 的使用流程,包括账号创建、邮箱验证、个人信息补充、SSH密钥配置,浏览和搜索代码库、创建自己的仓库、克隆远程仓库到本地、提交更改到GitHub,发起Pull Request参与项目贡献和...

    优雅合并的艺术:GitHub Pull Request模板的精粹

    GitHub是一个面向开源及私有软件项目的托管平台,因为只支持Git作为唯一的版本库格式进行托管,故名GitHub。GitHub提供了分布式版本控制和源代码管理(SCM)功能,此外还有一些特色功能,例如允许用户对项目进行跟踪...

    find-pull-request,IntelliJ插件,可跳转到“拉”请求页.zip

    - **快速访问Pull Request**:通过插件,开发者可以直接在IntelliJ IDEA中查看和打开与当前项目相关的GitHub、GitLab或Bitbucket上的Pull Request。 - **跳转到提交页面**:除了Pull Request,插件还支持跳转到...

    JavaScript_使用Meteor构建的开源看板保持变量字段名camelCase对于翻译只添加Pull Request更改

    Pull Request是一种版本控制协作方式,允许开发者向项目贡献代码,其他团队成员可以审查并讨论这些更改,确保它们符合项目的质量标准和设计原则。 创建Pull Request时,开发者应当详细说明所提议的更改,并遵循以下...

    github贡献者指南word版1

    GitHub 的贡献流程是开源社区协作的核心,通过这一过程,您可以参与到各种项目中,提升技能,同时也为全球开发者社区作出贡献。记得遵循项目的指导原则和代码风格,确保您的贡献符合项目需求,这样更有可能被接受和...

    借助开源项目,学习软件开发

    学习如何在GitHub上搜索项目、创建Pull Request和参与讨论,可以让你更好地融入开源社区。 6. **学习社区规范**:每个开源项目都有自己的编码规范和贡献指南,遵循这些规范可以让你的贡献更容易被接受。同时,这也...

    GitHub查找无代码贡献用户Octohat.zip

    交互包括:在一个 issue 上 raising 或者 commenting 在一个 pull request 上 raising 或者 commenting对一个 commit 进行 commenting 使用示例:octohat [-h] [-g] [-l LIMIT] repo_name positional ...

Global site tag (gtag.js) - Google Analytics