Project Icon

patchwork

开发流程自动化工具 提升效率的智能助手

Patchwork 是一款开源的开发流程自动化工具。它通过自托管的 CLI 代理和 LLM 模型,自动执行 PR 审查、Bug 修复和安全补丁等任务。Patchwork 提供可重用的原子操作、LLM 提示模板和预置工作流,支持本地 CLI、IDE 运行和 CI/CD 集成。除了内置工作流,用户还可创建自定义流程,提高开发效率。

Patchwork标志
Patchwork动图

Patchwork使用自托管的命令行界面代理和您偏好的大语言模型来自动化PR审查、错误修复、安全补丁等开发繁琐工作。

主要组件

  • 步骤:可重用的原子操作,如创建PR、提交更改或调用大语言模型。
  • 提示模板:可自定义的大语言模型提示,针对库更新、代码生成、问题分析或漏洞修复等任务进行了优化。
  • 补丁流程:通过组合步骤和提示构建的大语言模型辅助自动化流程,如PR审查、代码修复、文档编写等。

补丁流程可以在您的命令行界面和IDE中本地运行,或作为CI/CD管道的一部分。有多个现成的补丁流程可用,您也可以随时创建自己的

演示

Patchwork命令行界面快速入门

安装

使用Pip

Patchwork可在PyPI上获取,并可使用pip安装:

pip install 'patchwork-cli[all]' --upgrade

以下是可用的可选依赖组:

  • security:通过pip install 'patchwork-cli[security]'安装semgrepdepscan,这是AutoFixDependencyUpgrade补丁流程所需的。
  • rag:通过pip install 'patchwork-cli[rag]'安装chromadb,这是ResolveIssue补丁流程所需的。
  • notifications:用于发送通知的步骤,如Slack消息。
  • all:安装所有内容。
  • 不指定任何依赖组(pip install patchwork-cli)将安装足以运行GenerateDocstringPRReviewGenerateREADME补丁流程的核心依赖集。

使用Poetry

如果您想使用poetry从源代码构建,请参阅此处的详细文档。

Patchwork命令行界面

命令行界面运行补丁流程,如下所示:

patchwork <补丁流程> <?参数>

其中

  • 参数:允许以key=value的格式覆盖补丁流程的默认/可选属性。如果key没有任何值,则被视为布尔True标志。

示例

对于基于使用Semgrep扫描来修补漏洞的AutoFix补丁流程:

patchwork AutoFix openai_api_key=<您的OpenAI API密钥> github_api_key=<您的GitHub令牌>

上述命令默认通过运行Semgrep来识别漏洞,从而修补当前目录中的代码。您可以查看default.yml 文件以获取可以设置的配置列表,以管理AutoFix补丁流程。有关如何在命令行上使用GitHub个人访问令牌的更多详细信息,可以阅读此处

您可以将OpenAI密钥替换为我们托管服务的密钥,方法是在https://app.patched.codes/signin登录并从集成标签生成API密钥。然后,您可以使用以下密钥调用补丁流程:

patchwork AutoFix patched_api_key=<您的Patched API密钥> github_api_key=<您的GitHub令牌>

要使用Google的模型,您可以设置google_api_keymodel,如果您想处理大型上下文,这很有用,因为gemini-pro-1.5模型支持100万个令牌的输入上下文长度。 patchwork-template 仓库包含了所有补丁流程的默认配置和提示。你可以克隆该仓库,并将其作为参数传递给命令行界面:

patchwork AutoFix --config /path/to/patchwork-configs/patchflows

使用开源模型

Patchwork 支持任何与 OpenAI 兼容的端点,允许使用来自 Groq、Together AI 或 Hugging Face 等各种提供商的任何 LLM。

例如,要使用 Groq.com 的 Llama 3.1 405B,运行:

patchwork AutoFix client_base_url=https://api.groq.com/openai/v1 openai_api_key=your_groq_key model=llama-3.1-405b-reasoning

你也可以使用配置文件来实现同样的效果。要使用 Hugging Face 的 Llama 3.1 405B,创建一个 config.yml 文件:

openai_api_key: your_hf_token
client_base_url: https://api-inference.huggingface.co/models/meta-llama/Meta-Llama-3.1-405B-Instruct-FP8/v1
model: Meta-Llama-3.1-405B-Instruct-FP8

然后运行:

patchwork AutoFix --config=/path/to/config.yml

这允许你通过 llama.cppollamavllmtgi 运行本地模型。例如,你可以使用 llama_cpp.server 在本地运行 Llama 3.1 8B:

python -m llama_cpp.server --hf_model_repo_id bullerwins/Meta-Llama-3.1-8B-Instruct-GGUF --model 'Meta-Llama-3.1-8B-Instruct-Q4_K_M.gguf' --chat_format chatml

然后运行你的补丁流程:

patchwork AutoFix client_base_url=https://localhost/v1 openai_api_key=no_key_local_model

补丁流程

Patchwork 附带预定义的补丁流程,随时间会添加更多。示例补丁流程包括:

  • GenerateDocstring:为代码中的方法生成文档字符串。
  • AutoFix:生成并应用修复,以解决仓库中的代码漏洞。
  • PRReview:在创建 PR 时,提取代码差异,总结更改,并在 PR 上发表评论。
  • GenerateREADME:为给定文件夹创建 README markdown 文件,为你的仓库添加文档。
  • DependencyUpgrade:将你的依赖项从易受攻击的版本更新到修复版本。
  • ResolveIssue:识别仓库中需要更新以解决问题(或错误)的文件,并创建 PR 进行修复。

提示模板

提示模板由补丁流程使用,并作为查询传递给 LLM。模板包含带有占位符变量的提示,这些变量用 {{}} 括起来,在每次运行时都会被步骤或输入的数据替换。

以下是一个示例提示模板:

{
  "id": "diffreview_summary",
    "prompts": [
      {
        "role": "user",
        "content": "用一段话总结以下代码更改描述。{{diffreviews}}"
      }
    ]
}

每个补丁流程都有一个优化的默认提示模板。但你可以使用 prompt_template_file=/path/to/prompt/template/file 选项指定自己的模板。

贡献

欢迎为新的补丁流程和步骤,或核心框架做出贡献。请查看开放的问题以获取详细信息。

  • 要创建新的补丁流程,请按照这些说明进行操作。
  • 要创建新的步骤,请按照这些说明进行操作。

我们还提供了一个聊天助手,帮助你轻松创建新的步骤和补丁流程。

路线图

短期

  • 扩展补丁流程库和集成选项
  • 补丁流程调试器和验证模块
  • 错误修复和性能改进
  • 重构代码和文档

长期

  • 支持补丁流程中的大规模代码嵌入
  • 支持并行化和分支
  • 可自托管的微调模型
  • 开源 GUI

许可

Patchwork 根据 AGPL-3.0 条款授权。然而,可以使用 patchwork 模板仓库创建和共享自定义补丁流程和步骤,该仓库根据 Apache-2.0 条款授权。

项目侧边栏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号