据我研究,绿格子没了是因为你修改了用户邮箱,所以github默认不是你提交的了。你只要修改一下历史commit的用户邮箱即可。(我就是因为换了邮箱就出问题了)

那如何使用它更改之前已经提交过的commit的用户邮箱呢。


查看当前commit信息

  • git rebase -i HEAD~n

    是按照时间顺序由近到远显示最近提交的n条commit。
    比如git rebase -i HEAD~3
    会进入vim模式,英文状态下输入:q即可退出。

    因为我要合并的信息是最开始的两条。最近三条信息铁定是看不到的。

  • git rebase -i --root
    这个是从远到近列出所有的commit信息。

修改

首先使用

git rebase -i --root --committer-date-is-author-date

后边这个--committer-date-is-author-date是保留当时提交的时间,否则你虽然修改了但是commit时间会变为你修改的时间。


上图中可以看到我在最后三条前边改为e了,也就是edit编辑的意思。

将你想要修改的commit前面把pick改为e,保存退出。

不会修改的可能需要学一下vim怎么用。
在英文输入的状态下按i进入编辑模式,之后用法就和记事本一样。修改完毕之后Esc退出编辑模式。
再按:,输入wq保存修改并退出文件。

之后你会收到提示:

你可以使用

git commit --amend --author="用户名 <用户邮箱>"

输入之后你就会进入修改页面,也是vim编辑器。直接保存退出即可。

修改完第一个文件之后git rebase --continue继续修改下一个。

直到提示你所有的已经修改完毕。

Successfully rebased and updated refs/heads/master.

最后git push origin master -f强制推到远程仓库即可。

将用户邮箱修改以后,就可以看到我的绿格子已经恢复了。

更多用法看官方文档:
https://git-scm.com/docs/git-rebase#Documentation/git-rebase.txt