美文网首页
跟我学Git(三)

跟我学Git(三)

作者: 橙皇cc | 来源:发表于2020-06-12 13:48 被阅读0次

超强命令:filter-branch

如果你需要以某种脚本化的方式重写大量提交(例如,全面修改你的电子邮件地址或从所有提交中删除某个文件),就需要filter-branch,它能够大面积修改你的历史记录。

从所有提交中删除某个文件

filter-branch是一个可以用来清洗整个历史记录的工具,要想从整个历史记录中删除名为passwords.txt的文件,可以使用filter-branch--tree-filter选项,例如:

git filter-branch --tree-filter 'rm -f passwords.txt' HEAD

--tree-filter选项会在每次检出项目后执行指定的命令,然后重新提交结果。要想在所有分支上执行filter-branch,可以传入--all选项。

将子目录设置为新的根目录

如果你从其他源代码导入,获得了一些没什么用的子目录(trunk、tags等)。如果想让trunk子目录成为新目录每次提交的根目录,如下可以做到:

git filter-branch --subdirectory-filter trunk HEAD

现在项目的根目录为trunk子目录,Git会自动删除所有与该子目录无关的提交。

全面修改邮箱地址

在开始工作之前忘记执行git config设置自己的姓名和邮箱地址,或者在开源项目前需要将所工作电子邮件地址改成个人邮件地址,可以使用filter-branch批处理修改多个提交中的电子邮件地址。

git filter-branch --commit-filter '
        if [ "$GIT_AUTHOR_EMAIL" = "dewitt@localhost" ];
        then 
                GIT_AUTHOR_NAME="Dewitt";
                GIT_AUTHOR_EMAIL="dewitt@example.com";
                git commit-tree "$@";
        else
                git commit-tree "$@";
        fi'  HEAD

这个命令会修改历史记录中所有提交的SHA-1,不仅仅是包含指定电子邮件地址的提交。

重置

三棵树

关于重置的操作,先用较简单的理解方法将Git视为三棵树的内容管理器。

  • HEAD 最近提交的快照,下次提交的父提交
  • 索引 预计的下一次提交的快照(暂存区)
  • 工作目录 沙盒,在提交到索引并写入历史之前,可以随意修改
重置的步骤
  1. 移动HEAD指针的指向(如果指定了--soft,则在此停止)
  2. 更新索引,取消暂存所有的东西
  3. 如果指定了--hard,更新工作目录。

合并的高级用法

忽略空白字符

某些情况下,冲突与空白字符有关,因为每一行在一边被删除,而在另一边又被添加回来。默认情况下,Git将所有的这些行视为改动过的,因此它无法合并文件。如果你发现合并中出现了大量与空白字符有关的问题,你可以中止合并,然后加上-Xignore-all-space-Xignore-space-change再重新进行合并。第一个选项完全忽略空白字符,第二个选项将单个或多个空白字符序列视为等同。

rerere

rerere(reuse recorded resolution),使用该功能可以让Git记住一个块冲突的解决方案,如果下次再碰到相同类型的冲突,Git就可以自动解决。如果选用了一个已合并的分支,修复了一堆冲突后决定对其进行变基操作,这就不必再去解决同样的冲突了。运行如下命令启用:

git config --global rerere.enabled true

如果需要大量的合并操作,或者经常变基,可以启用rerere功能减轻负担。

相关文章

  • 跟我学Git(三)

    超强命令:filter-branch 如果你需要以某种脚本化的方式重写大量提交(例如,全面修改你的电子邮件地址或从...

  • 跟我学Git(四)

    凭据保存 如何保存 Git有一套有助于解决重复验证的凭据系统,有如下选项: 默认不缓存任何内容。所有连接都会提醒你...

  • 跟我学Git(一)

    写在开头 笔者在面试中遇到了很多次关于Git的提问,遂阅读《精通Git(第2版)》,此系列为读书笔记,对书中关键点...

  • 跟我学Git(二)

    标记 Git可以把特定的历史版本标记为重要版本。 创建注释标签 -a表示标签为注释标签,-m指定标记信息,它会和标...

  • 跟我学Docker(三)

    前言 首先进入Docker 命令环境: 校验环境完毕,下面开始命令: 1、我们可以通过直接输入docker命令来查...

  • 浅析git底层存储原理 2021-07-14

    git三区 git三大区:工作区、暂存区和git版本库 1.git版本库 先从git版本库说起,git版本库对应....

  • git资源学习

    git资源学习 Git详解之一 Git起步 Git详解之二 Git基础 Git详解之三 Git分支 Git详解之四...

  • Git 笔记系列(一)—— Git简介

    目录 Git 笔记系列(一)—— Git简介 Git 笔记系列(二)—— Git工作流程 Git 笔记系列(三)—...

  • Git 笔记系列(五)—— Git常用命令-Branch

    目录 Git 笔记系列(一)—— Git简介 Git 笔记系列(二)—— Git工作流程 Git 笔记系列(三)—...

  • Git 笔记系列(四)—— Git常用命令-Checkout

    目录 Git 笔记系列(一)—— Git简介 Git 笔记系列(二)—— Git工作流程 Git 笔记系列(三)—...

网友评论

      本文标题:跟我学Git(三)

      本文链接:https://www.haomeiwen.com/subject/rqjftktx.html