- 改用
git switch
- 优化
gitm start
创建分支流程 - 升级依赖包
build-mp
增加生成版本类型的选择环节,增加输入baseInfo
- 修复
miniprogramToken
miniprogramSession
参数必填问题
miniprogramToken
miniprogramSession
参数从git配置中取
- 增加
--push
传值,是否在copy之后推送目标分支到远程
- 修复版本控制BUG
- 重构项目,合理规划代码
- 新增
build-mp
指令构建小程序 - 新增
miniprogram
指令操作小程序 end
combine
指令支持批量操作build
指令改造成可选参数形式,project参数取消必填限制- 构建配置支持在list里面设置token
- 清理不需要的依赖包
- 升级依赖包
- 优化提示信息
- 升级依赖包
admin
combine
指令增加构建提示- 升级依赖包
build
指令增加--confirm
参数,为 true 时不显示确认框
- build指令增加参数确认环节
- 移除构建参数转码
- 升级依赖包
- 移除
server
ui
两个子项目 - 6.0.0 版本开始
token
从git config里面取user.token
,接口不需要再返回token - 弃用
gitm merge
指令 - 升级依赖包
combine
admin publish
build
指令传参增加--data
,用来传入其他自定义构建参数- 修复
upgrade
使用registry不生效的问题 - 移除
compareVersion
方法,改用js-cool提供的compareVersion方法 - 升级依赖包
- 修复一些问题
- 升级依赖包
- 使用 os-lang 获取系统语言
- 升级依赖包
- 修复 bug 优化体验
- 升级依赖包
- 使用 userdir
- 修复类型输出
- 升级依赖包
- 修复
spawnSync
解析指令出错问题 - 版本控制兼顾到
prerelease
premajor
preminor
prepatch
版本 - 构建输出 gitmars 类型文件
- 升级依赖包
- 全面改用 rollup v3.0
- 配置参数新增
versionControlType
用于控制强制更新版本的类型,传入 false 则不强制更新 - 升级依赖包,开始使用 commander v10,reinstaller v2
- 升级依赖包
- 增加
stringify
isWin32
两个方法,处理 windows 环境脚本兼容问题 - 修复
getIsMergedTargetBranch
在 windows 下的兼容问题 - 升级 spawn 和 spawnSync 处理 windows 环境脚本兼容问题
- 修复
getIsMergedTargetBranch
在 windows 下的兼容问题
- 修复
getIsMergedTargetBranch
在 windows 下的兼容问题 - os-local 降级
- 开始使用reinstaller
- 适配多语言,目前支持
zh-CN
en-US
getIsMergedTargetBranch
方法更改入参方式,新增 strictly,更换默认的判断方式- 全面改用 esm 规范,放弃支持 node12 及以下版本
- config 配置取消
msgUrl
项 - 修复
update
指令判断是否需要合并不准确的 bug - global 从 core 迁出,移到 gitmars 下面
- 重构
copy
指令,改造成自选提交记录的方式 - 新增
prune
方法 - 修复
checkGitStatus
方法 bug - 移除
lastet
limit
默认值设置 - 依赖包升级
combine
update
admin publish
admin update
指增加--force
,强制发起合并请求
postmsg
指令支持脱离 git 目录使用
- 修复
admin
指令合并判断不准确的遗留问题 - 新增
fetch
公共方法
- 修复构建流程导致 gitm-ui 无法运
- 修复
admin
指令合并判断不准确的问题
combine
update
admin
指令增加合并判断,不需要合并时不再合并- 升级依赖包版本
- 修复
gitm get
指令取不到对应暂存内容问题 - 修复
gitm undo
指令报错 - 完善 typescript 类型
- 更新 versionControl 策略,正式弃用 lite 通道
- 优化体验
- 修复一些问题
- monorepo 改造,拆分成
core
gitmars
server
ui
docs
五个子项目 - 放开
alias
指令只能在 git 项目下面执行的限制 - 升级依赖包版本
- 删除分支自动执行
git remote prune origin
清理记录 - 升级依赖包
- 新增
gitm alias
指令,初始化:git alias init
,移除:git alias remove
- 新增别名指令使用 gitmars,可使用
git mars xxx
或git flow xxx
,均等价于gitm xxx
- config 配置增加
apis
,原config.api
迁移到config.apis.userInfo
- 新增
config.apis.buildConfig
接口配置,用于读取构建配置,优先级高于config.apolloConfig
- 升级依赖包
- 新增
level=3
审核员权限,审核员有合并权限可以执行admin publish
动作,但是与管理员不同的是审核员提交代码会推送到远程。原开发者权限调整为 4
- 优化取项目名称的逻辑
approve
review
指令增加--quiet
,移除--postmsg
,默认发送消息
- 扩展
request
方法支持 gzip
approve
指令优化批量操作体验
approve
指令增加显示评论数量- 提示语调整
- 新增
approve
指令用于审批远程合并请求,支持差异预览,新增gitm admin approve
指令,引用approve
指令 - 新增
review
指令用于 review 代码,提交 review 记录 - 扩展
request
方法支持PUT
DELETE
- 修复
service
缓存问题 - 优化文档
- 新增
status
指令查看当前分支状态
log
指令增加--json
传值,是否以 json 格式输出日志,默认表格方式
- 新增
debug
方法,开启 debug 功能
gitm ui
增加支持undo
和redo
gitm go
增加支持undo
和redo
- 改用性能更好的原生脚本执行器,替代 shelljs 的
sh.exec
- 新增
undo
指令,用于撤回代码 - 新增
redo
指令,用于恢复撤销的代码 cleanbranch
指令流程优化,预览之后可选择分支进行清理undo
指令新增--no-merges
--limit
--lastet
--calc
--calcAll
传参log
指令增加--no-merges
传参,用于排除 merge 记录process.exit
替换sh.exit
- 优化读取
git log
的体验 - 新增
echo
gitLogsFormatter
revertCache
writeFileSync
等方法 - 移除
filterBranch
方法 - 完善
typescript
类型
- 替换调起构建和推送群消息的
curl
脚本,处理 win7 不能执行 curl 的兼容问题
queue
方法扩展支持 promise 函数- 替换创建远程合并请求的
curl
脚本,处理 win7 不能执行 curl 的兼容问题 - 解决脚本队列
continue
缓存保存失败的问题 - 解决
circular dependency
问题
- 替换
curl
脚本,处理 win7 不能执行 curl 的兼容问题 - 封装
request
方法
cleanbranch
指令不再主动切换分支log
指令体验优化
cleanbranch
指令优化提示信息ui
界面支持cleanbranch
/admin publish
/clean
/log
四个指令
- 优化代码
- 开源协议换成
GPL-3.0
- 重构核心代码
cleanbranch
指令放开仅支持二级分支的限制
cleanbranch
指令增加--key
传参,传递筛选关键词cleanbranch
指令新增--include
传参,用于正则筛选分支cleanbranch
指令--except
传参更改为--exclude
,用法不变
- 优化脚本执行提示,增加
processing
状态提示 clean
指令不再清理 gitmars 配置,--force
传参改为是否要删除执行缓存- 优化
upgrade
指令流程 - 优化
clean
指令体验
cleanbranch
指令增加branches
参数,用于指定清理分支,多个分支空格隔开cleanbranch
指令增加--target
传参,用于指定需要判断是否合过的目标分支,多个分支逗号隔开,默认:develop,release- 优化提示
cleanbranch
指令兼容旧版本 git
cleanbranch
指令增加--confirm
参数,为 true 时不显示确认框- 修复判断不准确的问题
cleanbranch
指令放开权限控制go
指令支持 cleanbranch
searchBranches
方法改进,删除local
参数- 纠正 branchs 单词错误
cleanbranch
指令增加--list
参数,删除前可以先预览cleanbranch
指令流程优化,加上了动效和提示cleanbranch
增加短指令gitm clb
cleanbranch
指令增加权限控制,仅管理员以上的级别(level < 3)可执行cleanbranch
指令执行前自动切分支
- 新增
cleanbranch
指令,清理合并过的功能分支 searchBranches
方法改进,支持多类型查找,增加local
参数和exclude
正则排除
go
指令支持 clean 方法clean
指令流程优化
- 修复
start
指令从 tag 创建分支报 code 不存在的问题
- 构建配置支持保存多个了
clean
指令支持清理packageInfo
缓存
continue
指令执行前检测是否遗忘了 commit 代码
- 解决 Windows 环境
UI
界面的xterm
运行报错问题
- 运行构建支持多应用逗号隔开
copy
指令去掉执行推送动作
combine
end
start
update
指令加上了版本检测,解决碎片化问题apollo
配置缓存方案调整- 新增
packageInfo
缓存
- typescript 类型完善
apollo
读配置方案优化
- 修复是否合并过
dev
分支判断不准确的问题
- 增加全局配置
descriptionValidator
,用于校验提交的原因描述,支持输入正则表达式和正则字符串 combine
end
admin.publish
admin.update
这几个需要调起远程合并请求的方法增加--description
传参,增加校验
- 抽离出生成 shell 脚本的方法
upgrade
指令增加--registry
和--client
传参,用于指定镜像地址和执行客户端
combine
和end
指令判断是否合并过 dev 默认使用远程分支
copy
指令使用方式调整,from 参数改成--source
传参。使用:gitm copy [commitid...]
或者gitm copy [-s --source [source]] [-k --key [keyword]] [-a --author [author]]
copy
指令在使用模糊查询批量 copy 时,--key
参数必传,且不能少于 3 个字
continue
指令在执行成功后清理执行缓存
- 调整数据库存放位置,避免升级之后数据丢失
log
指令开放更多日志详情
end
指令智能判断是否需要合并代码,不传--no-combine
时,不需要合并的时候不会发起合并操作getIsMergedDevBranch
改为getIsMergedTargetBranch
,新增remote
参数- 抽象
getIsBranchOrCommitExist
方法的判断分支或 commit 是否存在
- 优化
getIsUpdatedInTime
方法的判断策略
- 新增
nameValidator
配置参数,用于校验分支名合法性,支持输入正则表达式和正则字符串 - 分支名支持输入斜杠:
gitm start feature saqqdy/10000
- 修复自定义端口启动
UI
不生效的问题
ui
指令增加--port
参数,自定义端口号
- 依赖包升级
- 完善文档
go
指令增加command
参数,直接进入对应的指令- 完善每个指令的 help 提示信息
- 完善 type 类型
- 完善 UI 界面创建分支的功能
- 优化用户体验
- 解决跨平台脚本转义问题
gitm ui
执行后自动打开浏览器
- 修复是否合并过
dev
判断不准确的问题
- 解决判断是否合过 dev 的 BUG
- 解决方法导出方式错误
start
指令支持从 tag 创建 bugfix 分支
- 纠正
log
和hook
指令参数错误:latest
改成lastet
combine
指令新增是否同步过 dev 分支判断,没有同步过的不允许合 prodcombine
指令新增是否超过 1 周没有同步过主干代码判断
- 优化
ui
用户体验 end
指令删除分支时加上了判断- 修复几个配置 BUG
- 修复
end
指令--no-combine
参数不生效的问题
ui
界面优化,task 和工作流分拆成 2 个 Terminal,互不干扰- 体验和样式优化
- 修复
ui
的几个 bug
end
指令增加--as-feature
和--no-combine
参数- 依赖包升级
- 优化代码
- typescript 重构
server
get
指令优化
upgrade
指令的version
参数支持输入 tag 名称:alpha
、beta
、release
、lite
、latest
、next
、x.x.x
,默认值为latest
- typescript 重构项目
- 清理
bin
目录减小 npm 包体积 - 修复
upgrade
执行报错
gitm ui
迁移到vue3+vite+typescript
框架- 清理
static
目录减小 npm 包体积
- 调整
link
/unlink
使用方式 - 减小
npm
包体积
- 调整构建配置的存放目录
- 指令加上运行环境校验
- 依赖包升级
gitm end
指令同步删除远程分支branch
指令开放删除远程分支功能go
指令新增支持link
/unlink
/postmsg
- 解决
postmsg
中文乱码问题
- 发起
git
操作请求时发送群消息通知 postmsg
指令支持配置自定义消息通知url
- 修复
windows
发起合并请求失败的问题
- 修复无合并权限调不了
dev
构建的问题 - 弃用
babel
拥抱esbuild
- 清理不需要的依赖包,修复了几处代码问题
- 修复无合并权限调起了构建的问题
gitm update
支持--all
一键升级本地所有分支gitm update
改为默认使用merge
方式更新代码,新增--use-rebase
参数- 新增一个搜索分支的方法,提升搜索性能
- 整理文档
- 整理代码
gitmars UI
界面启动方式优化- 依赖包升级
- 修复一些 BUG
go
指令新增支持admin.create
/admin.update
/admin.clean
/branch
/get
/save
/copy
/revert
这些指令- 参数验证优先使用子选项的配置
- 新增
admin
指令自动创建merge
请求,优化判断逻辑
- 新增
gitm ui
指令,启动 UI 界面 - 新增无 git 权限自动调起合并请求的功能,需要配置
api
、gitHost
、gitID
,具体配置查阅:Gitmars 基本配置 - 升级
checkBranch
、searchBranches
、getCurrentBranch
方法,执行更加高效 - 取消强制配置 api
git config
和git init
加入对api
/gitHost
/gitID
参数设置的支持
- 依赖包升级
- 解决 bug
- 升级获取
config
的方法,升级更新config
的方法 - 优化读取
gitmars
配置和 git 配置的方式 - 更改配置方式,逐步弃用
gitmarsconfig.json
,改用.gitmarsrc
- 修复
Apollo
配置问题
- 新增
go
指令,免去记指令的烦恼,目前支持admin.publish
/build
/combine
/end
/start
/update
这些指令
- 新增
postmsg
指令用于推送消息
bugfix
分支使用--as-feature
合并时不主动和bug
线- 指令配置抽离,为
gitmars ui
做准备
- 更换获取当前分支状态的方法
- 更换获取当前分支名称的方式,解决 Windows 环境兼容问题
- 优化
link
/unlink
,兼容 Windows 系统
- 新增
link
指令,用来创建本地包软链接
combine
指令判断status
优化- 依赖包升级
- 修复
jenkins
调不起 BUG
- 升级
combine
/end
/update
指令,分支名称可以不传,默认合并/结束/更新当前分支 combine
指令新增-a
和-m
参数,传入可自动执行add
和commit
- 文档升级
- 升级
upgrade
指令,Windows 用户终于能用上升级指令了!
- 升级
get
/save
指令,暂存区“绑定”git 分支,新增高级用法 - 修复
config
指令 bug - 修复
continue
指令 bug
- 修复在 node v14 版本下的兼容问题
- 修复包缺失 BUG
- 代码转 ES5 发布
- 新增
build
指令调起 Jenkins 构建 combine
和admin publish
指令新增--build
参数,在合并完代码时调起 Jenkins 构建- 构建配置从远程获取并缓存 24 小时,过期或者执行
gitm clean
后会自动重新请求配置 - 优化代码结构,清理冗余操作,提升性能
- 修复历史 BUG
- 修复
permission
偶尔判断不准确的问题(重要)
- 增加
clean
指令用来清除 gitmars 缓存和配置文件 upgrade
指令增加version
参数支持升级指定版本
- 新增
permission
指令,用来限制master
分支直接提交的错误操作 - 优化执行逻辑,允许在子目录运行
gitm
- 优化日志功能和执行时的输出信息,不再输出大段乱码
- 修复
copy
指令 BUG
update
指令新增--use-merge
配置admin
指令--rebase
配置调整为--use-rebase
copy
指令去除关键词限制- 版本升级指令优化
- 指令运行提示优化
combine
指令新增--as-feature
配置,bugfix
分支特殊情况需要合并到release
时,传入--as-feature
- 优化消息提示
- 优化指令
- 新增支持
postmsg
的指令
combine
指令合并support
类型的分支时允许传入--no-bugfix
不合并到bug
分支- 新增
postmsg
开关 - 优化指令执行消息提示
gitm branch
支持设置与远程分支关联- 新增
upgrade
方法
start
指令创建分支自动拉取最新代码
- 更新
bugfix
和release
分支支持强制使用传入代码或当前代码 - 推送消息支持模板配置。目前支持参数:
message
、time
、project
、pwd
(执行目录)、user
(本地配置的用户名)。默认模板:${message};项目:${project};路径:${pwd}
- 加入了消息推送
- 切换分支判断有未加入版本的文件时不再阻止运行
admin
方法优化
- 调整
admin
合并策略 - 修复部分 Windows 兼容问题
- 新增对
support
分支支持
- 优化
gitm revert
功能 - 优化指令执行提示方式
admin
新增clean
指令,用于 Jenkins 构建时候清理分支- 更新
readme
- 新增
continue
和branch
方法; - 改进执行执行主程序;
- 加入
log
; - 改进
copy
功能; - 修改部分 BUG;
- 指令执行方法优化;
- 代码优化;
- 完善
readme
; - 完善
end
和start
功能; - 完善
admin
功能:update
、create
、publish