gptcommit
一个使用GPT-3编写提交信息的git prepare-commit-msg钩子。使用这个工具,你可以轻松生成清晰、全面且描述性的提交信息,让你专注于编写代码。
查看公告博文。
演示
安装
- 使用
cargo
在本地安装此工具(推荐)。
cargo install --locked gptcommit
或在macOS上使用homebrew
brew install zurawiki/brews/gptcommit
- 在你的
git
仓库中,运行以下命令将gptcommit
安装为git prepare-commit-msg钩子。你需要提供一个OpenAI API密钥来完成安装。
gptcommit install
使用方法
要使用gptcommit
,只需像往常一样运行git commit
。钩子将自动使用像GPT这样的大型语言模型为你生成提交信息。如果你对生成的信息不满意,可以在提交前随时编辑。
注意:默认情况下,gptcommit
使用GPT-3模型。请确保你的OpenAI账户有足够的额度来使用它。
功能
gptcommit
支持多种配置选项,这些选项从$HOME/.config/gptcommit/config.toml
中读取。
配置按以下顺序应用:
- 从
$HOME/.config/gptcommit/config.toml
读取的用户设置。 - 从仓库克隆的
$GIT_ROOT/.git/gptcommit.toml
中读取的设置。 - 以
GPTCOMMIT__*
开头的环境变量。
使用gptcommit config keys
查看所有可用的配置选项。
设置OpenAI API密钥
持久化保存你的OpenAI密钥
gptcommit config set openai.api_key sk-...
或仅为你的本地仓库设置:
gptcommit config set --local openai.api_key sk-...
你也可以通过GPTCOMMIT__OPENAI__API_KEY
环境变量配置此设置。
为了保持与其他OpenAI客户端的兼容性,我们支持OPENAI_API_KEY
环境变量。这将具有最高优先级。
设置自定义OpenAI API基础URL
持久化保存你的OpenAI密钥
gptcommit config set openai.api_base https://...
或仅为你的本地仓库设置:
gptcommit config set --local openai.api_base https://...
你也可以通过GPTCOMMIT__OPENAI__API_BASE
环境变量配置此设置。
为了保持与其他OpenAI客户端的兼容性,我们支持OPENAI_API_BASE
环境变量。这将具有最高优先级。
尝试不同的OpenAI模型
gptcommit
默认使用text-davinci-003
。可以按如下方式配置模型以使用其他模型
gptcommit config set openai.model text-davinci-002
你也可以通过GPTCOMMIT__OPENAI__MODEL
环境变量配置此设置。
有关公共OpenAI模型的列表,请查看OpenAI文档。你还可以引入自己的微调模型。
设置摘要语言
gptcommit
默认使用英语。可以按如下方式配置语言以使用其他语言
gptcommit config set output.lang zh-cn
目前支持的语言有:
语言代码 | 语言 |
---|---|
en | 英语 |
zh-cn | 简体中文 |
zh-tw | 繁体中文 |
ja | 日语 |
允许在修改提交时重新生成摘要
gptcommit config set allow-amend true
代理配置支持
使用以下方式配置OpenAI代理
gptcommit config set openai.proxy "my_http_proxy...."
常见问题 / 常见疑问
如何减少我的 OpenAI 使用费用?
在当前设计中,gptcommit 会发出 N+2 个提示,其中 N 是修改文件数量且差异在最大令牌限制内。其他两个提示是标题和摘要。
OpenAI 的完成功能按发送和生成的"令牌"计费。每个令牌的价格取决于所使用的模型。生成的令牌数量通常是可预测的(因为提交消息通常只有这么大),但 gptcommit 可能会以差异数据的形式发送大量令牌。
目前,我看到两个简单的解决方案来降低成本:
- 使用 openai.model 配置选项切换到不同的模型
- 减少发送给 OpenAI 的提示和差异数据的大小
OpenAI 的定价页面可以在以下网址找到: https://openai.com/api/pricing/#faq-completions-pricing
当我提交时 git 钩子没有运行
默认情况下,git 钩子只会在新提交时运行。 如果设置了模板或正在修改提交,默认情况下 git 钩子会跳过。
因为 git 钩子检测到用户提供了自己的模板,我们确保不会用 GPT 覆盖它。你可以通过确保 git config --local commit.template
为空来移除提交模板。
你可以通过以上配置允许 gptcommit 总结修改后的提交。
在 GitHub Codespaces 中安装
你首先需要安装 Rust 和 cargo 工具链。记得配置你的 API 密钥。
curl https://sh.rustup.rs -sSf | sh
bash
cargo install --locked gptcommit
# 插入你的 OpenAI API 密钥 https://platform.openai.com/account/api-keys
gptcommit config set openai.api_key # sk-...
衍生作品
所有这些很棒的项目都是使用 gptcommit
构建的。
遇到任何 bug?
如果你遇到任何 bug 或有任何改进建议,请在仓库上开一个 issue。
许可证
本项目基于 MIT 许可证 授权。
详细帮助用法
$ gptcommit -h
用法:gptcommit [选项] <命令>
命令:
install 安装 git 钩子
uninstall 卸载 git 钩子
config 读取和修改设置
prepare-commit-msg 在 prepare-commit-msg 钩子上运行
help 打印此消息或给定子命令的帮助
选项:
-v, --verbose 启用详细日志记录
-h, --help 打印帮助
-V, --version 打印版本
$ gptcommit install -h
安装 git 钩子
用法:gptcommit install [选项]
选项:
-v, --verbose 启用详细日志记录
-h, --help 打印帮助
-V, --version 打印版本
$ gptcommit uninstall -h
卸载 git 钩子
用法:gptcommit uninstall [选项]
选项:
-v, --verbose 启用详细日志记录
-h, --help 打印帮助
-V, --version 打印版本
$ gptcommit config -h
读取和修改设置
用法:gptcommit config [选项] <命令>
命令:
keys 列出所有配置键
list 列出所有配置值
get 读取配置值
set 设置配置值
delete 清除配置值
help 打印此消息或给定子命令的帮助
选项:
-v, --verbose 启用详细日志记录
-h, --help 打印帮助
-V, --version 打印版本
$ gptcommit config keys
allow_amend
file_ignore
model_provider
openai.api_base
openai.api_key
openai.model
openai.proxy
openai.retries
output.conventional_commit
output.conventional_commit_prefix_format
output.lang
output.show_per_file_summary
prompt.commit_summary
prompt.commit_title
prompt.conventional_commit_prefix
prompt.file_diff
prompt.translation