2021更新:修复CMakeLists.txt,解决PowerGraph deps依赖包编译问题

需积分: 5 2 下载量 45 浏览量 更新于2024-08-11 收藏 28KB TXT 举报
在PowerGraph项目的CMakeLists.txt文件中,主要关注的是如何处理项目依赖管理和构建配置。这个文件对于维护一个依赖于特定库(如deps)的C++项目至关重要,尤其是当外部依赖的下载地址出现过时时。以下是关键知识点的详细解读: 1. **项目初始化**: - `project(GraphLab)`:首先声明项目名为GraphLab,这将定义项目的基本结构和目录。 2. **CMake版本要求**: - `cmake_minimum_required(VERSION 2.8)`:指定最低支持的CMake版本,确保项目可以在当前或较新的CMake环境中正常构建。 3. **政策更新**: - `cmake_policy(SET CMP0003 NEW)` 和 `cmake_policy(SET CMP0005 NEW)`:这两个政策设置允许自动处理预处理器定义值的转义和添加额外的GraphLab特定CMake模块路径,提高了构建过程的自动化程度。 4. **模块路径设置**: - `set(CMAKE_MODULE_PATH ${GraphLab_SOURCE_DIR}/cmake)`:指定CMake模块搜索路径,以便在构建过程中可以找到自定义的GraphLab模块。 5. **库类型选择**: - `set(BUILD_SHARED_LIBS ON)`:这表示项目将编译共享库,即动态链接库,这对于跨平台部署和性能优化通常是有益的。 6. **依赖库检查**: - `include(CheckLibraryExists)`、`include(CheckFunctionExists)`:这些函数用于检查系统上是否存在特定的库函数或库文件,确保编译时所需的依赖已正确安装。 7. **外部项目管理**: - `include(ExternalProject)`:用于管理第三方库的外部项目,可能需要从源代码构建,以解决下载地址失效的问题。 8. **体系结构检测**: - `checkweareona64bitsystem(else fail)`:通过检查机器的位宽(CMAKE_SIZEOF_VOID_P),确保系统是64位,因为GraphLab不支持32位。 9. **系统信息展示**: - `include(CMakePrintSystemInformation)`:这个函数用于显示关于构建环境的信息,帮助开发者理解当前的系统配置。 10. **头文件包含**: - `include_directories`:指定了需要在项目中搜索头文件的目录,包括项目源代码、CxxTest库以及本地deps目录。 PowerGraph的CMakeLists.txt文件着重于项目配置、依赖管理、平台兼容性和构建过程中的自动化。它通过设置CMake变量、政策、模块路径以及依赖库检查,确保了项目的顺利编译和部署,尤其是在外部依赖库更新频繁的情况下。