存储库用户执行预定义 bazel 查询的最便捷方式 背景

问题描述

我正在编写一个存储库规则,我需要执行一个查询,以便我可以在我的包管理器中使用该查询输出

bazel query 'rdeps(//...,@package_manager//...) except @package_manager//...' --output=xml

让此存储库的用户执行此查询的最方便的方法是什么?

理想情况下,我可以为此使用 genquery,但由于 //... 查询范围,genquery 出错。

我考虑过让用户执行我定义的目标并将其通过管道传输到他们的 shell 中:bazel run @package_manager//:query" | shell 但这看起来很尴尬,并且显然会在似乎不需要时创建对 shell 的依赖,并且要求用户信任我将给他们的任何 shell 命令,这似乎是错误的形式。

背景

我正在制定规则以与 dotnet 的 nuget 包管理器一起使用。 Nuget 包管理有一个有趣的特性,即每个包都声明多个目标框架的依赖关系。当目标 A 声明对包 P 的依赖时,nuget 检查目标 A 以确定其目标框架列表是什么。确定目标框架列表后,nuget 为给定的目标框架解析包 P 的传递依赖关系。

本质上,每个包由子包组成:P:version:target-framework,即Newtonsoft.Json:12.0.3:netstandard2.0

然而,当目标声明对包的依赖时,目标只是列出 P_version,不包括目标框架。更重要的是,即使Newtonsoft.Json只有一个明确定义netstandard2.0的包,这个框架也兼容netstandard2.1。

为了在 Bazel 中适应这一点,我想保持与 nuget 生态系统相同的依赖管理风格,但指定包存储库范围内的版本。即我希望用户指定类似

nuget_install([
    "Newtonsoft.Json:12.0.3"
])

在工作区中,并指定:

dotnet_library(
    name="A"
    target_frameworks = ["netstandard2.1"]
    deps=[":B","@nuget//newtonsoft.json"]
)
dotnet_library(
    name="A"
    target_frameworks = ["netstandard1.0"]
    deps=["@nuget//newtonsoft.json"]
)

在构建中。

那么结果:

  1. 获取 newtonsoft.json:12.0.3:netstandard2.0 的依赖项(因为没有),并且此版本与目标 netstandard2.1 兼容
  2. 获取 newtonsoft.json:12.0.3:netstandard1.0 的依赖项(因为有一些) Dependencies by target framework are under the dependencies section

我计划让用户检查 nuget packages.lock.json 文件,因此第二次不需要查询目标,而是进行第一次获取,当用户更改任何目标框架版本时,看起来我需要在 nuget 能够计算给定包的依赖图的传递闭包之前查询依赖于这些包的目标框架的 bazel。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)