用来查找第三方依赖包的 .cmake文件,并根据.cmake文件生成依赖包的头文件目录和库文件路径等;
CMakeLists.txt实例
find_package(Protobuf REQUIRED)
include_directories(${PROTOBUF_INCLUDE_DIR})
add_executable(main src/main.cpp)
target_link_libraries(main ${PROTOBUF_LIBRARIES})
find_package从默认目录中寻找Protobuf,找到后将头文件目录设置为${PROTOBUF_INCLUDE_DIR},库文件位置设置为${PROTOBUF_LIBRARIES},然后在工程中包含protobuf头文件目录,链接库文件,生成可执行文件
补充:.cmake文件就像CMakeLists.txt的库一样,加载后可以在CMakeList.txt中使用它的一些函数和定义,提供最小可用配置
find_package包括设置查询路径和默认查询路径
默认查询路径
find_package查找.cmake的默认查询路径有如下
PATH
CMAKE_PREFIX_PATH
CMAKE_FRAMEWORK_PATH
CMAKE_APPBUNDLE_PATH
echo $PATH可查询PATH包含哪些默认查询路径,以默认路径为根目录,find_package将查询目录下包含的.cmake文件
设置查询路径
让find_package在指定路径找依赖包,有三种方式
# 1. 设置DIR
set(Torch_DIR /home/libtorch)
find_package(Torch REQUIRED)
# 2. 设置PATHS
find_package(Protobuf REQUIRED
PATHS /home/libtorch
NO_DEFAULT_PATH)
# 3. 指定
set(CMAKE_PREFIX_PATH /home/libtorch)
【参考文章】
find_package查找指定路径的方式
find_package的用法
find_package实例
find_library的用法
找不到xxxConfig.cmake怎么解决
created by shuaixio, 2023.09.06