前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >GitHub中Fork来的仓库如何进行双向更新

GitHub中Fork来的仓库如何进行双向更新

作者头像
FlyLolo
发布于 2022-09-09 00:27:40
发布于 2022-09-09 00:27:40
1.7K00
代码可运行
举报
文章被收录于专栏:Core NetCore Net
运行总次数:0
代码可运行

目录


一、做点贡献

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

1. Fork该仓库

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

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

2. Clone代码并修改

然后把这个仓库clone下来

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git clone https://github.com/FlyLolo/git-learn.git

我新建了一个Student类

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

然后将修改提交

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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分支的更新。

三、 如何获取并更新指定Tag

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

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

1. 如何Clone指定的标签

这里我指定了标签 v1.0

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git clone -b v1.0 https://github.com/FlyLolo/git-learn.git

切换到对应的文件夹

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cd git-learn

2. 我要添加注释

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

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

准备提交修改

提示detached HEAD

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

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
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地址

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git remote -v

添加源仓库地址到upstream

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git remote add upstream https://github.com/Test-2022/git-learn.git

再次查看remote地址列表

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git remote -v

获取upstream的数据

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git fetch upstream

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

也可以获取指定的tag

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git fetch upstream tag v3.0

合并分支

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
git merge v3.0

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-07-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
​攻防世界pyc-trade
攻防世界pyc-trade <img src="https://img-blog.csdnimg.cn/20200814232918821.png?x-oss-process=image/waterm
花落花相惜
2021/11/20
3250
怎么添加CSDN博客打赏功能及自定义模块
很多朋友喜欢在网络上分享自己的学习心得、工作经验、技术见解,自己呕心沥血写的好文章当然是非常希望得到认可。本文介绍怎么为csdn博客增加打赏功能。 如图所示:
江一铭
2022/06/16
5860
怎么添加CSDN博客打赏功能及自定义模块
​Pyqt面向对象模板建立
使用ide为pycharm 1.代码 from PyQt5.Qt import * class Window(QWidget): def __init__(self): super().__init__() self.setWindowTitle("pyqt") self.resize(500,500) self.setup_ui() #setup_ui是建立不同的对象,更加清楚 def setup_ui
ruochen
2021/11/20
5530
​jenkins持续集成springboot项目
技术栈:docker+jenkins+springboot+git 一、Devops介绍 <img src="https://img-blog.csdnimg.cn/82a179166b884d86b
ruochen
2021/11/20
5020
​jdbc
JDBC(Java DataBase Connectivity)就是Java数据库连接,说白了就是用Java语言来操作数据库。原来我们操作数据库是在控制台使用SQL语句来操作数据库,JDBC是用Java语言向数据库发送SQL语句。
ruochen
2021/11/20
1.4K0
​IIS安装以及搭建
<img src="https://img-blog.csdnimg.cn/20200810162746923.png" alt="在这里插入图片描述">
ruochen
2021/11/20
1.2K0
ctfhub 杂项 --icmp
#ctfhub 杂项 --icmp 技能树–流量分析–icmp–data 1.过滤icmp包 <img src="https://img-blog.csdnimg.cn/202008111347363
ruochen
2021/11/19
8520
ctfhub---SSRF
#ctfhub---SSRF 1.内网访问 直接访问127.0.0.1/flag.php <img src="https://img-blog.csdnimg.cn/20200910230951717
ruochen
2021/11/19
2090
009:博客类爬虫项目实战
爬虫项目开发的第一步,首先需要对我们想要实现的爬虫项目的功能进行定位和分析,即进行需求分析工作。
李玺
2021/11/22
3940
009:博客类爬虫项目实战
DeepWalk:图网络与NLP的巧妙融合
最近这段时间一直在做图网络相关,也差不多收尾了,有空整体复盘了下,大致以下几个主题,不过没整理完全哈哈
NewBeeNLP
2020/09/23
7320
DeepWalk:图网络与NLP的巧妙融合
​机器阅读理解(Neural Machine Reading Comprehension)综述,相关方法及未来趋势
Author:Shanshan Liu , Xin Zhang , Sheng Zhang , Hui Wang , Weiming Zhang
花落花相惜
2021/11/20
3810
XSS过关(二)6~10关 详细
这时突然发现第6关1处“now you’re here”全是小写,2处的“Let’s go”首字母进行了大写。看到这里我就想起了大小写过滤
宸寰客
2020/07/13
4860
XSS过关(二)6~10关 详细
MySQL8.0的binlog详解
binlog中可以不记录执行的sql语句的上下文相关的信息,仅需要记录那一条记录被修改成什么了。所以rowlevel的日志内容会非常清楚的记录下每一行数据修改的细节。而且不会出现某些特定情况下的存储过程,或function,以及trigger的调用和触发无法被正确复制的问题
JavaEdge
2020/10/08
4.6K0
MySQL8.0的binlog详解
Java NIO高性能网络编程(六)-Selector选择器
Selector提供选择执行已经就绪的任务的能力,使得多元 I/O 成为可能,就绪选择和多元执行使得单线程能够有效率地同时管理多个 I/O channel。
JavaEdge
2021/02/22
1.1K1
Java NIO高性能网络编程(六)-Selector选择器
架构师教你kill祖传石山代码重复/大量ifelse
很多 crud 工程师抱怨业务开发没有技术含量,什么设计模式、高并发都用不到,就是堆CRUD。每次面试被问到“讲讲常用设计模式?”,都只能把单例讲到精通,其他设计模式即使听过也只会简单说说,因为根本没实际用过。
JavaEdge
2020/10/25
1.1K0
Java运算符
参考链接: Java中的new运算符 表达式  算术运算符   除数和被除数都是整数时结果是在整数  自增自减运算符   加加在前,先加后用  求一个数的平方: 如 求a的平方 Math.pow(a,2)  赋值运算符   赋值运算符左边不能是常量  关系运算符  if条件语句  从键盘接收一个整数:  Scanner s=new Scanner(System.in); int n=s.nextInt(); ## 逻辑运算符 ![在这里插入图片描述](https://img-blog.csdnimg.cn/
用户7886150
2020/12/10
9070
五分钟跑通3D地图demo
官网页面上方有“开发文档”选项,本文以Android为例,从中选择“Android地图SDK”链接项,具体操作可以参考下图:
腾讯位置服务
2021/07/14
8680
五分钟跑通3D地图demo
腾讯地图 - 关键词输入提示(结尾附视频)
关键词输入提示接口可以用于获取输入关键字的补完与提示,帮助用户快速输入。可以通过配合前端程序实现Autocomplete(自动完成)的效果。
腾讯位置服务
2021/07/14
1.1K0
腾讯地图 - 关键词输入提示(结尾附视频)
听说你还不懂 Java 的服务定位器模式(Service Locator Pattern)?
由于为某个服务查找 JNDI 的代价很高,服务定位器模式(后文简称为 SLP)充分利用了缓存技术。在首次请求某服务时,服务定位器在 JNDI 中查找服务,并缓存该服务对象。当再次请求相同服务时,服务定位器会在它的缓存中查找,便可极大提高应用程序的性能。
JavaEdge
2020/08/16
5760
听说你还不懂 Java 的服务定位器模式(Service Locator Pattern)?
Kafka消费过程关键源码解析
简短的代码,背后牵涉很多问题,Consumer如何绑定特定分区?如何实现订阅 topic 的?又如何实现拉消息?
JavaEdge
2020/09/13
9710
Kafka消费过程关键源码解析
相关推荐
​攻防世界pyc-trade
更多 >
LV.0
这个人很懒,什么都没有留下~
目录
  • 一、做点贡献
    • 1. Fork该仓库
    • 2. Clone代码并修改
    • 3. 提交修改到自己的仓库
    • 4. 提交pull requests
    • 5. 源仓库审核pull requests
  • 二、Fork过来的仓库如何更新
  • 三、 如何获取并更新指定Tag
    • 1. 如何Clone指定的标签
    • 2. 我要添加注释
    • 3. 代码如何更新版本
      • 3.1 一次失败的尝试
      • 3.2 通过upstream获取更新合并
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档