apple_rules_lint

apple_rules_lint

高效的Bazel项目代码质量管理框架

apple_rules_lint是一个针对Bazel项目的代码质量管理框架。它支持集成多种lint工具,如Checkstyle和SpotBugs,提供全局配置和package级别的覆盖功能。该框架设计了简洁的API,方便项目管理者和规则集作者使用,既简化了lint工具的集成过程,又保持了较高的灵活性和可扩展性。

Bazellinting框架配置规则集APIGithub开源项目

apple_rules_lint

Bazel 的 lint 框架

用户

在其他任何操作之前,您必须先加载和配置 lint 框架。这是因为后续依赖 lint 框架的规则集会尝试通过注册空操作的 lint 配置实现来确保已配置 linter。您可以通过以下方式实现:

# WORKSPACE load("@apple_rules_lint//lint:repositories.bzl", "lint_deps") lint_deps() load("@apple_rules_lint//lint:setup.bzl", "lint_setup") lint_setup({ "java-checkstyle": "//your:checkstyle-config", })

或者,使用 Bzlmod:

# MODULE.bazel bazel_dep(name = "apple_rules_lint", version = "0.1.1") linter = use_extension("@apple_rules_lint//lint:extensions.bzl", "linter") linter.configure(name = "java-checkstyle", config = "//your:checkstyle-config")

您可以通过以下方式在每个包的基础上覆盖特定的 lint 配置:

# BUILD.bazel load("@apple_rules_lint//lint:defs.bzl", "package_lint_config") package_lint_config({ "java-checkstyle": ":alternative-checkstyle-config", })

缺少 @@apple_linters 错误

Bazel 可能会报告以下错误:

ERROR: Failed to load Starlark extension '@@apple_linters//:defs.bzl'.
Cycle in the workspace file detected. This indicates that a repository is used prior to being defined.
The following chain of repository dependencies lead to the missing definition.
 - @@apple_linters
This could either mean you have to add the '@@apple_linters' repository with a statement like `http_archive` in your WORKSPACE file (note that transitive dependencies are not added automatically), or move an existing definition earlier in your WORKSPACE file.

@apple_linters 仓库在调用 lint_setup 时定义。您需要找出 load("@apple_linters//:defs.bzl, ...) 在哪里被调用,并修改您的构建以确保在加载 linting 之前调用 lint_setup

API 文档

可以在 API 文档 中找到

规则集作者

WORKSPACE 设置

要为您的仓库添加 linter 支持,请将以下内容添加到...

# repositories.bzl load("@apple_rules_lint//lint:repositories.bzl", "lint_deps") lint_deps()

然后将以下内容添加到...

# setup.bzl load("@apple_rules_lint//lint:setup.bzl", "ruleset_lint_setup") ruleset_lint_setup()

Bzlmod 设置

添加:

# MODULE.bazel bazel_dep(name = "apple_rules_lint", version = "0.1.1") linter = use_extension("@apple_rules_lint//lint:extensions.bzl", "linter") linter.register(name = "java-checkstyle")

获取 linter 的配置

要获取规则集当前配置的配置,请使用:

# your_rules.bzl load("@apple_rules_lint//lint:defs.bzl", "get_lint_config") config = get_lint_config("java-checkstyle", tags) if config != None: # 设置 lint 目标 pass

其中 tags 是要检查的规则的标签。

apple_rules_lint 与您的规则集集成

以 Selenium 项目为例,我们将展示如何将 apple_rules_lint 集成到项目中,但同样的过程可以适用于任何 linter:

  1. _test 规则包装 linter,这样您就可以用 bazel test 运行它们。在 Selenium 中,这是 spotbugs_test

  2. 建议(但不是必需)您的测试返回一个 LinterInfo,以便其他工具可以检测这是否是一个 lint 测试。

  3. 创建一个配置规则或某种标记规则。例如, spotbugs_config

  4. 选择一个"众所周知"的名称: lang-tool 似乎很有效(比如 java-spotbugs,但您可能有 go-gofmtpy-black)

  5. 创建一个宏,使用 get_lint_config 为您查找配置。如果存在,创建一个新的测试规则实例。您可以在 这里 看到它的实际应用。

  6. 在编写代码时,确保调用您的宏。如果您是规则集作者,这可以简单到将上面创建的宏导出为调用规则的默认方式。

  7. ...

  8. 成功!

然后用户可以在 WORKSPACE 文件中使用"众所周知"的名称来指向配置规则的实例:

lint_setup({ "java-spotbugs": "//java:spotbugs-config", })

编辑推荐精选

潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

AI助手热门AI工具AI创作AI辅助写作讯飞绘文内容运营个性化文章多平台分发
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

热门AI工具生产力协作转型TraeAI IDE
商汤小浣熊

商汤小浣熊

最强AI数据分析助手

小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。

imini AI

imini AI

像人一样思考的AI智能体

imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。

Keevx

Keevx

AI数字人视频创作平台

Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。

下拉加载更多