Golang编程语言知识介绍


  • 首页

  • todo

  • 思考

  • life

  • food

  • OS

  • lua

  • redis

  • Golang

  • C

  • TCP/IP

  • ebpf

  • p4

  • OpenVPN

  • IPSec

  • L2TP

  • DNS

  • distributed

  • web

  • OpenWRT

  • 运维

  • Git

  • 鸟哥的私房菜

  • IT杂谈

  • 投资

  • About Me

  • 友情链接

  • FTP

  • 搜索
close

合并多次提交

时间: 2021-12-13   |   分类: 运维     |   阅读: 1044 字 ~3分钟
  1. 找到需要合并的最后一条commitid的上一条commitid a3953b9 55ecd9c a142bb1 33018e91766fb 比如,这里需要合并前三个commit 则他们的上一个是 33018e91766fb
  2. 执行 git rebase -i 33018e91766fb (git rebase -i [startpoint] (endpoint)) 将区分范围内的commit 合并 第一条pick保留,其它的pick改为f pick a3953b9 feature: incoming code block name function. f 55ecd9c feature: add compile string length information and debugging symbol information f a142bb1 optimize: remove unnecessary strlen calls
  3. 修改commit的注释 执行 git commit –amend 把日志修改一下
  4. 使用fork工具看看修改是否符合自己的预期
  5. 强制提交

git rebase -i合并多次提交

简介

在日常开发中,代码变更比较频繁,有时候想让前几次提交的合并为一次提交,这里可以使用git rebase -i 命令来完成,当然,git rebase命令不仅仅用于合并提交,它还有许多用处,比如可以使用git rebase onto将某一段commit粘贴到另一个分支上等等,这里主要介绍合并提交。

命令介绍

rebase为变基 git rebase -i 命令可以压缩合并多次提交 格式:git rebase -i [startpoint] [endpoint]

其中-i的意思是–interactive,即弹出交互式的界面让用户编辑完成合并操作,[startpoint] [endpoint]则指定了一个编辑区间,如果不指定[endpoint],则该区间的终点默认是当前分支HEAD所指向的commit(注:该区间指定的是一个前开后闭的区间)。

在查看git的log后,可以使用如下命令

// 合并从当前head到15f745b(commit id)
git rebase -i 15f745b
或:
// 合并最近的两次提交
git rebase -i HEAD~2
12345

执行这个命令后会跳到一个vi编辑器 里面的提示有: pick:保留该commit(缩写:p) reword:保留该commit,但我需要修改该commit的注释(缩写:r) edit:保留该commit, 但我要停下来修改该提交(不仅仅修改注释)(缩写:e) squash:将该commit和前一个commit合并(缩写:s) fixup:将该commit和前一个commit合并,但我不要保留该提交的注释信息(缩写:f) exec:执行shell命令(缩写:x) drop:我要丢弃该commit(缩写:d)

实操

这里在终端输入: git rebase -i HEAD~2 这里的 HEAD~2 表示合并最近两次的提交, 如果想合并最近三次的提交修改为: git rebase -i HEAD~3 在这里插入图片描述 需要做的是,将第二行的 pick 改为 s, “s” 为 “squash” 的缩写,“squash” 的意思是将这个提交压缩为最后一次提交 在这里插入图片描述 保存后弹出这样的 将 This is the commit message #2 下面的内容改成你想提交的概述即可 在这里插入图片描述 最后保存退出即可

**********2021.1.11更新************ 发现IDEA2020.3的版本控制可以更方便的做这个操作 在这里插入图片描述 右键,点击Squash Commits即可

#运维#
git忽略文件权限和所有者
git squash用法
shankusu2017@gmail.com

shankusu2017@gmail.com

日志
分类
标签
GitHub
© 2009 - 2025
粤ICP备2021068940号-1 粤公网安备44011302003059
0%