CMake 基础

简单的语法
•注释
# 我是注释•命令语法
COMMAND(参数1 参数2 ...)
•字符串列表
A;B;C # 分号分割或空格分隔的值
•变量(字符串或字符串列表)
set(Foo a b c)
 设置变量 Foo
 
command(${Foo})
 等价于 command(a b c)
command("${Foo}")
 等价于 command("a b c")
command("/${Foo}")
 转义,和 a b c无关联
 
•流控制结构
IF()...ELSE()/ELSEIF()...ENDIF()
WHILE()...ENDWHILE()
FOREACH()...ENDFOREACH()
正则表达式

•正则表达式
部分经常使用命令
INCLUDE_DIRECTORIES( "dir1" "dir2" ... )
 头文件路径,至关于编译器参数 -Idir1 -Idir2
 
LINK_DIRECTORIES("dir1" "dir2")
 库文件路径。注意:
因为历史缘由,相对路径会原样传递给连接器。
尽可能使用FIND_LIBRARY而避免使用这个。
 
AUX_SOURCE_DIRECTORY( “sourcedir” variable)
 收集目录中的文件名并赋值给变量
 
ADD_EXECUTABLE
 可执行程序目标
 
ADD_LIBRARY
 库目标
 
ADD_CUSTOM_TARGET
 自定义目标
 
ADD_DEPENDENCIES( target1 t2 t3 )
 目标target1依赖于t2 t3
 
ADD_DEFINITIONS( "-Wall -ansi")
 本意是供设置 -D... /D... 等编译预处理须要的宏定义参数,对比 REMOVE_DEFINITIONS()
 
TARGET_LINK_LIBRARIES( target-name lib1 lib2 ...)
 设置单个目标须要连接的库
 
LINK_LIBRARIES( lib1 lib2 ...)
 设置全部目标须要连接的库
 
SET_TARGET_PROPERTIES( ... )
 设置目标的属性 OUTPUT_NAME, VERSION, ....
 
MESSAGE(...)
  
INSTALL( FILES “f1” “f2”DESTINATION . )
 DESTINATION 相对于 ${CMAKE_INSTALL_PREFIX}
 
SET( VAR value [CACHE TYPE DOCSTRING [FORCE]])
  
LIST( APPEND|INSERT|LENGTH|GET| REMOVE_ITEM|REMOVE_AT|SORT ...)
 列表操做
 
STRING( TOUPPER|TOLOWER|LENGTH| SUBSTRING|REPLACE|REGEX ...)
 字符串操做
 
SEPARATE_ARGUMENTS( VAR )
 转换空格分隔的字符串到列表
 
FILE( WRITE|READ|APPEND|GLOB| GLOB_RECURSE|REMOVE|MAKE_DIRECTORY ...)
 文件操做
 
FIND_FILE
 注意 CMAKE_INCLUDE_PATH
 
FIND_PATH
 注意 CMAKE_INCLUDE_PATH
 
FIND_LIBRARY
 注意 CMAKE_LIBRARY_PATH
 
FIND_PROGRAM
  
FIND_PACKAGE
 注意 CMAKE_MODULE_PATH
 
EXEC_PROGRAM( bin [work_dir] ARGS <..> [OUTPUT_VARIABLE var] [RETURN_VALUE var] )
 执行外部程序
 
OPTION( OPTION_VAR “description” [initial value] )
  
变量
工程路径
•CMAKE_SOURCE_DIR
•PROJECT_SOURCE_DIR
•<projectname>_SOURCE_DIR
这三个变量指代的内容是一致的,是工程顶层目录
spa

•CMAKE_BINARY_DIR
•PROJECT_BINARY_DIR
•<projectname>_BINARY_DIR
这三个变量指代的内容是一致的,若是是in source编译,指得就是工程顶层目录,若是 是out-of-source编译,指的是工程编译发生的目录
命令行

•CMAKE_CURRENT_SOURCE_DIR
指的是当前处理的CMakeLists.txt所在的路径。
ip

•CMAKE_CURRRENT_BINARY_DIR
若是是in-source编译,它跟CMAKE_CURRENT_SOURCE_DIR一致,若是是out-ofsource 编译,他指的是target编译目录。
字符串

•CMAKE_CURRENT_LIST_FILE
输出调用这个变量的CMakeLists.txt的完整路径
get

CMAKE_BUILD_TYPE
控制 Debug 和 Release 模式的构建
编译器

•CMakeList.txt文件
SET(CMAKE_BUILD_TYPE Debug)
•命令行参数
cmake DCMAKE_BUILD_TYPE=Release编译器参数
•CMAKE_C_FLAGS
•CMAKE_CXX_FLAGS
也能够经过指令ADD_DEFINITIONS()添加
it

CMAKE_INCLUDE_PATH
配合 FIND_FILE() 以及 FIND_PATH() 使用。若是头文件没有存放在常规路径(/usr/include, /usr/local/include等),
则能够经过这些变量就行弥补。若是不使用 FIND_FILE 和 FIND_PATH的话,CMAKE_INCLUDE_PATH,没有任何做用。
io

•CMAKE_LIBRARY_PATH
配合 FIND_LIBRARY() 使用。不然没有任何做用
编译

•CMAKE_MODULE_PATH
cmake 为上百个软件包提供了查找器(finder):FindXXXX.cmake

当使用非cmake自带的finder时,须要指定finder的路径,这就是CMAKE_MODULE_PATH,配合 FIND_PACKAGE()使用
CMAKE_INSTALL_PREFIX
控制make install是文件会安装到什么地方。默认定义是/usr/local 或 %PROGRAMFILES%

BUILD_SHARED_LIBS
若是不进行设置,使用ADD_LIBRARY且没有指定库类型,默认编译生成的库是静态库。

UNIX 与 WIN32 •UNIX,在全部的类UNIX平台为TRUE,包括OS X和cygwin •WIN32,在全部的win32平台为TRUE,包括cygwin

相关文章
相关标签/搜索