我有一个有很多分支的项目。
我想同时在几个分支上工作,而不是来回切换git签出。
除了将整个存储库复制到其他地方之外,还有什么方法可以做到这一点吗?
我有一个有很多分支的项目。
我想同时在几个分支上工作,而不是来回切换git签出。
除了将整个存储库复制到其他地方之外,还有什么方法可以做到这一点吗?
当前回答
看一下$GIT_SRC_DIR/contrib/workdir/git-new-workdir。
根据存储库某个端口的提交日志:
一个简单的脚本,用于创建使用符号链接的工作目录 指向一个现有的存储库。这允许有不同的 分支位于不同的工作目录中,但都来自相同的目录 存储库。
其他回答
不完全是,因为Git只支持在存储库目录中有一个存储库数据的工作副本。
如果您希望使用两个不同的工作副本提交/提取到同一个存储库,您可以创建一个裸存储库并将其克隆到两个工作副本。
当您完成一些事情时,您只需将其推到“主”裸存储库。
一些提示:
男人git clone
甘孜
Git同时支持多个工作树。有关更多信息,请参阅:
Git有多个工作目录? https://git-scm.com/docs/git-worktree
然而,支持多个带有id的工作树是非常困难的。例如,这是JGet (eclipse ID)中的增强请求,以支持工作树。
因此,您必须手动管理项目(命令行),或者在IDE中使用单一的工作树。
看一下$GIT_SRC_DIR/contrib/workdir/git-new-workdir。
根据存储库某个端口的提交日志:
一个简单的脚本,用于创建使用符号链接的工作目录 指向一个现有的存储库。这允许有不同的 分支位于不同的工作目录中,但都来自相同的目录 存储库。
下面是已接受答案的可伸缩版本(已被认可),按顺序命名分支(app1..app10)。
注意,我们应该尽量避免重复签出(这里:通过签出主分支,git工作树add不会覆盖):
$ git checkout master && for NUM in {1..10}; do git worktree add ~/git/<repo-name>/app$NUM app$NUM; done
我建议使用我的小脚本http://www.redhotchilipython.com/en_posts/2013-02-01-clone-per-feature.html
它将做git克隆和替换配置(“查看”原始的回购,所以拉/推将进入“主”回购),但它足够简单,可以从实际的引导中抽象出来。