diff --git a/docs/cmake.md b/docs/cmake.md index 08092c8..c14dc54 100644 --- a/docs/cmake.md +++ b/docs/cmake.md @@ -11,8 +11,13 @@ CMake 备忘清单 CMake 是一个用于配置跨平台源代码项目应该如何配置的工具建立在给定的平台上。 ```bash -├┈ CMakeLists.txt # 希望运行的 CMake 命令 -╰┈ main.cpp # 带有 main 的源文件 +├── CMakeLists.txt # 希望运行的 CMake命令 +├── main.cpp # 带有main 的源文件 +├── include # 头文件目录 +│   └── header.h +└── src # 源代码目录 + ├── a.c + └── b.c ``` 在此项目上运行 `CMake` 时,系统会要求您提供二进制目录,运行 `CMake` 不会创建最终的可执行文件,而是会为 `Visual Studio`、`XCode` 或 `makefile` 生成项目文件。 使用这些工具构建该项目 @@ -26,6 +31,18 @@ cmake_minimum_required(VERSION 3.5) project (hello_cmake) # 添加可执行文件 add_executable(hello_cmake main.cpp) +# 添加头文件目录 +target_include_directories(hello_cmake PRIVATE ./include) +# 批量添加源文件 +file(GLOB SRCS CONFIGURE_DEPENDS ./src/*.cpp) +target_sources(hello_cmake PUBLIC ${SRCS}) +# 添加第三方库 +find_package(OpenGL CONFIG REQUIRED) +# 链接第三方库 +target_link_libraries(hello_cmake PRIVATE OpenGL) +# 指定输出路径 +set_property(TARGET hello_cmake ${CMAKE_SOURCE_DIR}/bin) + ``` #### main.cpp @@ -46,6 +63,7 @@ int main(int argc, char *argv[]) $ mkdir build # 创建 build 目录 $ cd build # 进入目录 $ cmake .. # 目录的上一级目录运行命令 +$ make # 使用对应的编译工具 $ ./hello_cmake # 运行生成的 hello_cmake Hello CMake! ``` @@ -72,6 +90,12 @@ $ cmake --build [] [-- ] $ cmake --install [] ``` +运行指定项目 + +```bash +cmake --build --target +``` + 打开一个项目 ```bash @@ -108,6 +132,30 @@ $ cmake --workflow [] $ cmake --help[-] ``` +#### 常用参数 + +- 方式一: 在`CMakeLists.txt`中使用`set(KEY VAL)`函数 +- 方式二: 在执行`cmake ...` -D 指定(只需一次,推荐) + +```cmake +# 指定编译参数(Debug/Release/MinSizeRel/RelWithDebInfo) +$ cmake ... -D CMAKE_BUILD_TYPE=DEBUG +# 指定编译链工具(windows下vcpkg需要) +$ cmake ... -D CMAKE_TOOLCHAIN_FILE=/scripts/buildsystems/vcpkg.cmake +# 指定编译器 +$ cmake ... -D CAMKE_C_COMPILER=... +$ cmake ... -D CAMKE_CXX_COMPILER=... +# 指定生成器 +$ cmake .. -G "Unix Makefile" +$ cmake .. -G "Ninja" +$ cmake .. -G "Visual Studio 17 2022" + +# 设置Cpp标准 +set(CMAKE_CXX_STANDARD 17) +set(CMAKE_CXX_STANDARD_REQUIRED ON) # 在检测到不支持时出错 +set(CMAKE_CXX_EXTENSIONS ON) #一般设为off,否则在msvc上没有特性会出错 +``` + 另见 ----