Conan 其他重要功能¶
python_requires¶
可以使用 python_requires 功能 重用其他 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 和包,同时保留在给定时间段内使用过的(最近最少使用 LRU 策略)。这可以通过 conan remove
和 conan list
命令的 --lru
参数实现。
# 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。