git: hint:use --reapply-cherry-picks to include skipped commits
问:
当我在feture分支写完功能,切换到dev更新了远端dev代码,切回feture分支,git rebase dev分支后出现报错:
warning skipped previously applied commit 709xxxx
hint:use --reapply-cherry-picks to include skipped commits
hint:Disable this message with "git config advice.skippedCherryPicks false"
successfully rebased and updated refs/head/feature/xxxx项目名/分支
回答:
在使用 `git rebase` 时,出现 `warning skipped previously applied commit` 的提示,通常是因为某些提交在之前的重置基础操作中已经被应用过,但在当前的重置基础操作中被跳过了。这可能是由于冲突解决后的提交或其他原因导致的。
以下是一些解决这个问题的方法:
### 方法 1: 使用 `--reapply-cherry-picks` 选项
Git 提示使用 `--reapply-cherry-picks` 选项来包含被跳过的提交。你可以在重置基础操作中添加这个选项:
git rebase --reapply-cherry-picks dev
### 方法 2: 手动应用被跳过的提交
如果你知道哪些提交被跳过了,可以手动应用这些提交。首先,找到被跳过的提交哈希值(例如 `709xxxx`),然后使用 `git cherry-pick` 命令手动应用这些提交:
git cherry-pick 709xxxx
### 方法 3: 检查和解决冲突
如果重置基础操作中有冲突,确保你已经正确解决了这些冲突。你可以使用以下命令来检查冲突文件:
git status
然后手动解决冲突,并使用以下命令继续重置基础操作:
git add <解决冲突的文件>
git rebase --continue
### 方法 4: 关闭提示信息
如果你不希望再看到这个提示信息,可以禁用它:
git config advice.skippedCherryPicks false
### 总结
以下是一个完整的步骤示例,展示如何在重置基础操作中处理被跳过的提交:
1. 切换到你的功能分支:
git checkout feature/xxxx项目名/分支
2. 更新远端 `dev` 分支代码:
git checkout dev
git pull origin dev
3. 切换回功能分支并开始重置基础操作:
git checkout feature/xxxx项目名/分支
git rebase --reapply-cherry-picks dev
4. 如果有冲突,解决冲突并继续重置基础操作:
git status
git add <解决冲突的文件>
git rebase --continue
通过这些步骤,你可以确保在重置基础操作中正确处理被跳过的提交,并成功将你的功能分支合并到最新的 `dev` 分支。
问:
还用重新执行git rebase --continue?
回答:
no