如何解决存储库用户执行预定义 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"]
)
在构建中。
那么结果:
- 不获取 newtonsoft.json:12.0.3:netstandard2.0 的依赖项(因为没有),并且此版本与目标 netstandard2.1 兼容
- 获取 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 举报,一经查实,本站将立刻删除。