AI同时完成多个功能(Git WorkTree)

一、介绍

正常情况下,一个项目的 Git 仓库只有一个工作目录,也就是说你同一时间只能在一个分支上干活。想切换分支,就得先保存手头的代码,从当前分支爬下来,然后再爬到另一个分支上开始干活,来回折腾。

但用了 WorkTree,你可以让一个仓库同时拥有多个工作目录,每个目录对应不同的分支,你可以开启分身术,同时在不同的分支上干活,互不干扰。

二、使用

1. 拆开目录

比如你的项目在 meiji-takeout 文件夹,想同时搞首页商家列表、搜索功能和个人中心这 3 个功能,可以创建 3 个工作树,分别对应 3 个功能分支:

shell 复制代码
# 创建 3 个工作树,对应 3 个功能分支
git worktree add -b feat/shop-list  ../feat-homepage
git worktree add -b feat/search     ../feat-search
git worktree add -b feat/user-profile ../feat-profile

打开三个目录进行工作

2. 合并代码

1. 子目录提交

每个工作树里的代码完成后,先用 git add . 命令把改动的文件添加到 Git 的暂存区,然后用 git commit 命令提交保存。

切换到子目录下面

shell 复制代码
git add .
git commit -m "完成首页商家列表"

2. 父目录合并

接着切回主分支,用 git merge 命令把各个功能分支的代码依次合并进来就行了。

shell 复制代码
cd ../meiji-takeout
git merge feat/shop-list
git merge feat/search
git merge feat/user-profile

冲突了自己解决即可

3. 合并清除没有的工作目录

shell 复制代码
git worktree remove ../feat-homepage
git worktree remove ../feat-search
git worktree remove ../feat-profile

三、原文地址

原文地址

不知道为什么,配置转发加上鱼皮的链接csdn不让发布,所以改到这里

相关推荐
和你看星星2 天前
Git rerere:让重复冲突只解决一次
git
嘻嘻仙人5 天前
Ubuntu中 git上传自己的项目和二次上传一般流程
git·github
Patrick_Wilson5 天前
Squash Merge 的血缘陷阱:为什么删掉的代码又活了过来
前端·git·程序员
沉浸学习的匿名网友6 天前
什么是 .gitignore?为什么每个 Git 项目几乎都离不开它?
前端·git
深海鱼在掘金7 天前
Git 完全指南 —— 第3章:理解工作区、暂存区、版本库三个核心
git
江华森7 天前
Git 基础筑基:从原理到团队协作的全栈实战
git
JakeJiang7 天前
Git 必备命令指南:从日常高频到项目开发实战
git
叫我少年8 天前
Windows 中安装 git
git
深海鱼在掘金13 天前
Git 完全指南 —— 第1章:Git 概览与版本控制演进
git
noravinsc14 天前
关于Git Flow
git