cmake使用教(二) install的使用_cmakelist install

    [RUNTIME_DEPENDENCIES args...|RUNTIME_DEPENDENCY_SET <set-name>]
    [[ARCHIVE|LIBRARY|RUNTIME|OBJECTS|FRAMEWORK|BUNDLE|
      PRIVATE_HEADER|PUBLIC_HEADER|RESOURCE]
     [DESTINATION <dir>]
     [PERMISSIONS permissions...]
     [CONFIGURATIONS [Debug|Release|...]]
     [COMPONENT <component>]
     [NAMELINK_COMPONENT <component>]
     [OPTIONAL] [EXCLUDE_FROM_ALL]
     [NAMELINK_ONLY|NAMELINK_SKIP]
    ] [...]
    [INCLUDES DESTINATION [<dir> ...]]
    )

下表显示了目标类型及其关联变量和内置默认值,这些默认值适用于未指定目标的情况:




| 目标类型 | GNUInstallDirs 变量 | 内置默认值 |
| --- | --- | --- |
| `RUNTIME` | `${CMAKE_INSTALL_BINDIR}` | `bin` |
| `LIBRARY` | `${CMAKE_INSTALL_LIBDIR}` | `lib` |
| `ARCHIVE` | `${CMAKE_INSTALL_LIBDIR}` | `lib` |
| `PRIVATE_HEADER` | `${CMAKE_INSTALL_INCLUDEDIR}` | `include` |
| `PUBLIC_HEADER` | `${CMAKE_INSTALL_INCLUDEDIR}` | `include` |


参数中的TARGETS后面跟的就是我们通过ADD\_EXECUTABLE 或者ADD\_LIBRARY 定义的目标文件,可能是可执行二进制、动态库、静态库。  
 目标类型也就相对应的有三种,ARCHIVE特指静态库,LIBRARY特指动态库,RUNTIME特指可执行目标二进制。  
 DESTINATION定义了安装的路径,如果路径以/开头,那么指的是绝对路径,这时候CMAKE\_INSTALL\_PREFIX其实就无效了.  
 如果你希望使用CMAKE\_INSTALL\_PREFIX来定义安装路径,就要写成相对路径,即不要以/开头,那么安装后的路径就是${CMAKE\_INSTALL\_PREFIX}/<DESTINATION定义的路径>  
 举个简单的例子:



INSTALL(TARGETS myrun mylib mystaticlib
RUNTIME DESTINATION bin
LIBRARY DESTINATION lib
ARCHIVE DESTINATION libstatic
)


上面的例子会将:  
 可执行二进制myrun 安装到${CMAKE\_INSTALL\_PREFIX}/bin 目录  
 动态库libmylib安装到${CMAKE\_INSTALL\_PREFIX}/lib目录  
 静态库libmystaticlib 安装到${CMAKE\_INSTALL\_PREFIX}/libstatic目录  
 特别注意的是你不需要关心TARGETS具体生成的路径,只需要写上TARGETS名称就可以  
 了。


## 2.普通文件安装



install(<FILES|PROGRAMS> files…
TYPE | DESTINATION


[PERMISSIONS permissions…]
[CONFIGURATIONS [Debug|Release|…]]
[COMPONENT ]
[RENAME ] [OPTIONAL] [EXCLUDE_FROM_ALL])





| `TYPE` Argument | GNUInstallDirs Variable | Built-In Default |
| --- | --- | --- |
| `BIN` | `${CMAKE_INSTALL_BINDIR}` | `bin` |
| `SBIN` | `${CMAKE_INSTALL_SBINDIR}` | `sbin` |
| `LIB` | `${CMAKE_INSTALL_LIBDIR}` | `lib` |
| `INCLUDE` | `${CMAKE_INSTALL_INCLUDEDIR}` | `include` |
| `SYSCONF` | `${CMAKE_INSTALL_SYSCONFDIR}` | `etc` |
| `SHAREDSTATE` | `${CMAKE_INSTALL_SHARESTATEDIR}` | `com` |
| `LOCALSTATE` | `${CMAKE_INSTALL_LOCALSTATEDIR}` | `var` |
| `RUNSTATE` | `${CMAKE_INSTALL_RUNSTATEDIR}` | `<LOCALSTATE dir>/run` |
| `DATA` | `${CMAKE_INSTALL_DATADIR}` | `<DATAROOT dir>` |
| `INFO` | `${CMAKE_INSTALL_INFODIR}` | `<DATAROOT dir>/info` |
| `LOCALE` | `${CMAKE_INSTALL_LOCALEDIR}` | `<DATAROOT dir>/locale` |
| `MAN` | `${CMAKE_INSTALL_MANDIR}` | `<DATAROOT dir>/man` |
| `DOC` | `${CMAKE_INSTALL_DOCDIR}` | `<DATAROOT dir>/doc` |


