cmake把子目录加入工程
时间: 2023-10-15 15:02:42 浏览: 56
要将子目录添加到CMake项目中,你可以使用`add_subdirectory`命令。该命令将指定的子目录添加到当前项目中,并在构建过程中处理子目录中的CMakeLists.txt文件。
示例:
假设你的项目结构如下:
```
project/
CMakeLists.txt
main.cpp
subdirectory/
CMakeLists.txt
subfile.cpp
```
在主项目的CMakeLists.txt文件中,使用`add_subdirectory`命令添加子目录:
```cmake
cmake_minimum_required(VERSION 3.12)
project(MyProject)
# 添加子目录
add_subdirectory(subdirectory)
# 主项目的源文件
add_executable(main main.cpp)
# 链接子目录生成的库
target_link_libraries(main PRIVATE sublibrary)
```
在子目录的CMakeLists.txt文件中,定义子目录的源文件和生成的库:
```cmake
# 子目录的源文件
set(SUB_SOURCES subfile.cpp)
# 生成库
add_library(sublibrary ${SUB_SOURCES})
```
这样,当你构建主项目时,CMake会同时构建子目录并生成子目录中定义的库。你可以根据需要进一步设置子目录的编译选项、链接选项等。
相关问题
cmake 复杂工程目录
CMake是一个跨平台的开源构建工具,可以用来管理C++项目。复杂的C++工程一般会有多个子目录,每个子目录中可能包含多个源文件和头文件。使用CMake可以方便地管理这些源文件和头文件,同时也可以定义编译选项和链接选项,方便构建和管理整个项目。
下面是一个复杂的C++工程目录结构示例:
```
project/
├── CMakeLists.txt
├── lib/
│ ├── CMakeLists.txt
│ ├── lib1/
│ │ ├── CMakeLists.txt
│ │ ├── src/
│ │ │ ├── file1.cpp
│ │ │ └── file2.cpp
│ │ └── include/
│ │ ├── file1.h
│ │ └── file2.h
│ └── lib2/
│ ├── CMakeLists.txt
│ ├── src/
│ │ ├── file1.cpp
│ │ └── file2.cpp
│ └── include/
│ ├── file1.h
│ └── file2.h
├── app/
│ ├── CMakeLists.txt
│ ├── src/
│ │ ├── main.cpp
│ │ ├── file1.cpp
│ │ └── file2.cpp
│ └── include/
│ ├── file1.h
│ └── file2.h
└── test/
├── CMakeLists.txt
├── src/
│ ├── test1.cpp
│ └── test2.cpp
└── include/
├── test1.h
└── test2.h
```
其中,项目根目录下的CMakeLists.txt文件是整个项目的主要配置文件,lib、app和test三个子目录分别是库、应用程序和测试代码的目录。每个子目录下也有自己的CMakeLists.txt文件,用于定义该子目录的构建规则。
通过CMake可以实现如下功能:
- 在项目根目录下的CMakeLists.txt中设置整个项目的编译选项和链接选项;
- 在每个子目录下的CMakeLists.txt中设置该子目录下的源文件、头文件和依赖库;
- 在根目录下的CMakeLists.txt中引用各子目录下的CMakeLists.txt文件,实现整个项目的构建。
cmake 多级目录编译
CMake是一个跨平台的开源构建工具,用于管理软件项目的编译过程。它使用CMakeLists.txt文件来描述项目的构建规则,并生成适用于不同编译系统的构建脚本。
在CMake中,多级目录编译是指将一个大型项目分为多个子目录,并在每个子目录中编写独立的CMakeLists.txt文件来管理编译过程。这种方式可以提高项目的可维护性和可扩展性。
下面是一个简单的多级目录编译的示例:
假设我们有一个名为"project"的项目,包含以下目录结构:
```
project/
|- CMakeLists.txt
|- src/
|- CMakeLists.txt
|- main.cpp
|- include/
|- header.h
```
1. 在项目根目录下的CMakeLists.txt文件中,我们可以设置一些全局的编译选项和链接库:
```cmake
cmake_minimum_required(VERSION 3.0)
project(project)
# 设置编译选项
set(CMAKE_CXX_STANDARD 11)
# 添加子目录
add_subdirectory(src)
```
2. 在src目录下的CMakeLists.txt文件中,我们可以编写与该子目录相关的编译规则:
```cmake
# 添加可执行文件
add_executable(project main.cpp)
# 添加头文件搜索路径
target_include_directories(project PUBLIC ${CMAKE_SOURCE_DIR}/include)
```
3. 在main.cpp中,我们可以引用头文件"header.h"并编写相应的代码。
这样,当我们在项目根目录下执行cmake命令时,CMake会自动递归地处理每个子目录的CMakeLists.txt文件,并生成相应的构建脚本。最终,我们可以使用生成的构建脚本来编译和构建我们的项目。