Apple 应用和 Bazel

报告问题 查看来源 每晚 · 7.4。 ,了解所有最新动态。 7.3 · 7.2 · 7.1敬上 · 7.0敬上 · 6.5

本页包含有助于您使用 Bazel 构建 macOS 和 iOS 项目的资源。此页面提供了指向相关教程、构建规则和 使用 Bazel 来构建和测试这些平台

使用 Bazel

以下资源可帮助您在 macOS 和 iOS 项目中使用 Bazel:

迁移到 Bazel

如果您目前使用 Xcode 构建 macOS 和 iOS 项目,请按照迁移指南中的步骤开始使用 Bazel 构建这些项目:

Apple 应用和新规则

注意:创建新规则适用于高级构建和测试场景。开始使用 Bazel 时,您无需执行此操作。

以下模块、配置 fragment 和提供程序将有助于您 扩展 Bazel 的功能 请在构建 macOS 和 iOS 项目时执行以下操作:

Xcode 选择

如果您的 build 需要 Xcode,Bazel 将根据 --xcode_config--xcode_version 标志选择适当的版本。--xcode_config 会使用一组可用的 Xcode 版本,如果未传递 --xcode_version,则会设置默认版本。只要 --xcode_version 标志设置为 --xcode_config 目标中表示的 Xcode 版本,此默认值就会被替换。

如果您没有传递 --xcode_config,Bazel 将使用自动生成的 XcodeVersionConfig,用于表示 主机上可用的 Xcode 版本。默认版本为 最新可用的 Xcode 版本。这适合本地执行。

如果您要执行远程构建,应将 --xcode_config 设置为 xcode_config 目标,其 versions 属性为可远程访问的 xcode_version 目标的列表,其 default 属性为这些 xcode_versions 之一。

如果您使用的是动态执行,则应将 --xcode_config 设置为 xcode_config 目标,其 remote_versions 属性为 available_xcodes target 包含远程可用的 Xcode 版本,并且其 local_versions 属性是 available_xcodes target 包含本地可用的 Xcode 版本。对于local_versions, 那么您可能需要使用自动生成的 @local_config_xcode//:host_available_xcodes。默认 Xcode 版本是可互用的最新版本(如果有),否则为 local_versions 目标的默认版本。如果您想使用 local_versions 默认值作为默认值,可以传递 --experimental_prefer_mutual_default=false