可用于安装一般文件,并可以指定访问权限,文件名是此指令所在路径下的相对路径。如果默认不定义权限PERMISSIONS,安装后的权限为:  
 OWNER\_WRITE, OWNER\_READ, GROUP\_READ,和WORLD\_READ,即 644权限。 


## 3.目录的安装



install(DIRECTORY dirs…
TYPE | DESTINATION


[FILE_PERMISSIONS permissions…]
[DIRECTORY_PERMISSIONS permissions…]
[USE_SOURCE_PERMISSIONS] [OPTIONAL] [MESSAGE_NEVER]
[CONFIGURATIONS [Debug|Release|…]]
[COMPONENT ] [EXCLUDE_FROM_ALL]
[FILES_MATCHING]
[[PATTERN | REGEX ]
[EXCLUDE] [PERMISSIONS permissions…]] […])


这里主要介绍其中的DIRECTORY、PATTERN 以及 PERMISSIONS 参数。  
 DIRECTORY 后面连接的是所在Source目录的相对路径,但务必注意:abc和 abc/有很大的区别。  
 如果目录名不以/结尾,那么这个目录将被安装为目标路径下的abc,如果目录名以/结尾,  
 代表将这个目录中的内容安装到目标路径,但不包括这个目录本身。  
 PATTERN用于使用正则表达式进行过滤,PERMISSIONS用于指定PATTERN过滤后的文件权限。  
 我们来看一个例子:



INSTALL(DIRECTORY icons scripts/ DESTINATION share/myproj
PATTERN “CVS” EXCLUDE
PATTERN “scripts/*”
PERMISSIONS OWNER_EXECUTE OWNER_WRITE OWNER_READ
GROUP_EXECUTE GROUP_READ)


这条指令的执行结果是:  
 将icons 目录安装到 <prefix>/share/myproj,将 scripts/中的内容安装到  
 <prefix>/share/myproj  
 不包含目录名为CVS的目录,对于scripts/\* 文件指定权限为 OWNER\_EXECUTE  
 OWNER\_WRITE OWNER\_READ GROUP\_EXECUTE GROUP\_READ.


这里测试一下:根据[上一篇]( )的文章进行安装测试:


## 4.测试


修改根目录下的CMakeLists.txt文件如下,其实就增加了install,这里你需要先创建几个文件,才能尝试安装:



多个目录多个源文件

cmake_minimum_required(VERSION 2.8)

project(test1)

遍历当前目录的所有文件并使用DIR_SRCS保存,也可以通过SET(SRC_LIST main.c)进行指定

aux_source_directory(. DIR_SRCS)

添加生成可执行文件的保存目录,不会保存中间产物,如果不指定该目录则和中间产物保存在一起

set(EXECUTABLE_OUTPUT_PATH ${PROJECT_BINARY_DIR}/bin )

添加头文件

include_directories(${PROJECT_SOURCE_DIR}/include)

这里将子目录条件到工程,并指定编译的输出产物,默认输出产物保存到build/src文件夹下,

如果不指定库目录保存路径同样也会保存到该路径下

add_subdirectory(src)

上面定义了将src子目录加入工程,并指定编译输出(包含编译中间结果)路径为

bin目录。如果不进行 bin目录的指定,那么编译结果(包括中间结果)都将存放在

build/src 目录(这个目录跟原有的src目录对应),指定 bin 目录后,相当于在编译时

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值