使用Cmake遇到如下情况:
1.将主功能class生成一个库
2.有代码可以调用这个库,用于测试
环境:Windows10,VS2019
写了一个小demo,文件结构如图。
1. testCMakeLib文件夹下包含
HelloLib文件夹
CMakeLists.txt
main.cpp
2. HelloLib文件夹下包含
inc文件夹
src文件夹
CMakeLists.txt
3. inc文件夹下包含
Hello.h
4. src文件夹下包含
Hello.cpp
HelloLib文件夹下生成库hello_static_library,保存在lib文件夹中
CMakeLists.txt
cmake_minimum_required (VERSION 3.8)
SET(LIBRARY_OUTPUT_PATH ./lib)
#set( STATIC_LIB_SOURCES
# src/Hello.cpp
#)
file(GLOB STATIC_LIB_SOURCES ./src/*.cpp)
add_library( hello_static_library STATIC
${STATIC_LIB_SOURCES}
)
target_include_directories( hello_static_library PUBLIC
${CMAKE_CURRENT_SOURCE_DIR}/inc
)
inc/Hello.h
class Hello
{
public:
void print();
};
src/Hello.cpp
#include <iostream>
#include "Hello.h"
void Hello::print()
{
std::cout << "Hello Static Library!" << std::endl;
}
testCMakeLib文件夹下main程序可以调试程序
CMakeLists.txt
cmake_minimum_required (VERSION 3.8)
project ("testCMakeLib")
set( EXE_SOURCES
main.cpp
)
# 包含子项目。
add_subdirectory ("HelloLib")
add_executable( hello_world_exe ${EXE_SOURCES} )
target_include_directories( hello_world_exe PRIVATE
${PROJECT_SOURCE_DIR}/HelloLib/inc
)
target_link_libraries( hello_world_exe PRIVATE
hello_static_library
)
main.cpp
#include "Hello.h"
int main(int argc, char* argv[])
{
Hello hi;
hi.print();
return 0;
}
Cmake常用变量
PROJECT_SOURCE_DIR:工程的根目录
PROJECT_BINARY_DIR:运行cmake命令的目录,通常为${PROJECT_SOURCE_DIR}/build
PROJECT_NAME:返回通过 project 命令定义的项目名称
CMAKE_CURRENT_SOURCE_DIR:当前处理的 CMakeLists.txt 所在的路径
CMAKE_CURRENT_BINARY_DIR:target 编译目录
CMAKE_CURRENT_LIST_DIR:CMakeLists.txt 的完整路径
EXECUTABLE_OUTPUT_PATH:重新定义目标二进制可执行文件的存放位置
LIBRARY_OUTPUT_PATH:重新定义目标链接库文件的存放位置
把./src目录下所有符合*.cpp结尾的文件存入USER_LIBS_PATH变量中
file(GLOB USER_LIBS_PATH ./src/*.cpp)
不但在当前目录需要引入,还需要在当前目录子目录引入了,这里就直接使用GLOB_RECURSE
file(GLOB_RECURSE USER_LIBS_PATH ./src/*.cpp)
参考: