问题描述
要修改之前的提交,我可以在我的阶段性更改上运行提交
git commit --amend --no-edit
git push -f
提交已被修改,但提交的时间戳更改...
有没有办法不改变时间戳?。类似的东西:
git commit --amend --no-edit --no-time-change
解决方法
请注意,git commit --amend
不会修改提交;相反,它进行了一个新改进的提交并停止使用旧的和糟糕的提交。如果其他人或任何其他分支可以访问原始提交,这种区别很重要,因为他们不会切换到新的和改进的提交。新的提交有一个新的和不同的哈希 ID;旧提交的所有用户都在使用旧的哈希 ID,它没有改变。由于这些原因,日期更改这一事实通常并不重要。
也就是说:每个提交中有两个时间戳:
- 作者日期,以及
- 提交者日期。
使用 git commit
时,无论是否带有 --amend
,您都可以使用 --date=<whatever>
来指定作者日期,但没有用于指定提交者日期的 flag .
幸运的是,您可以设置两个环境变量来覆盖提交者和作者日期。它们是 GIT_AUTHOR_DATE
和 GIT_COMMITTER_DATE
。例如,它们接受 --date
接受的相同日期格式,并且 git show --pretty=fuller
显示两个日期。
使用 eval
(一般来说有点危险)或 env
,我们可以让与 sh/bash 兼容的 shell 作为单行程序为我们执行此操作:
eval $(git log --no-walk --format='GIT_AUTHOR_DATE="%ad" GIT_COMMITTER_DATE="%cd"') git commit --amend
或:
env GIT_AUTHOR_DATE="$(git log --no-walk --format=%ad)" GIT_COMMITTER_DATE="$(git log --no-walk --format=%cd)" git commit --amend
eval
方法更短一些,调用 git
的次数更少,但确实意味着您必须小心命令本身。只要命令本身只是 git commit --amend
,整个过程运行良好,因此您可以将其设为 Git 别名(记住前导 !
以强制 Git 将其传递给 shell)。>
(如果您愿意,请将 --no-walk
替换为 -1
。请注意,无论哪种方式,我们都依赖于这样一个事实,即没有起点,git log
假定 HEAD
。)