1

前言

上一篇文章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

这个 script 接收两个参数

  1. 第一个参数是 repohttps | ssh 两种方式都可以
  2. 第二个参数是 branch,不同的 repo 默认的主分支命名可能不一样,Github 现在将主分支命从 master 改为 main,所以这里默认值就是 main
该脚本默认创建 repo 同名文件夹

将 worktree.sh 保存在磁盘目录的某个位置,并授权(最大权限)

chmod -R 777 worktree.sh

接下来就测试一下效果

假如默认主分支名是 develop, 我们只需要添加一个参数就可以了:

../worktree.sh git@github.com:FraserYu/amend-crash-demo.git develop

每次找可执行文件的目录很显然不是一个好的方式,我们需要起个别名,配知道环境变量中,这样方便我们全局使用,根据自己电脑情况打开 .zshrc.bashprofile 文件(我用的前者)

在里面创建一个别名 gwt(感觉这个名字好高端):

alias gwt='/Users/rgyb/Documents/projects/personal/worktree.sh'

然后刷新一下该文件

source ~/.zshrc

再来看一下效果:

到这里,使用 worktree 应该非常简单了吧

总结

如果你有多分支切换的各种痛点,学会使用 git worktree,那些问题将不复存在。服务提供全套,脚本放在了

https://github.com/FraserYu/s..., 有什么问题欢迎留言

日拱一兵 | 原创


日拱一兵
3.4k 声望25.1k 粉丝