git 如何只将某个子文件夹的修改应用到另一条分支?

111 天前
 Kaleidopink

假设有 topic 分支和 main 分支, topic 分支由 main 分支创建而来, 而后 main 分支一直没有动过. 现在在 topic 分支上做了许多修改, 但是只需要将某个子文件夹的修改应用到 main 分支. 可以保证对该子文件夹的修改都是单独的 commit.

2358 次点击
所在节点    git
9 条回复
estk
111 天前
git restore 命令
Kaleidopink
111 天前
@estk 确实可以, 感谢.
lonhongg
111 天前
没想到有啥便捷的 git 命令,可以:
1. 切到 topic 把这个目录复制出来
2. 切回 main 粘贴覆盖吗?
yidinghe
111 天前
stage 是可以选择只暂存哪些文件的,你只要只选择该文件夹下的变更,就能生成一次只包含该文件夹的 commit 。接下来在 main 分支进行 cherry-pick 即可。
yidinghe
111 天前
你帖子中没说这些修改已经 commit 了,如果是这样, #3 是最简单可靠的办法。
dayeye2006199
111 天前
git diff + git apply
Kaleidopink
111 天前
@lonhongg
@yidinghe
@dayeye2006199
我用的 `git restore --source=topic patch` (假设要修改的是 patch 目录).
lucifer69
111 天前
restore 还能这样用,学到了
sagaxu
111 天前
在新增 restore 功能之前,一般用 git checkout topic -- patch

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1069487

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX