一、做点贡献

想对别人的某个仓库“做点贡献”怎么办?

1. Fork该仓库

首先Fork该仓库,本文以git-learn这个仓库为例

这样自己的账号下就会出现这样一个仓库

2. Clone代码并修改

然后把这个仓库clone下来

git clone https://github.com/FlyLolo/git-learn.git

我新建了一个Student类

3. 提交修改到自己的仓库

然后将修改提交

git add .

git commit -m 'add student'

git push origin master

这样会将修改提交到自己账号下的git-learn仓库

那么如何将修改提交到源仓库呢?

4. 提交pull requests

如果想将修改提交到源仓库,需要进行pull requests

点击上图的pull requests按钮,可以看到自动做了配置

图中红框部分显示了提交修改的方向,即从自己账号仓库的main分支提交到源仓库的main分支。

点击create pull request按钮:

点击下面的按钮提交就可。

5. 源仓库审核pull requests

此时源仓库的作者在源仓库的pull requests页面就会看到如下的Merge pull请求

可以对该请求做相应的处理

比如点击Merge pull request同意将修改合并。

二、Fork过来的仓库如何更新

当一个仓库被Fork过来之后,它是不会随着源仓库更新的,那么如果想同步源仓库的更新过来如何操作呢?

还是pull requests。

默认是向原仓库提交修改请求

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-q1L0ByGC-1654552184213)(git-tag-update.assets/image-20220602094759603.png)]

我们现在不一样,想用原仓库更新fork过来的仓库

首先修改左侧的,改成自己的仓库

此时会变成这样

点击图中的蓝字“ compare across forks”,可以看到箭头两边都是自己的仓库

更改右侧的仓库,最终结果如下图

已经找到了更新,点击右上角的create pull request 按钮

更新即可,这样就完成了main分支的更新。

三、 适用于阅读源码

看一下如何通过Fork方式满足的我源码阅读需求。

首先我想阅读的是指定版本的源码,例如tomcat的10.0.21版本,这需要我去clone它的tag 10.0.21,这样才能保证版本一致。

1. 如何Clone指定的标签

这里我指定了标签 v1.0

git clone -b v1.0 https://github.com/FlyLolo/git-learn.git

切换到对应的文件夹

cd git-learn

2. 我要添加注释

我想对部分代码进行注释,并提交到自己的仓库。(源仓库估计不会接收这样的修改请求,自己看就行了)

修改一个文件,例如添加了一个注释

准备提交修改

提示detached HEAD

如果是在IDEA中也会提示失败

其实clone的时候已经有提示,见第一幅图的红框提示。需创建并切换到一个新的分支。我将其命名为tag-v1.0

git switch -c tag-v1.0

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aIHXykxD-1654552184220)(git-tag-update.assets/image-20220602071921679.png)]

push的时候如果未指定分支会有如下提示:

按提示操作:

提交成功。网页查看一下,已经有了新建的分支:

3. 代码如何更新版本

如果此时源仓库更新了v2.0甚至v3.0版本,而我这里还是v1.0的代码怎么办?

3.1 一次失败的尝试

首先,我想到了第二节的反向pull request, 机智如我

做了如上图配置,右侧选择了源仓库的tag v3.0 ,如愿的识别出了差异,但此时才发现原来的create pullrequest按钮没有了,尝试失败。

3.2 通过upstream获取更新合并

查看现有的remote地址

git remote -v

添加源仓库地址到upstream

git remote add upstream https://github.com/Test-2022/git-learn.git

再次查看remote地址列表

git remote -v

获取upstream的数据

git fetch upstream

可以看到获取到了源仓库的各个分支和tag。

也可以获取指定的tag

git fetch upstream tag v3.0

合并分支

git merge v3.0

如果像这样出现合并冲突,自行解决冲突即可。

