我正在尝试使用 cmake 的 add_compile_options
将“复合”选项传递给编译器。
也就是说,选项涉及两个(或更多)必须以特定顺序传递的标志,并且即使它们已经传递给编译器,也不能省略任何标志。
一个例子是必须通过 clang 传递给 llvm 的所有 llvm 选项,例如,-mllvm -ABC -mllvm -XYZ -mllvm ...
。
我宁愿不使用 CMake 的反模式 set (CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mllvm -ABC")
而是使用像 check_cxx_compiler_flag(flag available)
这样的可移植的东西 + add_compile_option(标志)
。
但是,add_compile_options(-mllvm -XYZ -mllvm -ABC)
失败,因为 -mllvm
选项被缓存并且只传递一次,这样 - mllvm -XYZ -ABC
被传递导致错误。
此外,使用引号 ""也无济于事,因为引号也会被传递(即它们不会被删除),这也会导致错误。
使用 CMake 传递这些选项的惯用方式是什么?
最佳答案
您在这里观察到的不是 CMake 保留引号。
CMake 有一种特殊的字符串——一个列表。列表是一个字符串,其中的元素用 ";"
分隔。当您编写 somefunction(A B C)
时,您实际上构造了一个字符串 "A;B;C"
,它也是一个包含 3 个元素的列表。但是,当您编写 somefunction("A B C")
时,您传递的是一个纯字符串。
现在,当您编写 add_compile_options("-mllvm -XYZ;-mllvm -ABC")
时,CMake 做了正确的事情(在某种意义上)——它向编译器传递了两个命令行参数,"-mllvm -XYZ
"和 "-mllvm -ABC"
。问题是 clang 也将这些参数作为两个。也就是说,clang 的 main()
中的 argv[i]
指向 "-mllvm -XYZ"
字符串,clang 将其视为单个标志。
我能看到的唯一解决方案是使用 CMAKE_{C,CXX}_FLAGS
设置这些标志。正如@Tsyvarev 所说,使用这个变量是完全可以的。
关于c++ - 使用 cmake 传递复合编译器选项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35365252/