引题
最近公司项目,成都小伙伴,在develop
上合并了错误的代码。
然后我们自己的分支上也合并了错误的代码。虽然最终develop
的代码回滚了,
错误的代码丢掉,但是自己分支上错误的提交还在,创建merge request
的时,发现一大堆不是自己写的代码,如何解决呢?
cherry-pick
git-cherry-pick - Apply the changes introduced by some existing commits
拙略的英文,翻译为:可以把已经存在提交再次提交。
实战
总体思路如下:找到自己本工单号,本分支提交的commits
,在新分值上merge
这些commits
。
第一步: 格式化输出log
git log命令可一接受一个--pretty选项,来确定输出的格式.
如果我们只想输出hash.
git log --pretty=format:"%h"
git用各种placeholder 来决定各种显示内容:
- %H: commit hash
- %h: 缩短的commit hash
- %T: tree hash
- %t: 缩短的 tree hash
- %P: parent hashes
- %p: 缩短的 parent hashes
- %an: 作者名字
- %aN: mailmap的作者名字 (.mailmap对应,详情参照git-shortlog(1)或者git-blame(1))
- %ae: 作者邮箱
- %aE: 作者邮箱 (.mailmap对应,详情参照git-shortlog(1)或者git-blame(1))
- %ad: 日期 (--date= 制定的格式)
- %aD: 日期, RFC2822格式
- %ar: 日期, 相对格式(1 day ago)
- %at: 日期, UNIX timestamp
- %ai: 日期, ISO 8601 格式
- %cn: 提交者名字
- %cN: 提交者名字 (.mailmap对应,详情参照git-shortlog(1)或者git-blame(1))
- %ce: 提交者 email
- %cE: 提交者 email (.mailmap对应,详情参照git-shortlog(1)或者git-blame(1))
- %cd: 提交日期 (--date= 制定的格式)
- %cD: 提交日期, RFC2822格式
- %cr: 提交日期, 相对格式(1 day ago)
- %ct: 提交日期, UNIX timestamp
- %ci: 提交日期, ISO 8601 格式
- %d: ref名称
- %e: encoding
- %s: commit信息标题
- %f: sanitized subject line, suitable for a filename
- %b: commit信息内容
- %N: commit notes
- %gD: reflog selector, e.g., refs/stash@{1}
- %gd: shortened reflog selector, e.g., stash@{1}
- %gs: reflog subject
- %Cred: 切换到红色
- %Cgreen: 切换到绿色
- %Cblue: 切换到蓝色
- %Creset: 重设颜色
- %C(...): 制定颜色, as described in color.branch.* config option
- %m: left, right or boundary mark
- %n: 换行
- %%: a raw %
- %x00: print a byte from a hex code
- %w([[,[,]]]): switch line wrapping, like the -w option of git-shortlog(1).
第二步: 根据需要输出自己的commit
根据上述format,定制
git log -150 --pretty=format:"%h %s %an %aD " | grep wanghao | grep xxxxx
其中 -150 表示输出150次的commits
-<1number>, -n <1number>, --max-count=<1number>
Limit the number of commits to output.
- %h : 缩短的commit hash
- %s : commit信息标题
- %an : 作者名字
- %aD : 日期, RFC2822格式
grep wanghao grep xxxxx
管道符输出
是 wanghao 并且是工单 xxxxx 的commits
最终输出如下:
98743af [rmxxxxx] Merge branch 'develop' xxxxx
2b48938 [rmxxxxx] rmxxxxxx wanghao
3320829 [rmxxxxx] rmxxxxxx ****** wanghao Mon, 18 May 2015 14:42:51 +0800
1e09778 [rmxxxxx] rmxxxxxx ****** wanghao Sun, 17 May 2015 18:07:44 +0800
第三步: 运用强大的cherry-pick
git checkout develop
git pull origin develop
git checkout -b feature/rmxxxxx_wanghao_20150521_xxxx
git cherry-pick 2b48938 3320829 1e09778
git branch -D feature/rmxxxxx_wanghao_20150521_xxxx_tmp
git push origin :feature/rmxxxxx_wanghao_20150521_xxxx
git push origin feature/rmxxxxx_wanghao_20150521_xxxx
bingo!