Project Icon

spr

优化GitHub堆叠式拉取请求管理工具

spr是一款优化GitHub工作流的客户端工具,通过自动化管理堆叠式拉取请求简化开发流程。它将每个提交转化为独立PR,使分支成为PR序列。spr自动处理PR的创建、更新和合并,减少手动操作,提高开发效率。此工具便于修改提交、监控PR状态,并提供多样化配置,特别适合需要快速迭代的开发团队。spr支持灵活的PR管理,包括部分更新和合并功能,有助于维护清晰的代码历史。

logo License: MIT Build ReportCard Doc Release Join the chat at https://gitter.im/ejoffe-spr/community

terminal cast

GraphQL用户

查看我的公司Inigo,了解最全面的API平台。

GitHub上的堆叠式拉取请求

轻松管理GitHub上的堆叠式拉取请求。 git spr是一个客户端工具,通过使用GitHub的拉取请求和分支,实现了简单流畅的堆叠式差异工作流程。git spr为您管理拉取请求堆栈,让您无需操心。

使用git spr,每个提交都会成为一个拉取请求,每个分支都成为一堆拉取请求的堆栈。这允许在单个分支上堆叠多个提交,避免了为每个新的更改或功能启动新分支的开销。小的更改和拉取请求变得简单快速。您不必担心堆叠在一起的分支以及管理复杂的拉取请求堆栈。最终结果是更加流畅、更快速的软件开发周期。

安装

Brew

brew tap ejoffe/homebrew-tap
brew install ejoffe/tap/spr

Apt

echo "deb [trusted=yes] https://apt.fury.io/inigolabs/ /" | sudo tee /etc/apt/sources.list.d/inigolabs.list
sudo apt update 
sudo apt install spr

手动安装

发布页面下载预编译的二进制文件,并复制到您的bin路径。

从源码安装

安装goreleaser并运行make。二进制文件可以在dist目录中找到。

make bin

工作流程

像往常一样将您的更改提交到分支。请注意,每个提交最终都会成为一个拉取请求。

> touch feature_1
> git add feature_1
> git commit -m "Feature 1"
> touch feature_2
> git add feature_2
> git commit -m "Feature 2"
> touch feature_3
> git add feature_3
> git commit -m "Feature 3"

提交消息的主题将成为拉取请求的标题,消息的正文将成为拉取请求的正文。 如果您有一个正在进行的更改需要提交,但还不想创建拉取请求,请以全大写的WIP开始提交消息。spr脚本不会为任何以WIP开头的提交创建拉取请求,当您准备好创建拉取请求时,请删除WIP。 您无需为每个更改创建新分支,也不必调用git push将代码推送到GitHub。相反,只需调用git spr update即可。

管理拉取请求

运行git spr update将您的整个提交堆栈同步到GitHub,并为堆栈中的每个新提交创建拉取请求。如果提交被修改,拉取请求将自动更新。该命令输出您的开放拉取请求列表及其状态。git spr update将您的提交推送到GitHub并为您创建拉取请求,因此您无需手动调用git push或在UI中手动打开拉取请求。

> git spr update
[⌛❌✅❌] 60: Feature 3
[✅✅✅✅] 59: Feature 2
[✅✅✅✅] 58: Feature 1

要仅更新部分堆栈,请使用--count标志指定要更新的堆栈中的拉取请求数量。拉取请求将从堆栈底部向上更新。

修改提交

当您需要更新提交时,无论是修复测试、根据审查意见更新代码,还是仅仅因为想要更改,您都应该修改提交。 使用git amend可以轻松修改堆栈中任何位置的更改。暂存您想要修改的文件,然后不要调用git commit,而是使用git amend并在提示时选择您想要修改的提交。

> touch feature_2
> git add feature_2
> git amend
 3 : 5cba235d : Feature 3
 2 : 4dc2c5b2 : Feature 2
 1 : 9d1b8193 : Feature 1
Commit to amend [1-3]: 2

合并状态位

每个拉取请求都有四个合并状态位,表示请求是否可以合并。要合并请求,所有必需的状态位都需要显示**✔**。每个状态位的含义如下:

  1. GitHub检查运行并通过
  • ⌛ : 待处理
  • ❌ : 某些检查失败
  • ✅ : 所有检查通过
  • ➖ : 合并不要求检查(可在yml配置中配置)
  1. 拉取请求批准
  • ❌ : 拉取请求尚未被批准
  • ✅ : 拉取请求已被批准
  • ➖ : 合并不要求批准(可在yml配置中配置)
  1. 合并冲突
  • ❌ : 提交有需要解决的冲突
  • ✅ : 提交没有冲突
  1. 堆栈状态
  • ❌ : 提交下面有其他无法合并的拉取请求
  • ✅ : 此提交以下的所有提交都可以合并

