NMakeDeps

此生成器可以这样使用:

from conan import ConanFile

class Pkg(ConanFile):
    settings = "os", "compiler", "build_type", "arch"

    requires = "mydep/1.0"
    # attribute declaration
    generators = "NMakeDeps"

    # OR explicit usage in the generate() method
    def generate(self):
        deps = NMakeDeps(self)
        deps.generate()

    def build(self):
        self.run(f"nmake /f makefile")

生成器将创建一个 conannmakedeps.bat 环境脚本,该脚本定义了 CLLIB_LINK_ 环境变量,注入必要的标志以定位和链接 requires 中声明的依赖项。此生成器最有可能与 NMakeToolchain 一起使用。

NMakeToolchain

此生成器可以这样使用:

from conan import ConanFile

class Pkg(ConanFile):
    settings = "os", "compiler", "build_type", "arch"
    generators = "NMakeToolchain"

    def build(self):
        self.run("nmake /f makefile")

或者,它可以在 conanfile 的 generate() 方法中完全实例化:

from conan import ConanFile
from conan.tools.microsoft import NMakeToolchain

class Pkg(ConanFile):
    settings = "os", "arch", "compiler", "build_type"

    def generate(self):
        tc = NMakeToolchain(self)
        tc.generate()

    def build(self):
        self.run("nmake /f makefile")

NMakeToolchain 生成器将创建一个 conannmaketoolchain.bat 环境脚本,注入从 profile 推断出的标志(build_type、runtime、cppstd、conf 中的 build flags),放入 NMake 可理解的环境变量中:CL_LINK_。它还将生成一个 conanvcvars.bat 脚本,该脚本激活与 Conan host 设置 archcompilercompiler.version 以及 build 设置 arch 匹配的正确 VS 提示。

构造函数

def __init__(self, conanfile):
  • conanfile:当前配方对象。始终使用 self

属性

如果要在调用 generate() 方法之前注入更多标志,可以更改某些属性。

from conan import ConanFile
from conan.tools.microsoft import NMakeToolchain

class Pkg(ConanFile):
    settings = "os", "arch", "compiler", "build_type"

    def generate(self):
        tc = NMakeToolchain(self)
        tc.extra_cflags.append("/my_flag")
        tc.extra_defines.append("FOO=BAR")
        tc.generate()
  • extra_cflags(默认为 []):附加的 cflags。

  • extra_cxxflags(默认为 []):附加的 cxxflags。

  • extra_defines(默认为 []):附加的宏定义。

  • extra_ldflags(默认为 []):附加的 ldflags。

conf

NMaketoolchain 受以下 [conf] 变量影响:

  • tools.build:cflags:将由 CL 使用的附加纯 C 标志列表。

  • tools.build:cxxflags:将由 CL 使用的附加 C++ 标志列表。

  • tools.build:defines:将由 CL 使用的预处理器定义列表。

  • tools.build:sharedlinkflags:将由 _LINK_ 使用的附加链接器标志列表。

  • tools.build:exelinkflags:将由 _LINK_ 使用的附加链接器标志列表。

  • tools.build:compiler_executables 一个类似字典的 Python 对象,其中编译器作为键,编译器可执行文件路径作为值。这些键将映射如下

    • asm:将在 conannmaketoolchain.sh|bat 脚本中设置 AS

    • c:将在 conannmaketoolchain.sh|bat 脚本中设置 CC

    • cpp:将在 conannmaketoolchain.sh|bat 脚本中设置 CPPCXX

    • rc:将在 conannmaketoolchain.sh|bat 脚本中设置 RC

自定义环境

如果您的 Makefile 脚本需要 CL_LINK_ 以外的其他环境变量,您可以在调用 generate() 方法之前对其进行自定义。调用 environment() 方法来计算上述变量,然后添加您需要的变量。environment() 方法返回一个 Environment 对象。

from conan import ConanFile
from conan.tools.microsoft import NMakeToolchain

class Pkg(ConanFile):
    settings = "os", "arch", "compiler", "build_type"

    def generate(self):
        tc = NMakeToolchain(self)
        env = tc.environment()
        env.define("FOO", "BAR")
        tc.generate(env)

您还可以检查 NMakeToolchain 将在 conannmaketoolchain.sh|bat 脚本中注入的默认环境变量。

from conan import ConanFile
from conan.tools.microsoft import NMakeToolchain

class Pkg(ConanFile):
    settings = "os", "arch", "compiler", "build_type"

    def generate(self):
        tc = NMakeToolchain(self)
        env_vars = tc.vars()
        cl_env_var = env_vars.get("CL")