我有一个git存储库(在github.com上)有两个分支:master和gh-pages.我想将gh-pages分支放在子目录中,这样我每次都不需要切换分支.
repo/ (content of the master branch) gh-pages/ (content of the gh-pages branch)
那可能吗 ?
您可能正在寻找子树合并选项.
它会让你将一个不相关的分支签出到另一个分支的子目录中,然后在它们之间来回合并.然而,在推送将在GitHub上运行之前,你仍然需要检查gh-pages并合并来自主repo的更改.
你也可以检查gh-pages作为你的主分支的子模块,如果这更适合你.
这不是设计工作的方式.理论上,您可以在原始克隆的子目录中克隆存储库,并将该目录标记为从较高级别存储库中排除,但是在完全不同的目录而不是子目录中检查它是不是更简单?
也就是说...
/repo/master/(clone on master branch)
然后另一个克隆在另一个分支上
/repo/gh-pages/(clone on gh-pages branch)
从git 2.5开始,您可以在不同的目录中同时检出两个分支.请参阅https://github.com/blog/2042-git-2-5-including-multiple-worktrees-and-triangular-workflows.通过设置git worktree add -b gh-pages ../gh-pages origin/gh-pages
.
如果您希望将master
结帐的子目录的内容放入gh-pages
github,请使用https://github.com/X1011/git-directory-deploy提供的脚本.