mqzlp 发表于 2018-1-15 16:35:03

[译]git commit

  git commit --amend命令用来修复最近一次commit. 可以让你合并你缓存区的修改和上一次commit, 而不是提交一个新的快照. 还可以用来编辑上一次的commit描述.
https://images2015.cnblogs.com/blog/702742/201509/702742-20150929221852199-1393044311.png
  记住amend不是修改最近一次commit, 而是整个替换掉他. 对于Git来说是一个新的commit.

用法
  

git commit --amend  

  

  合并缓存区的修改和最近的一次commit, 然后用生成的新的commit替换掉老的. 如果缓存区没有内容, 那么利用amend可以修改上一次commit的描述.

讨论
  开发过程中很容易忘记stage某个文件或填写了不够准确的commit描述. --amend就是用来fix这些错误的.

不要对一个公共的commit使用amend
  amend后生成的commit是一个全新的commit, 之前的老的commit会从项目历史中被删除. 如果你amend了一个被其他开发者使用的commit, 会严重影响其他开发者.

例子
  下面的例子我们添加一个文件, 然后单独把它commit到HEAD里面, 然后发现这次commit少包括了一个文件. 然后我们使用--amend解决这个问题.
  

# Edit hello.py and main.py  
git add hello.py
  
git commit
  

  
# Realize you forgot to add the changes from main.py
  
git add main.py
  
git commit --amend --no-edit
  

  

  编辑器的默认描述会是上一次commit的描述, --no-edit能让我们修复commit,而且不要修改commit描述.
https://images2015.cnblogs.com/blog/702742/201509/702742-20150929223740996-653804803.png
页: [1]
查看完整版本: [译]git commit