CMakeLists.txt加载头文件和源文件目录下的所有文件

# CMake 最低版本号要求
cmake_minimum_required (VERSION 2.8)

# ---项目信息
project (Project1)

# --- Find OpenMp dependencies
FIND_PACKAGE( OpenMP REQUIRED)
if(OPENMP_FOUND)
    message("OPENMP FOUND")
    set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${OpenMP_C_FLAGS}")
    set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${OpenMP_CXX_FLAGS}")
    set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${OpenMP_EXE_LINKER_FLAGS}")
else()
    message(STATUS "Not found OpenMP")
endif()

# --- 执行文件输出路径
set(EXECUTABLE_OUTPUT_PATH ${PROJECT_SOURCE_DIR}/bin)

# --- 头文件和源文件保存路径
set(INCLUDE_DIR ./include)
set(SRC_DIR ./src)

include_directories(${INCLUDE_DIR})
file(GLOB_RECURSE SOURCES "${SRC_DIR}/*.cpp")

add_executable(${PROJECT_NAME} test.cpp ${SOURCES})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
对于大型的 C++ 项目,可能需要将代码分为多个模块,并使用多个 CMakeLists.txt 文件来管理它们。下面是一个使用多个 CMakeLists.txt 文件来管理 C++ 多文件项目的示例: 假设我们有以下项目结构: ``` myproject/ ├── CMakeLists.txt ├── module1/ │ ├── CMakeLists.txt │ ├── include/ │ │ └── module1.h │ └── src/ │ └── module1.cpp └── module2/ ├── CMakeLists.txt ├── include/ │ └── module2.h └── src/ └── module2.cpp ``` 其中,`myproject` 目录下的 `CMakeLists.txt` 文件是主 CMakeLists.txt 文件,它用于管理整个项目。`module1` 目录和 `module2` 目录是两个子模块,每个子模块都有自己的 `CMakeLists.txt` 文件文件源文件。 现在,我们需要使用 CMake 来构建这个项目。我们可以在 `myproject` 目录下创建一个主 CMakeLists.txt 文件,并添以下内容: ```cmake cmake_minimum_required(VERSION 3.10) project(myproject) # 添目录 add_subdirectory(module1) add_subdirectory(module2) ``` 该 CMakeLists.txt 文件指定了项目的最低 CMake 版本和项目名称。`add_subdirectory` 命令用于添目录,它告诉 CMake 去处理 `module1` 和 `module2` 这两个子目录中的 CMakeLists.txt 文件。 接下来,我们需要在 `module1` 目录下创建一个名为 `CMakeLists.txt` 的文件,并添以下内容: ```cmake # 添文件搜索路径 include_directories(include) # 添源文件 add_library(module1 src/module1.cpp) # 暴露文件 target_include_directories(module1 PUBLIC include) ``` 该 CMakeLists.txt 文件指定了 `module1` 子模块的构建规则。`include_directories` 命令添文件搜索路径,它告诉 CMake 在 `include` 目录中查找文件。`add_library` 命令编译 `module1.cpp` 源文件并生成一个静态库文件 `libmodule1.a`。最后,`target_include_directories` 命令将 `include` 目录暴露给其他模块,以便它们可以包含 `module1.h` 文件。 然后,在 `module2` 目录下创建一个名为 `CMakeLists.txt` 的文件,并添以下内容: ```cmake # 添文件搜索路径 include_directories(include) # 添源文件 add_library(module2 src/module2.cpp) # 暴露文件 target_include_directories(module2 PUBLIC include) ``` 该 CMakeLists.txt 文件指定了 `module2` 子模块的构建规则,与 `module1` 子模块类似。 完成以上步骤后,我们可以使用以下命令来构建项目: ```bash mkdir build cd build cmake .. make ``` `mkdir build` 创建了一个构建目录,`cd build` 进入该目录,`cmake ..` 命令使用上面的主 CMakeLists.txt 文件来构建项目,`make` 命令编译源代码并生成可执行文件。 这就是一个使用多个 CMakeLists.txt 文件来管理 C++ 多文件项目的示例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Cynthia.Chen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值