美文网首页
利用`git commit —amend —no-edit`命令

利用`git commit —amend —no-edit`命令

作者: voidint | 来源:发表于2017-05-20 11:48 被阅读0次

    场景描述

    假设你创建了一个文件,并写入了一些内容,然后通过git addgit commit将此变更提交。提交之后才发现这个文件中少了一些内容,此时有两个选择摆在你面前:

    • 将文件内容补全,然后和之前一样git addgit commit。显然,你可以通过git log看到这两条commit记录。

    • 回到过去,修改上一次提交的那个文件。如此一来,你的commit记录只会有一条。对于一些有代码洁癖并且看中git commit记录的程序员,这点很重要,特别是在开源项目中。

    场景再现

    • 初始化git仓库
    $ mkdir test && cd test && git init
    
    • 第一次commit内容
    $ echo 'Hello world' > README.md
    $ git add .
    $ git commit -m "Add README.md"
    $ git log --oneline
    c56f680 Add README.md
    
    • 修改文件内容并合并到上一次的commit变更当中
    $ echo 'Hello voidint' >> README.md
    $ git add .
    $ git commit --amend --no-edit
    $ git log --oneline
    eb6c8cb Add README.md // hash值发生了变化
    

    可以看到,在执行git commit --amend --no-edit之后,hash值由c56f680变成了eb6c8cb,但是message内容并没有发生变化,并且最重要的是只有一条commit记录。

    如果要修改上一条的message,那么去掉--no-edit选项即可,git commit --amend -m "xxxx"。同理,commit记录同样只会有一条。

    相关文章

      网友评论

          本文标题:利用`git commit —amend —no-edit`命令

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