使用 cmake 传递复合编译器选项
Pass compound compiler options using cmake
我正在尝试使用 cmake 的 add_compile_options
将 "compound" 选项传递给编译器。
也就是说,涉及两个(或更多)标志的选项必须按特定顺序传递,其中 none 标志可以省略,即使它们已经传递给编译器。
一个例子是必须通过 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(flag)
.
这样便携的东西
但是,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 所说,使用这个变量是完全可以的。
我正在尝试使用 cmake 的 add_compile_options
将 "compound" 选项传递给编译器。
也就是说,涉及两个(或更多)标志的选项必须按特定顺序传递,其中 none 标志可以省略,即使它们已经传递给编译器。
一个例子是必须通过 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(flag)
.
但是,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 所说,使用这个变量是完全可以的。