如何用cmake自定义宏
可以这样自定义宏在CMake中:
- 使用 add_definitions() 命令定义宏。例如:
add_definitions(-DMY_MACRO)
这会在编译时定义 MY_MACRO 宏。
2. 在 CMakeLists.txt 文件开头使用 set 命令定义宏。例如:
set(MY_MACRO 1)
这会在 CMake 处理时定义 MY_MACRO 宏为 1。
3. 使用 option 命令定义可选宏。例如:
option(USE_MYLIB "Use MyLib" ON)
这会定义 USE_MYLIB 宏,如果选项为 ON 则定义该宏,如果为 OFF 则不定义。
4. 对于只在 Debug 模式下定义的宏,可以:
if(CMAKE_BUILD_TYPE STREQUAL "Debug")
add_definitions(-DDEBUG)
endif()
这会在 Debug 模式下定义 DEBUG 宏。
5. 对于只在 Release 模式下定义的宏,可以:
if(CMAKE_BUILD_TYPE STREQUAL "Release")
add_definitions(-DRELEASE)
endif()
所以通过 add_definitions, set, option, if条件判断等就可以灵活地自定义不同类型的宏。
可以在生成库是不定义宏,在生成可执行文件时定义宏吗
是的,CMake 可以在生成库和可执行文件时分别定义不同的宏。
例如:
# 库的 CMakeLists.txt
add_library(mylib lib.cpp)
# 可执行文件的 CMakeLists.txt
add_executable(myapp main.cpp)
target_compile_definitions(myapp PRIVATE MY_MACRO=1)
在生成 mylib 库时,不会定义任何宏。
但在生成 myapp 可执行文件时,会定义 MY_MACRO=1 这个宏。
target_compile_definitions 指定的宏定义是 TARGET 级别的,只对指定的 target 生效。
所以通过 target_compile_definitions 可以为可执行文件定义宏,而库目标不定义该宏。
此外,如果希望库和可执行文件共享的宏,可以在顶层 CMakeLists.txt 中定义:
add_definitions(-DSHARED_MACRO=1)
add_subdirectory(lib)
add_subdirectory(app)
这样库和可执行文件都会继承 SHARED_MACRO 宏定义。
所以通过合理使用 add_definitions 和 target_compile_definitions 就可以实现在库和可执行文件中分别定义宏的效果。
target_compile_definitions定义无值的宏要如何定义
在使用 target_compile_definitions 定义无值的宏时,直接指定宏名称即可,不需要给出值。
例如:
add_executable(myapp main.cpp)
target_compile_definitions(myapp PUBLIC ENABLE_LOGGING)
这会在编译 myapp 时定义 ENABLE_LOGGING 宏,但不给出值。
在 C/C++ 源代码中可以直接使用:
#ifdef ENABLE_LOGGING
// 日志代码
#endif
来判断该宏是否被定义。
也可以通过设置宏值为 1 来实现相同效果:
target_compile_definitions(myapp PUBLIC ENABLE_LOGGING=1)
这样 ENABLE_LOGGING 宏的值为 1,在 C/C++ 中可以通过:
#if ENABLE_LOGGING
// 日志代码
#endif
来判断宏是否定义。
所以 target_compile_definitions 定义无值宏,可以直接指定宏名,或者设置值为 1。都可以在源码中用 #ifdef 或 #if 来检查该宏是否存在。