XcodeDeps

XcodeDeps 工具是 Xcode 的依赖信息生成器。它将生成多个 .xcconfig 配置文件,这些文件可供使用 xcodebuildXcode 的消费者使用。要使用它们,只需将生成的配置文件添加到 Xcode 项目中,或在命令行中设置 -xcconfig 参数。

XcodeDeps 生成器可以在 conanfiles 中按名称使用

conanfile.py
class Pkg(ConanFile):
    generators = "XcodeDeps"
conanfile.txt
[generators]
XcodeDeps

它也可以在 conanfile 的 generate() 方法中完全实例化

conanfile.py
from conan import ConanFile
from conan.tools.apple import XcodeDeps

class Pkg(ConanFile):
    settings = "os", "compiler", "arch", "build_type"
    requires = "libpng/1.6.37@" # Note libpng has zlib as transitive dependency

    def generate(self):
        xcode = XcodeDeps(self)
        xcode.generate()

当使用 XcodeDeps 生成器时,每次调用 conan install 都会为每个依赖项和配置生成多个配置文件。例如,对于上面的 conanfile.py

$ conan install conanfile.py # default is Release
$ conan install conanfile.py -s build_type=Debug

此生成器是多配置的。它将为每个依赖项的不同 Debug/Release 配置生成不同的文件。它还将生成一个单独的文件 (conandeps.xcconfig),该文件汇总了所有直接依赖项的文件(在此例中仅为 libpng)。上面的命令会生成以下文件:

.
├── conan_config.xcconfig
├── conan_libpng.xcconfig
├── conan_libpng_libpng.xcconfig
├── conan_libpng_libpng_debug_x86_64.xcconfig
├── conan_libpng_libpng_release_x86_64.xcconfig
├── conan_zlib.xcconfig
├── conan_zlib_zlib.xcconfig
├── conan_zlib_zlib_debug_x86_64.xcconfig
├── conan_zlib_zlib_release_x86_64.xcconfig
└── conandeps.xcconfig

第一次使用默认的 Releasex86_64 配置运行 conan install 会生成:

  • conan_libpng_libpng_release_x86_64.xcconfig:声明带有条件逻辑的变量,这些变量仅在 Xcode 的活动配置或传递给 xcodebuild 的命令行配置中考虑。

  • conan_libpng_libpng.xcconfig:包含 conan_libpng_libpng_release_x86_64.xcconfig 并声明以下 Xcode 构建设置:SYSTEM_HEADER_SEARCH_PATHSGCC_PREPROCESSOR_DEFINITIONSOTHER_CFLAGSOTHER_CPLUSPLUSFLAGSFRAMEWORK_SEARCH_PATHSLIBRARY_SEARCH_PATHSOTHER_LDFLAGS。它还包含传递性依赖项生成的 xcconfig 文件(在此例中为 conan_zlib_zlib.xcconfig)。

  • conan_libpng.xcconfig:在这种情况下,它仅包含 conan_libpng_libpng.xcconfig,但如果所需包有组件,则此文件将包含该包的所有组件。

  • 将为图中的每个依赖项生成相同的 3 个文件。在此例中,由于 zliblibpng 的依赖项,它将生成:conan_zlib_zlib_release_x86_64.xcconfigconan_zlib_zlib.xcconfigconan_zlib.xcconfig

  • conandeps.xcconfig:包含所有直接依赖项的配置文件,在此例中,它仅包含 conan_libpng.xcconfig

  • conan_config.xcconfig 文件,将添加到项目中。如果也设置了 XcodeToolchain,则它将包含来自此生成器以及 XcodeToolchain 生成的文件。

第二次运行 conan install -s build_type=Debug 会生成:

  • conan_libpng_libpng_debug_x86_64.xcconfig:为 Debug 配置声明与下方相同的变量。

  • conan_libpng_libpng.xcconfig:此文件已由上一个命令创建,现在会修改它以添加对 conan_libpng_debug_x86_64.xcconfig 的包含。

  • conan_libpng.xcconfig:此文件将保持不变。

  • 与上一个命令一样,将为图中的每个依赖项生成相同的 3 个文件。在此例中,由于 zliblibpng 的依赖项,它将生成:conan_zlib_zlib_debug_x86_64.xcconfigconan_zlib_zlib.xcconfigconan_zlib.xcconfig

  • conandeps.xcconfig:包含所有直接依赖项的配置文件,在此例中,它仅包含 conan_libpng.xcconfig

  • conan_config.xcconfig 文件,将添加到项目中。如果也设置了 XcodeToolchain,则它将包含来自此生成器以及 XcodeToolchain 生成的文件。

如果要将这些依赖项添加到 Xcode 项目中,只需将 conan_config.xcconfig 配置文件添加到所有要使用的配置(通常是 DebugRelease)即可。

附加变量定义

除了定义 Xcode 构建设置的上述变量之外,还声明了一些附加变量,这些变量可能在 Xcode 项目中使用很有用。

组件支持

此生成器支持带有组件的包。这意味着:

  • 如果一个依赖项package_info() 在一些组件上声明了 cpp_info.requires,则生成的 .xcconfig 文件将仅包含对这些组件的包含。

  • 当前包的 requires 将完全依赖于所有组件。请注意,package_info() 仅适用于使用者,而不适用于当前包。

自定义配置

如果您的 Xcode 项目定义了自定义配置,例如 ReleaseSharedMyCustomConfig,则可以将其定义到 XcodeDeps 生成器中,以便不同的项目配置可以使用不同的依赖项集。假设我们当前的可以构建为共享库,并使用自定义配置 ReleaseShared,并且包也通过 shared 选项来控制这一点:

from conan import ConanFile
from conan.tools.apple import XcodeDeps

class Pkg(ConanFile):
    settings = "os", "compiler", "arch", "build_type"
    options = {"shared": [True, False]}
    default_options = {"shared": False}
    requires = "zlib/1.3.1"

    def generate(self):
        xcode = XcodeDeps(self)
        # We assume that -o *:shared=True is used to install all shared deps too
        if self.options.shared:
            xcode.configuration = str(self.settings.build_type) + "Shared"
        xcode.generate()

这将生成此自定义配置的新 .xcconfig 文件,当您在 IDE 中切换到此配置时,构建系统将根据我们是想链接共享库还是静态库来获取正确的值。