github Pull Request合入全流程介绍
图解全流程
详细步骤
1. fork仓库
2. clone fork仓库到本地
3. 关联upstream原仓库
在fork本地仓库输入下面命令进行关联:
git remote add upstream <原仓库github地址>
查看仓库地址:
git remote -v
4. fork本地仓库commit+push
修改完文件后执行下面命令:
git add .
git commit -m 'message'
// push推送到fork远程仓库
git push origin master
5. 发起Pull Request
在fork远程仓库,点击Pull Request->New Pull Request,进入以下截图页面
base repository为原仓库的某个分支,
head repository为fork仓库发某个分支
head的某个分支代码合到base的某个分支
6. 原仓库合入PR
进入原仓库的Pull requests可看到刚才发起的PR
github pull request介绍:https://help.github.com/cn/github/collaborating-with-issues-and-pull-requests/merging-a-pull-request
三种合入方式介绍:
- Merge pull request:将fork仓库的每一次提交都合并到原仓库,并且还产生了一个merge commit log。
- Squash and merge:将多个commit合并为一个commit添加到原仓库中,会产生一个新的commit id。
- Rebase and merge:将fork仓库的每一次提交都rebase到原仓库,但github的rebase行为与git rebase略有偏差。GitHub上的变基和合并始终会更新提交者信息并创建新的提交,也就是产生新的commit id。
选择“Squash and merge”进行合入
合入后会产生如下图的一条commit:
这条commit包含了发起PR时fork仓库的几个commit
7. fork本地仓库更新
原仓库合入后产生了一条新的commit id,为了保持一致,需要在fork本地仓库进行更新
// 更新并合并原仓库的master分支
git pull --rebase upstream master
更新前:test4和test5为两次commit
更新后:test4和test5合并为fork原仓库通过squash and merge产生的commit
8. 修改文件后,再commit + push
这时,push推送到远程仓库,需要进行强制覆盖fork远程仓库。因为fork远程仓库仍是test4、test5两次提交的commit,而本地仓库已经更新同步为原仓库的合并commit。不强制覆盖则会在push时提示需要更新与远程分支同步。
git push origin master --force
到这里!!!fork、clone、commit、push、pull整个流程已完成。
之前也写过类似的两篇文章:
- github的pull Request使用
- github上fork原项目,如何将本地仓库代码更新到最新版本?
不同之处在于合入方式,之前写的是按照"merge pull request“合入,在最近开发中,发现这样始终会多出一个commit,在fork仓库同步的时候又会多出一个commit,来回多了两个commit,并且commit log看起来也会交错在一起,不便于阅读。。诸如下图
通过本篇文章操作后,commit log如下图,清晰整洁。
不断的学习!不断的爬坑!不断的总结!写出更优质的代码!
github Pull Request合入全流程介绍的更多相关文章
- Github Pull Request的提出与采纳
这一文来简要介绍一下Github Pull Request(以下简称PR)的使用方法: 作为PR的提出者,如何对某个仓库提交PR,如何根据仓库管理者对所提交PR的反馈对PR进行完善 作为PR的接收者, ...
- sonarQube Github pull request扫描代码
参考官方地址:https://docs.sonarqube.org/display/PLUG/GitHub+Plugin 运行环境:sonarQube6.2 + sonarScanner2.8 近来, ...
- VS Code 中使用 GitHub pull request 插件提交代码
VS Code作为一个代码编辑器,受到很多人的喜爱:其中有很多非常有用的插件/扩展功能,也会极大的提高我们的工作效率. 这里介绍一下GitHub pull request,用来向GitHub提交在VS ...
- gitHub pull Request记录
1.fork开源项目到自己的gitHub,点fork,然后clone即可 2.提交本地修改,push到自己的代码库 3.点new pull Request,写点备忘信息 注意确保修改的正确性,如果运行 ...
- github pull request
https://stackoverflow.com/questions/14680711/how-to-do-a-github-pull-request https://help.github.com ...
- Ubuntu系统的开机全流程介绍及grub美化
目录 前言 Ubuntu开机经历的步骤 BIOS Boot Loader Kernel 配置 Grub 的个性化主题 /usr/share/grub/default/grub /etc/default ...
- github的pull request是指什么意思?有什么用处
github的pull request是指什么意思? 来看看某乎某位阿牛的理解,多么的简单粗暴! 我尝试用类比的方法来解释一下 pull reqeust.想想我们中学考试,老师改卷的场景吧.你做的试卷 ...
- 六、配置github的pull request触发jenkins自动构建
之前的配置,都是向master分支push操作触发jenkins进行构建,但是在一般的正常工作中,不会允许程序员直接向主分支推送代码:正常都是fork一个本地的分支,在本地分支调试完后,向主干分支提交 ...
- 配置github的pull request触发jenkins自动构建
参照: https://www.cnblogs.com/zanjiahaoge666/p/6402738.html 之前的配置,都是向master分支push操作触发jenkins进行构建,但是在一般 ...
随机推荐
- Java实现 蓝桥杯 算法训练 最小乘积
算法训练 最小乘积(基本型) 时间限制:1.0s 内存限制:512.0MB 问题描述 给两组数,各n个. 请调整每组数的排列顺序,使得两组数据相同下标元素对应相乘,然后相加的和最小.要求程序输出这个最 ...
- Java实现 LeetCode 598 范围求和 II(最小值相乘)
598. 范围求和 II 给定一个初始元素全部为 0,大小为 m*n 的矩阵 M 以及在 M 上的一系列更新操作. 操作用二维数组表示,其中的每个操作用一个含有两个正整数 a 和 b 的数组表示,含义 ...
- Java实现 蓝桥杯VIP 基础练习 Huffuman树
基础练习 Huffuman树 问题描述 Huffman树在编码中有着广泛的应用.在这里,我们只关心Huffman树的构造过程. 给出一列数{pi}={p0, p1, -, pn-1},用这列数构造Hu ...
- java实现三进制转十进制
** 三进制转十进制** 不同进制的数值间的转换是软件开发中很可能 会遇到的常规问题.下面的代码演示了如何把键盘输入的3 进制数字转换为十进制.试完善之. BufferedReader br = ne ...
- java实现第三届蓝桥杯填算式
** 填算式** [结果填空] (满分11分) 看这个算式: ☆☆☆ + ☆☆☆ = ☆☆☆ 如果每个五角星代表 1 ~ 9 的不同的数字. 这个算式有多少种可能的正确填写方法? 173 + 286 ...
- Linux 文件特殊权限-Sticky BIT
SBIT粘着位作用 只对目录有效 普通用户对该目录拥有w和x权限,即普通用户可以在此目录有写权限 如果没有粘着位,普通拥有写权限,就可以删除目录下所有文件,包括其他用户创建的文件,一旦有粘着位,只有r ...
- CVE-2020-0796漏洞复现(RCE)
0x01 漏洞简介 2020年3月10日,微软在其官方SRC发布了CVE-2020-0796的安全公告(ADV200005,MicrosoftGuidance for Disabling SMBv3 ...
- 05-Python基础4
本节大纲: 模块介绍 time &datetime模块 random os sys shutil json & picle shelve xml处理 yaml处理 configpars ...
- 最全面的SourceTree账号注册教程
前言: 作为一个国内开发者而言使用Git操作神器SoureTree最大的问题就是账号注册问题,因为注册账号的链接在不翻墙的情况下基本上是打不开的(弄过的童鞋应该都体会过),所以有的时候我们需要借助一些 ...
- [每日一题2020.06.12]P3375 【模板】KMP字符串匹配
题目链接 关于kmp : https://www.cnblogs.com/roccoshi/p/13096988.html 关于kmp, 想了很久, 我觉得不应该放在这里写, 另开一贴记录一下. #i ...