其他重要的 Conan 功能¶
python_requires¶
可以使用 python_requires 功能 重用来自其他 recipe 的代码。
如果您维护许多用于不同包的 recipe,这些 recipe 共享一些通用逻辑,并且您不想在每个 recipe 中重复代码,您可以将该通用代码放在 Conan 的 conanfile.py
中,将其上传到您的服务器,并让其他 recipe conanfile 执行 python_requires = "mypythoncode/version"
来依赖它并重用它。
包列表¶
可以使用“packages-list”功能管理包、recipe 和二进制文件的列表。诸如 upload
、download
和 remove
等多个命令允许接收包列表文件作为输入,并且它们可以对该列表执行操作。一个典型的用例是“将最近在 conan create
中构建的包上传到服务器”,这可以通过以下方式完成
$ conan create . --format=json > build.json
$ conan list --graph=build.json --graph-binaries=build --format=json > pkglist.json
$ conan upload --list=pkglist.json -r=myremote -c
请参阅 本节中的示例。
从缓存中删除未使用的包¶
警告
最近最少使用功能处于预览阶段。有关更多信息,请参见 Conan 稳定性 部分。
Conan 缓存不实现任何自动过期策略,因此除非删除包或不时从缓存中删除,否则其大小将始终增加。 可以删除最近未使用的 recipe 和包,同时保留在给定时间段内使用的 recipe 和包(最近最少使用 LRU 策略)。这可以通过 --lru
参数传递给 conan remove
和 conan list
命令来完成
# remove all binaries (but not recipes) not used in the last 4 weeks
$ conan remove "*:*" --lru=4w -c
# remove all recipes that have not been used in the last 4 weeks (with their binaries)
$ conan remove "*" --lru=4w -c
请注意,LRU 时间遵循 remove
命令的规则。如果我们使用 "*"
模式删除 recipe,则只会检查 recipe 的 LRU 时间。如果一个 recipe 最近被使用过,它将保留所有的二进制文件,如果该 recipe 最近没有被使用过,它将删除自己和它的所有二进制文件。如果我们使用 "*:*"
模式,它将只检查二进制文件,并删除那些未使用的,但始终保留 recipe。
首先使用 conan list
(请记住,与 remove
相反,conan list
默认情况下不列出所有修订版本,因此如果需要选择所有修订版本,则必须明确指定 #*
),可以创建最近最少使用的包的列表
# List all unused (last 4 weeks) recipe revisions
$ conan list "*#*" --lru=4w --format=json > old.json
# Remove those recipe revisions (and their binaries)
$ conan remove --list=old.json -c
请参阅命令帮助 conan remove 和 conan list。