Skip to content

Latest commit

 

History

History
141 lines (92 loc) · 3.43 KB

Pull-Request.md

File metadata and controls

141 lines (92 loc) · 3.43 KB

拉取请求

什么是拉取请求?

拉取请求 PR (Pull Request),GitHub 官方文档定义如下:

拉取请求是一种通知机制。你修改了他人的代码,将你的修改通知原来作者,希望他合并你的修改。

基本的工作流:

  1. 获取最新的代码库

  2. 从主分支创建最新的分支进行开发

  3. 提交修改

  4. 推送你的修改并创建一个拉取请求

  5. 讨论、审核代码

  6. 将开发分支合并到主分支

具体步骤

1.获取最新的代码库

  • 当第一次提交 PR

    Fork MLU-OPS™ 原代码库,点击 GitHub 界面右上角的 Fork 按钮即可

    fork

    克隆 Fork 的代码库到本地

    git clone https://github.com/yourname/mlu-ops.git
    cd mlu-ops
    git submodule update --init --recursive

    添加原代码库为上游代码库

    git remote add upstream https://github.com/Cambricon/mlu-ops.git
  • 从第二个 PR

    检出本地代码库的主分支,然后从最新的原代码库的主分支拉取更新

    git checkout master
    git pull upstream master 

2.从主分支创建一个新的开发分支

git checkout -b yourbranch
为了保证提交历史清晰可读,我们强烈建议您先检出主分支(master),再创建新的分支。
若子仓mlu-ops-proto有修改,先按照2~5步提交子仓修改为一个 PR。

3.提交你的修改

git add [files]
git commit -m "messages"

4.推送你的修改到 Fork 的代码库,并创建一个拉取请求

  • 推送当前分支到远端 Fork 的代码库

    git push origin yourbranch
    
  • 创建一个拉取请求 pull request

5.讨论并评审你的代码

  • 创建拉取请求后,可以关联相关人员进行评审
  • 根据评审意见修改代码,并推送修改

6.拉取请求合并之后删除该分支

git branch -d yourbranch  # delete local branch
git push origin --delete yourbranch  # delete remote branch

PR 规范

  1. 尽量减少代码风格相关问题

  2. 一个 PR 对应一个短期分支

  3. 粒度要细,一个 PR 只做一件事情,避免超大的 PR

    • Bad:给 MLU-OPS™ 添加一个 Add 算子,同时修改了 Div 算子的接口
    • Acceptable:给 MLU-OPS™ 添加一个 Add 算子并添加 Add 算子的设计文档
    • Good:提交两个PR,分别为:提交 Add 算子的设计文档,提交 Add 算子的代码
  4. commit 需要提供清晰且有意义的 commit 信息

  5. 提供清晰且有意义的拉取请求描述

    • 标题写明任务类型,一般格式:

      [Prefix] Short description of the pull request (Suffix)
    • prefix:新增功能 [Feature] ,修 bug [Fix],文档相关 [Docs] ,开发中 [WIP] (暂时不会被 review)

      跟具体算子相关修改

      [Feature](mluOpXXX): Revise code type.
      [Fix](mluOpXXX): Fix div bug.
      [Docs](mluOpXXX): Add div doc.
      

      跟公共模块相关修改

      [Feature](mlu-ops): Revise code type.
      [Fix](mlu-ops): Fix div bug.
      [Docs](mlu-ops): Add div doc.
      
    • 描述里介绍拉取请求的主要修改内容、结果,以及对其他部分的影响

    • 关联相关的议题(issue)和其他拉取请求