cmake语法:option,add_definition,add_dependencies的基本作用
add_dependencies
在cmake中,add_dependencies的作用是为了指明当前的执行程序依赖的动态库,而在编译的时候,对于依赖关系,会告诉编译器针对动态库编译的先后顺序,对于以下的命令:
ADD_EXECUTABLE(main main.cpp)
TARGET_LINK_LIBRARIES(main a.so b.so c.so d.so)
首先是生成执行程序,通过main.cpp,生成main,在生成main的时候,TARGET_LINK_LIBRARIES链接到了四个动态库,而此时已经生成了main,所以会提示main函数链接的时候出现错误。一些符号的定义找不到,而这些符号恰恰就在这几个库中,假设在a.so 和 b.so中,在上述两条指令之间加上一条指令即可编译通过:
ADD_DEPENDENCIES(main a.so b.so)
原因比较简单,生成main需要依赖a.so和b.so中的符号定义,然而a.so和b.so库的生成是在main编译生产之后的,添加这条语句就是提醒编译器需要先生成main的依赖(a.so,b.so),然后再去生成main.
option
使用场景:通过编译脚本(CMakeLists)传递参数(源代码中定义的宏)
#include <iostream>
int main() {
#ifdef TEST
std::cout<<"Hello,Test"<<std::endl;
#endif
std::cout << "Hello, World!" << std::endl;
return 0;
}
CMakeLists.txt 内容如下:
cmake_minimum_required(VERSION 3.13)
project(cmake_option_example_00)
set(CMAKE_CXX_STANDARD 14)
option(TEST "option for TEST" OFF)
if(TEST)
add_definitions(-DTEST)
endif()
add_executable(cmake_option_example_00 main.cpp)
其中:
option 的格式如下:
option(编译开关 “一些简单的描述” NO/OFF)
option(TEST "option for TEST" OFF)
编译命令:
cmake .
cmake -DTEST=NO .
add_definitions
add_definitions的功能和C/C++中的#define是一样的,
#include <iostream>
int main()
{
#ifdef TEST_IT_CMAKE
std::cout<<"in ifdef"<<std::endl;
#endif
std::cout<<"not in ifdef"<<std::endl;
}
cmake_minimum_required(VERSION 3.10)
project(optiontest)
add_executable(optiontest main.cpp)
option(TEST_IT_CMAKE "test" ON)
message(${TEST_IT_CMAKE})
if(TEST_IT_CMAKE)
message("itis" ${TEST_IT_CMAKE})
add_definitions(-DTEST_IT_CMAKE)
endif()
其中的下边两部分一般是连在一起用的(message语句仅为了更好的输出变量,无特殊意义)
option(TEST_IT_CMAKE "test" ON)
message(${TEST_IT_CMAKE})
if(TEST_IT_CMAKE)
message("itis" ${TEST_IT_CMAKE})
add_definitions(-DTEST_IT_CMAKE)
endif()
通过option设置一个变量,并通过add_definitions将其转换为#define TEST_IT_CMAKE