Project Icon

pr-size-labeler

自动标记和管理Pull Request规模的GitHub工具

pr-size-labeler是一个GitHub Action,用于自动标记和管理Pull Request的规模。此工具可为PR添加大小标签,支持自定义标签和阈值,能够忽略特定文件,并在PR过大时提供警告或阻止合并。通过维持PR的合理规模,pr-size-labeler有助于提升代码审查效率和维护代码质量。

Codely 标志

🏷 拉取请求大小标签器

codely.tv CodelyTV 课程 GitHub Action 版本

可视化并可选择限制拉取请求的大小

🚀 使用方法

.github/workflows 目录下创建一个名为 labeler.yml 的文件,并粘贴以下配置。

[!注意] 请注意,PR 大小标签器默认将任何行的添加、删除或修改视为更改,但你可以使用可选参数进行配置,如 files_to_ignoreignore_file_deletions 或甚至 ignore_line_deletions

name: labeler

on: [pull_request]

jobs:
  labeler:
    permissions:
      pull-requests: write
      contents: read
      issues: write
    runs-on: ubuntu-latest
    name: 标记 PR 大小
    steps:
      - uses: codelytv/pr-size-labeler@v1
        with:
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
          xs_label: 'size/xs'
          xs_max_size: '10'
          s_label: 'size/s'
          s_max_size: '100'
          m_label: 'size/m'
          m_max_size: '500'
          l_label: 'size/l'
          l_max_size: '1000'
          xl_label: 'size/xl'
          fail_if_xl: 'false'
          message_if_xl: >
            此 PR 超过了建议的 1000 行大小。
            请确保你没有在一个 PR 中处理多个问题。
            请注意,此 PR 可能因其大小而被拒绝。
          github_api_url: 'https://api.github.com'
          files_to_ignore: ''

[!提示] 当使用 fork 并且不希望任何 PR 能够执行代码时,将 on: [pull_request] 替换为 on: [pull_request_target]更多信息:GitHub 文档)。

🎛️ 参数

名称必需默认值描述
GITHUB_TOKEN自动提供与仓库交互所需的 GitHub 令牌。
xs_label'size/xs'超小型 PR 的标签。
xs_max_size'10'XS 大小 PR 允许的最大更改数。
s_label'size/s'小型 PR 的标签。
s_max_size'100'S 大小 PR 允许的最大更改数。
m_label'size/m'中型 PR 的标签。
m_max_size'500'M 大小 PR 允许的最大更改数。
l_label'size/l'大型 PR 的标签。
l_max_size'1000'L 大小 PR 允许的最大更改数。
xl_label'size/xl'超大型 PR 的标签。如果 PR 超过了 l_max_size 中定义的更改数量,它将被标记为 'xl'
fail_if_xl'false'如果 PR 大小为 'XL',是否使 GitHub 工作流失败(阻止合并)。
message_if_xl自定义消息当 PR 超过 'XL' 大小限制时显示的消息。
github_api_url'https://api.github.com'GitHub API 的 URL,可以为 GitHub Enterprise Servers 更改。
files_to_ignore''计算 PR 大小时要忽略的文件。支持换行或空格分隔的列表。
ignore_line_deletions'false'计算 PR 大小时是否忽略被删除的行。如果设置为 'true',将忽略删除的行。
ignore_file_deletions'false'计算 PR 大小时是否完全忽略被删除的文件。如果设置为 'true',将忽略完全删除的文件。与 ignore_line_deletions 不同,它只忽略完全删除的文件。如果使用了 ignore_line_deletions,那么使用 ignore_file_deletions 就是多余的。

files_to_ignore 示例

files_to_ignore: 'package-lock.json *.lock'
# 或
files_to_ignore: |
  "package-lock.json"
  "*.lock"
  "docs/*"

贡献

如果你想帮助改进这个项目,请阅读贡献指南

⚖️ 许可证

MIT

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

豆包MarsCode

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

Project Cover

AI写歌

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

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

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

Project Cover

Kimi

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

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

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

Project Cover

AIWritePaper论文写作

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

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