相关技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > 相关技巧 > git worktree依赖隔离

git worktree与分支依赖隔离的使用场景分析

作者:前端cry

git worktree 是 Git 命令,用于管理多分支工作区,这篇文章主要介绍了git worktree与分支依赖隔离,需要的朋友可以参考下

git worktree介绍

git worktree 是 Git 命令,用于管理多分支工作区。

使用场景

以下是 git worktree 的子命令:

git worktree add <path> [(-b | -B) <new-branch>]

在当前分支下创建一个新工作区,效果类似于git clone ,但新旧工作区属于同一个仓库,可以正常add、commit、merge等操作。

注意:

# 基于HEAD创建工作区../brance1,分支为brance1
# 相当于 git worktree add ../brance1 -b brance1
git worktree add ../brance1
# 关联branch2创建工作区../brance1,分支为brance2
git worktree add ../brance1 branch2
# 基于HEAD创建工作区../brance1,分支为brance2
git worktree add ../brance1 -b brance2

git worktree remove <worktree>

移除worktree有两种方式。

# 移除指定工作区<worktree>
git worktree remove <worktree>
# 清除worktree记录
git worktree prune

注意:删除工作区,关联的分支并不会被删除哦!

git worktree list

显示所有已添加的工作区。

git worktree list
# 显示完整的hash值
git worktree list --porcelain

git worktree lock <worktree>

用于锁定工作区<worktree>,以防止在合并或其他操作时被意外删除。

git worktree unlock <worktree>

解锁工作区<worktree>

git worktree处理分支依赖冲突

背景

现在远程仓库有一个项目gitworktree,存在两个分支vuereact,两个分支作为两个项目并行开发,且两分支下的依赖存在差异。

步骤

1、 将gitworktree目录下所有内容迁移到新的文件夹gitworktree/project1,方便在一个文件夹下管理。

2、 在目录gitworktree/project1下,执行git worktree add ../vue vue。执行完后可以发现gitworktree目录下存在两个文件夹,分别是project1 和 vue。

3、 在目录gitworktree/project1下,执行git worktree add ../react react。执行完后可以发现gitworktree目录下存在三个文件夹,分别是project1 、 vue 和 react。

这时候就可以愉快的玩耍了,可以像往常一样add、commit、merge,甚至cherry-pick!两个分支vue 和 react已经隔离开了,且依赖互不影响。

与往常不同的是,vuereact之间不能互相切换分支,只需要打开对应工作区即可进入对应的分支。

到此这篇关于git worktree与分支依赖隔离的文章就介绍到这了,更多相关git worktree与分支依赖隔离内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文