本文转载自微信公众号「日拱一兵」,作者tan日拱一兵。转载本文请联系日拱一兵公众号。
前言
上一篇文章Git Worktree 高级使用 整体反应不错,这完全是日常开发中可以用到的奇淫技巧。微服务环境下,通常我们都会有多个 repo,高级用法好归好,但每个 repo 都按照高级用法进行配置,还是比较麻烦的,你看这不就有同学发声了嘛
说者有心,听者有意,那就写个脚本吧
Git Worktree 脚本
个人不是很擅长写 bash script,磕磕绊绊写了一个 worktree.sh,完全执行上一篇文章的整个过程
#!/bin/bash -e
repo=$1
dir="${repo##*/}"
dir="${dir%.*}"
echo $dir
branch=$2
defaultBranch="${branch:-main}"
mkdir -p $dir
cd $dir
git clone --bare $repo .bare
echo "gitdir: ./.bare" > .git
echo " fetch = +refs/heads/*:refs/remotes/origin/*" >> ./.bare/config
git worktree add $defaultBranch
- 1.
- 2.
- 3.
- 4.
- 5.
- 6.
- 7.
- 8.
- 9.
- 10.
- 11.
- 12.
- 13.
- 14.
- 15.
- 16.
- 17.
这个 script 接收两个参数
第一个参数是 repo,https | ssh 两种方式都可以
第二个参数是 branch,不同的 repo 默认的主分支命名可能不一样,Github 现在将主分支命从 master 改为 main,所以这里默认值就是 main
该脚本默认创建 repo 同名文件夹
将 worktree.sh 保存在磁盘目录的某个位置,并授权(最大权限)
chmod -R 777 worktree.sh
- 1.
接下来就测试一下效果
假如默认主分支名是 develop, 我们只需要添加一个参数就可以了:
../worktree.sh git@github.com:FraserYu/amend-crash-demo.git develop
每次找可执行文件的目录很显然不是一个好的方式,我们需要起个别名,配知道环境变量中,这样方便我们全局使用,根据自己电脑情况打开 .zshrc 或 .bashprofile 文件(我用的前者)
在里面创建一个别名 gwt(感觉这个名字好高端):
../worktree.sh git@github.com:FraserYu/amend-crash-demo.git develop
- 1.
然后刷新一下该文件
source ~/.zshrc
- 1.
再来看一下效果:
到这里,使用 worktree 应该非常简单了吧
总结
如果你有多分支切换的各种痛点,学会使用 git worktree,那些问题将不复存在。服务提供全套,脚本放在了
https://github.com/FraserYu/script.git, 有什么问题欢迎留言,那位童鞋,还有什么问题吗?