1. find_package的作用与实例
-
用来查找第三方依赖包的 .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中使用它的一些函数和定义,提供最小可用配置
2. find_package的查询路径
-
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怎么解决