cmake使用install安装库
如果你是库开发者,你应该学习install命令。这个命令很简单,其实就是把编译出来的文件(可执行文件、静态库、动态库、头文件等)拷贝到相应的目录下面。
原理
一个典型的install命令如下所示
install(TARGETS main mylib mylib-shared main
ARCHIVE #静态库
DESTINATION lib
LIBRARY #动态库
DESTINATION lib
RUNTIME #可执行文件
DESTINATION bin
)
以上命令会安装一个动态库,一个静态库,一个可执行文件。CMAKE会根据target类型自动推断。TARGETS 表示我们现在要安装的是TARGETS,除此之外你还可以安装FILES、DIRECTORY等。这里不讲。
通过ARCHIVE/LIBRARY/RUNTIME关键字分别指定静态库、动态库和可执行文件的属性。比如指定安装后缀DESTINATION。例如静态库安装路径就是前缀+后缀=${CMAKE_INSTALL_PREFIX}/install/lib。还可以从/开始直接指定绝对路径。
其中CMAKE_INSTALL_PREFIX可以通过顶层目录中的CMakeLists.txt来定义(注意,需要是顶层目录)。你也可以通过-D CMAKE_INSTALL_PREFIX=xxx来从外部命令行传递。
实例
目录结构
.
├── CMakeLists.txt
└── src
├── CMakeLists.txt
├── main.cpp
├── mylib.cpp
└── mylib.h
我们这里编译一个可执行文件main,一个静态库,一个动态库。
顶层的 CMakeLists
cmake_minimum_required(VERSION 3.16)
project(learn-cmake LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_EXTENSIONS OFF)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
if(NOT CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE Release CACHE STRING "Build type" FORCE)
endif()
# 设置安装的位置前缀。默认在Unix-like是/usr/local, 在Windows是C:\Program Files。注意!这个设置必须在顶层的CMakeLists.txt当中指定!
set(CMAKE_INSTALL_PREFIX ${CMAKE_SOURCE_DIR}/install)
message("CMAKE_SOURCE_DIR: ${CMAKE_SOURCE_DIR}")
message("CMAKE_INSTALL_PREFIX: ${CMAKE_INSTALL_PREFIX}")
add_subdirectory(src)
src/CMakeLists.txt
add_executable(main main.cpp)
# 编译静态库
add_library(mylib mylib.cpp mylib.h)
# 编译动态库。注意在Windows平台需要将WINDOWS_EXPORT_ALL_SYMBOLS设置为ON(默认为OFF),以设置符号可见性。
if(WIN32)
set(WINDOWS_EXPORT_ALL_SYMBOLS ON)
endif()
add_library(mylib-shared SHARED mylib.cpp mylib.h)
# 安装可执行文件,静态库和动态库。CMAKE会根据target类型自动推断。
# 通过ARCHIVE/LIBRARY/RUNTIME关键字分别指定静态库、动态库和可执行文件的属性。比如指定安装后缀DESTINATION。例如静态库安装路径就是前缀+后缀=${CMAKE_SOURCE_DIR}/install/lib。还可以从/开始直接指定绝对路径。
install(TARGETS main mylib mylib-shared main
ARCHIVE #静态库
DESTINATION lib
LIBRARY #动态库
DESTINATION lib
RUNTIME #可执行文件
DESTINATION bin
)
src/main.cpp
#include<iostream>
int main()
{
std::cout<<"hello world\n";
return 0;
}
mylib.cpp
#include "mylib.h"
float sum(float a, float b)
{
return a+b;
}
mylib.h
float sum(float a, float b);
运行结果
cmake -B build
cmake --build build --config=Release --target=install
输出
MSBuild version 17.3.1+2badb37d1 for .NET Framework
Checking Build System
Building Custom Rule E:/learn/cmake/src/CMakeLists.txt
main.cpp
main.vcxproj -> E:\learn\cmake\build\src\Release\main.exe
Building Custom Rule E:/learn/cmake/src/CMakeLists.txt
mylib.cpp
mylib.vcxproj -> E:\learn\cmake\build\src\Release\mylib.lib
Building Custom Rule E:/learn/cmake/src/CMakeLists.txt
mylib.cpp
mylib-shared.vcxproj -> E:\learn\cmake\build\src\Release\mylib-shared.dll
Building Custom Rule E:/learn/cmake/CMakeLists.txt
-- Install configuration: "Release"
-- Installing: E:/learn/cmake/install/bin/main.exe
-- Installing: E:/learn/cmake/install/lib/mylib.lib
-- Installing: E:/learn/cmake/install/bin/mylib-shared.dll
-- Up-to-date: E:/learn/cmake/install/bin/main.exe
会在当前项目根目录下产生install文件夹,并且在Install文件夹中出现
.
├── bin
│ ├── main.exe
│ └── mylib-shared.dll
└── lib
└── mylib.lib
执行main.exe
hello world