分享git的”奇淫“技巧,提升你的工作效率

背景

公司使用git作为代码的版本控制工具,快速迭代开发就会涉及到代码的分支创建,分支合并,标签管理和分支删除操作。

项目一开始是单体应用,使用idea提供的git管理工具就可以轻松完成上面的代码管理了。

但随着业务量的增加,单体应用变为前后端分离,再到后面改成微服务架构。要管理的项目数增长飞速,每半年就产出一个新的项目。还是使用idea提供的git管理工具进行项目管理,十分浪费时间。

其实git工具提供了丰富的命令,将这些命令组合起来成脚本。执行脚本,电脑在工作,自己在摸鱼,美滋滋!

下面分享下我在工作中用的到git脚本。

分支创建

新建文件branch.bat,复制如下命令

@echo off

D:
cd D:\project\%~1

git fetch
git switch %~2
git pull origin %~2

git branch %~3
git push origin %~3


echo ::::::::::::
echo ::::::::::::branch project: %~1 base %~2 to %~3 ,push origin/%~3
echo ::::::::::::
echo.
echo.

eg:branch.bat doc master v1.1.0

  • 参数含义:

    • doc:要操作的项目

    • master:基于master分支创建新分支

    • v1.1.0:新分支名称

分支合并

新建文件merge.bat,复制如下命令

@echo off

D:
cd D:\project\%~1

git fetch
git switch %~3
git pull origin %~3

git merge origin/%~2
git push origin %~3:%~3


echo ::::::::::::
echo ::::::::::::merge project: %~1 merge from %~2 to %~3 ,push origin/%~3
echo ::::::::::::
echo.
echo.

eg:merge.bat doc v1.1.0 master

  • 参数含义:

    • doc:要操作项目

    • v1.1.0:源分支(要合并代码的分支)

    • master:目标分支(合并到哪个位置的分支)

标签管理

新建文件tag.bat,复制如下命令

@echo off

D:
cd D:\project\%~1

git fetch
git switch %~3
git pull origin %~3

git merge origin/%~2
git push origin %~3:%~3

git tag %~4
git push origin %~4


echo ::::::::::::
echo ::::::::::::tag project: %~1 merge from %~2 to %~3 ,push origin/%~3 , tag origin/%~3 : %~4
echo ::::::::::::
echo.
echo.

eg:tag.bat doc v1.1.0 master tag_v1.1.0

  • 参数含义:

    • doc:要操作项目

    • v1.1.0:源分支(要合并代码的分支)

    • master:目标分支(合并到哪个位置的分支)

    • tag_v1.1.0:对目标分支打标签

注意:tag.bat脚本会先把源分支代码合并到目标分支,再对目标分支打标签。

分支删除

新建文件delete.bat,复制如下命令

@echo off

SetLocal EnableDelayEdexpansion

D:
cd D:\project\%~1

git fetch
git switch master
git pull origin master

echo project %~1(%~2) delete branch list:
git branch -r | find "%~2"

for /f %%a in ('git branch -r ^| find "%~2"') do (
	set old=%%a
	set bname=!old:origin/=!
	
	git branch -D !bname!
	git push --delete origin !bname!

	echo ::::::::::::
	echo :::::::::::: project: %~1 delete !bname! and origin/!bname!
	echo ::::::::::::
	echo.
	echo.
)

eg:delete.bat doc v1

  • 参数含义:

    • doc:要操作项目

    • v1:匹配分支名称开头是v1的分支

注意:delete.bat脚本是一个批量删除操作,会删除分支名称开头是指定字符串的远程分支和本地分支,谨慎操作。

关注公众号:java编程秀,获取更多Java最新资讯

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

楚洛瞬

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值