开源项目贡献代码流程
程序员文章站
2022-07-10 18:04:09
...
原来在github上断断续续给许多项目提交过pr(pull requests),比较有成就感的是参与的datax-web项目,目前已近1.8k star。现将开源项目贡献代码流程成文,方便后续更多的同学参与到开源社区。
一.整体流程如下图
二.详细步骤
1.fork
- 作用:在GitHub(或gitlab,gitee)上,将别人项目引出一个新的分支到你的GitHub账号(fork字面意思“叉子”)
- 操作:github项目右上角点击fork,如下图(因为我已经fork过,所以没有fork到waterWang的选项);
- 效果:自己的github上有了别人项目,可以看到项目从哪里fork过来的;
2.clone
- 作用:将fork到自己github账户的项目,从github克隆到自己机器,以便开发修改代码;
- 操作:git命令行或可视化git工具都可以(我习惯git命令行)。克隆如下图有三种方式,a地址克隆(又分https,SSH,GitHub CLI),b GitHub Desktop,c下载zip包
>git clone url-xxx # 输入命令后安静的等待进度达到100%
- 效果:本地文件夹中出现datax-web项目
3.checkout
- 作用:clone的下来默认的是master分支,但是开发尽量避免在master上—要开发,先切糕(checkout)
- 操作:命令行
>git checkout -b newBranchName
# 默认以当前本地分支为基准,创建并切换到新分支。
#也可以以远程分支为基准,创建并切换到新分支 ,如下命令
git chekcout -b origin/master newBranchName #origin/master 是远程地址别名为origin上的master分支;
- 效果:创建出了一个新分支,并切换当前分支到新分支
4.add/commit
- 作用:上步骤切出新分支后,可以书写自己代码,本地测试通过,可以进行代码的提交
- 操作:git命令行
>git add . # git add 还有很多用法,本文不再赘述
>git commit -m 'sth msg' # git commit 还有很多用法,已经msg的规范,本文不赘述
- 效果:代码已经全部存在本地仓库(git status后提示nothing to commit, working tree clean)
5.push
- 作用:从本地仓库将分支推到远程自己GitHub上。
- 操作:git命令行
>git push origin branchName
- 效果:GitHub上对应项目上多看一个分支;
6.pull request
- 作用:将上步骤的远程分支请求合并到原作者的项目上(真正意义上为开源项目提交代码)
- 操作:GitHub页面。在原作者的项目页面点击pull request–》new pull request,(也可以直接点击compare and pull request)
注意选择从哪里合并到哪里(注意箭头方向),GitHub会检测代码是否可以合并,如果可以就会出现Able to merge,反之需要先解决代码冲突。
- 效果:“pull request”合并请求已经发生,安静的等待原作者处理该请求。
上一篇: 跨域请求以及实现跨域的方案
推荐阅读
-
【项目实战】数据爬虫 + 数据清洗 + 数据可视化+开源代码啦
-
php代码如何加域名授权?开源php项目如何保护版权 商业授权?
-
个人项目开源之c++基于epoll实现高并发游戏盒子(服务端+客户端)源代码
-
[Unity]创建项目环境用GithubDesktop管理Git代码的安装流程
-
开源项目贡献代码流程
-
Slickflow.NET 开源工作流引擎高级开发(二) -- 流程快速测试和流程图形代码创建介绍
-
电商网站开源代码大全(java电商项目)
-
Slickflow.NET 开源工作流引擎高级开发(四) -- 硬核编码:代码式快速构建流程图
-
23个Python爬虫开源项目代码,让你一次学个够
-
Docker搭建代码检测平台SonarQube并检测maven项目的流程