拉取请求批准和检查要求可以在配置文件中禁用,详情请参阅下面的配置部分。

显示当前拉取请求

使用git spr status查看您的拉取请求堆栈状态。在以下情况下,三个拉取请求都是绿色的,可以合并,一个拉取请求正在等待审查批准。

> git spr status
[✅❌✅✅] 61: Feature 4
[✅✅✅✅] 60: Feature 3
[✅✅✅✅] 59: Feature 2
[✅✅✅✅] 58: Feature 1

合并拉取请求

您的拉取请求是堆叠的。不要使用GitHub UI来合并拉取请求,如果您按错误的顺序合并,可能会将一个拉取请求推入另一个,这可能不是您想要的。相反,只需使用git spr merge,您就可以一次性合并所有可合并的拉取请求。合并后的请求状态将在剩余的拉取请求之后打印。 为了一次性合并所有拉取请求而不触发额外的GitHub检查,spr会找到最顶层的可合并拉取请求。然后它将所有提交合并到这个拉取请求中,合并这个请求,并关闭其余的拉取请求。这一开始可能会有些意外,并且有一些副作用,但到目前为止还没有找到更好的解决方案。

> git spr merge
已合并 #58 功能1
已合并 #59 功能2
已合并 #60 功能3
[✅❌✅✅] 61: 功能4

要只合并部分堆栈,请使用 --count 标志加上您想要合并的堆栈中的拉取请求数量。拉取请求将从堆栈底部向上合并。

> git spr merge --count 2
已合并 #58 功能1
已合并 #59 功能2
[✅❌✅✅] 61: 功能4
[✅✅✅✅] 60: 功能3

默认情况下,合并使用变基合并方法,可以通过mergeMethod配置进行更改。

开始新的堆栈

开始新的堆栈是通过创建新分支实现的。例如,如果您想从当前分支的最新推送状态开始一个新的堆栈,使用 git checkout -b new_branch @{push}

配置

首次运行脚本时会创建两个配置文件。 仓库配置保存在仓库基础目录的 .spr.yml 文件中。 用户特定配置保存在用户主目录的 .spr.yml 文件中。

仓库配置类型默认值描述
requireChecks布尔true要求检查通过才能合并
requireApproval布尔true要求拉取请求获得批准才能合并
githubRepoOwner字符串GitHub所有者名称(从git远程配置获取)
githubRepoName字符串GitHub仓库名称(从git远程配置获取)
githubRemote字符串origin要使用的GitHub远程名称
githubBranch字符串main拉取请求目标的GitHub分支
githubHost字符串github.comGitHub主机,可以更新以用于GitHub企业版用例
mergeMethod字符串rebase合并方法,有效值:[rebase, squash, merge]
mergeQueue布尔false使用GitHub合并队列合并拉取请求
prTemplatePath字符串PR模板路径(例如 .github/PULL_REQUEST_TEMPLATE/pull_request_template.md)
prTemplateInsertStart字符串在PR模板中搜索以确定正文插入起始位置的文本
prTemplateInsertEnd字符串在PR模板中搜索以确定正文插入结束位置的文本
mergeCheck字符串使用 'git spr check' 强制执行合并前检查
forceFetchTags布尔false运行 'git spr update' 时也获取标签
branchNameIncludeTarget布尔false在拉取请求分支名称中包含目标分支名称
showPrTitlesInStack布尔false在拉取请求正文的堆栈描述中显示PR标题
branchPushIndividually布尔false单独推送分支而不是原子式推送(仅在需要避免超时时启用)
用户配置类型默认值描述
showPRLink布尔true显示完整的拉取请求http链接
logGitCommands布尔true将所有git命令记录到标准输出
logGitHubCalls布尔true将所有GitHub API调用记录到标准输出
statusBitsHeader布尔true显示状态位类型标头
statusBitsEmojis布尔true使用花哨的表情符号显示状态位
createDraftPRs布尔false新建的拉取请求创建为草稿状态
preserveTitleAndBody布尔false更新拉取请求时不会覆盖PR标题和正文
noRebase布尔false为true时,spr update不会在原始分支之上变基

祝编码愉快!

如果您发现了bug,欢迎提出问题。欢迎提交拉取请求。

如果您觉得这个脚本和我一样有用,请添加一个星标并告诉您的GitHub伙伴。

许可证

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号