GitHub中Fork来的仓库如何进行双向更新的更多相关文章

  1. github中fork分支和pullrequest的最佳实践

    github中fork分支和pullrequest的最佳实践 */--> code {color: #FF0000} pre.src {background-color: #002b36; co ...

  2. 利用git把本地项目传到github+将github中已有项目从本地上传更新

    利用git把本地项目传到github中 1.打开git bash命令行,进入到要上传的项目中,比如Spring项目,在此目录下执行git init 的命令,会发下在当前目录中多了一个.git的文件夹( ...

  3. 如何在Github中删除已有仓库或文件

    一.删除已有仓库如果我们想要删除Github中没有用的仓库,应该如何去做呢? 进入到我们需要删除的仓库里面,找到“settings”即仓库设置: 然后,在仓库设置里拉到最底部,找到“Danger Zo ...

  4. github上fork的项目,如何同步原作者更新的内容?

    一.引言   我在github上fork了一个项目,之后原作者又更新了内容,我想把原作者更新的内容同步到我fork的项目仓库中.在此记录一下同步步骤. 二.同步步骤 打开fork的项目的主页,点击Ne ...

  5. github中fork的使用

    转载https://www.cnblogs.com/patchouli/p/6511251.html 由于git的权限控制功能比较弱,如果想给某个项目提供代码除了直接获得项目的push权限外,gith ...

  6. 出于迁移项目的考虑,GitHub 中 Fork 出来的项目,如何与原项目断开 Fork 关系?

    如果需要为 GitHub 上的项目做贡献,我们通常会 Fork 到自己的名称空间下.在推送代码之后添加 pull request 时,GitHub 会自动为我们跨仓库建立 pull request 的 ...

  7. GitHub中有关已建仓库及上传项目文件的删除

    上传了项目,竟然发现找不到删除的地方,真是囧... 1. 已建仓库的删除 点击 settings,进入以下界面,点击箭头指向的按钮 进入以下界面 2. 某个文件的删除 直接点开文件,在右上角有个删除工 ...

  8. [转]五步git操作搞定Github中fork的项目与原作者同步

    命令如下: git clone xxx-fork.git git remote add xxx xxx.git git fetch xxx git merge xxx/master git push ...

  9. gitlab或github下fork后如何同步源的新更新内容?

    两种方式: 项目 fetch 到本地,通过命令行的方式 merge 懒人方法,只用 Github ,不用命令行 1.项目 fetch 到本地,通过命令行的方式 merge 提示:跟上游仓库同步代码之前 ...

随机推荐

  1. 【kubevirt】VirtualMachineInstanceReplicaSet(vmis)-扩缩容-弹性伸缩

    @ 目录 概述/理解 使用场景 创建vmis 扩缩容 弹性伸缩 方法1 方法2 概述/理解 VirtualMachineInstanceReplicaSet(vmis)确保指定数量的 VirtualM ...

  2. springboot简单发送邮件介绍

    1.新建一个springboot项目 2.所需要的的jar包: <dependency> <groupId>org.springframework.boot</group ...

  3. 干货 | 一文彻底读懂nginx中的location指令

    一个执着于技术的公众号 Nginx系列导读 给小白的 Nginx 10分钟入门指南 Nginx编译安装及常用命令 完全卸载nginx的详细步骤 Nginx 配置文件详解 一文带你读懂Nginx反向代理 ...

  4. MongoDB排序时内存大小限制和创建索引的注意事项!

    线上服务的MongoDB中有一个很大的表,我查询时使用了sort()根据某个字段进行排序,结果报了下面这个错误: [Error] Executor error during find command ...

  5. OpenStack平台调度策略优化

    OpenStack平台报错分析 在OpenStack平台经历大并发的时候,比如同一个平台,大量的用户同时创建云主机(单个用户创建大量云主机不会触发此种现象),会达到云平台的性能瓶颈,导致创建云主机报错 ...

  6. 循环中的scanf处理了换行符怎么破

    这种情况一般在循环中要求输入一个字符时容易出现问题. 问题在于缓冲区,缓冲区中存留了换行符,所以... 运行下面代码: int main(void){ char a=0; while(1){ scan ...

  7. Kafka 生产者解析

    一.消息发送 1.1 数据生产流程 数据生产流程图解: Producer创建时,会创建⼀个Sender线程并设置为守护线程 ⽣产消息时,内部其实是异步流程:⽣产的消息先经过拦截器->序列化器-& ...

  8. hadoop联合hive基础使用

    sqoop路径:/opt/module/sqoop 把指定文件放到hadoop指定路径:hadoop fs -put stu1.txt /user/hive/warehouse/stu hive启动( ...

  9. 对于vjudge在有些网络下无法打开的问题

    因为有些网络会屏蔽vjudge,所以打开 镜像网址 不行再试试这个:最新镜像网址

  10. .NET C#基础(4):属性 - 本质是方法

    0. 文章目的   本文面向有一定.NET C#基础知识的学习者,介绍C#中属性的属性.定义.使用方法以及特殊性. 1. 阅读基础   理解C#基本语法(定义类及类成员,调用方法)   认可OOP的封 ...