Better structure
This commit is contained in:
parent
8fc1144b51
commit
6fb5337b61
26
SUMMARY.md
26
SUMMARY.md
@ -4,37 +4,31 @@
|
|||||||
* [Installing CMake](chapters/installing.md)
|
* [Installing CMake](chapters/installing.md)
|
||||||
* [Running CMake](chapters/running.md)
|
* [Running CMake](chapters/running.md)
|
||||||
* [What's new in CMake](chapters/newcmake.md)
|
* [What's new in CMake](chapters/newcmake.md)
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
## Making a CMakeLists
|
|
||||||
|
|
||||||
* [Introduction to the Basics](chapters/basics.md)
|
* [Introduction to the Basics](chapters/basics.md)
|
||||||
* [Variables and the Cache](chapters/options.md)
|
* [Variables and the Cache](chapters/basics/variables.md)
|
||||||
* [C++11 and Beyond](chapters/cpp11.md)
|
|
||||||
* [Adding Features](chapters/features.md)
|
|
||||||
* [How to Structure Your Project](chapters/structure.md)
|
* [How to Structure Your Project](chapters/structure.md)
|
||||||
|
* [Running Other Programs (X)](chapters/programs.md)
|
||||||
|
* [Adding Features](chapters/features.md)
|
||||||
|
* [C++11 and Beyond](chapters/cpp11.md)
|
||||||
|
* [Tidy and Format (X)](chapters/tidy.md)
|
||||||
|
* [IDEs (X)](chapters/IDEs.md)
|
||||||
|
* [Debugging (X)](chapters/debug.md)
|
||||||
* [Including Projects](chapters/projects.md)
|
* [Including Projects](chapters/projects.md)
|
||||||
* [Submodule](chapters/projects/submodule.md)
|
* [Submodule](chapters/projects/submodule.md)
|
||||||
* [DownloadProject](chapters/projects/download.md)
|
* [DownloadProject](chapters/projects/download.md)
|
||||||
* [Fetch (3.11)](chapters/projects/fetch.md)
|
* [Fetch (3.11)](chapters/projects/fetch.md)
|
||||||
* [Running Other Programs (X)](chapters/programs.md)
|
|
||||||
* [Testing](chapters/testing.md)
|
* [Testing](chapters/testing.md)
|
||||||
* [GoogleTest](chapters/testing/googletest.md)
|
* [GoogleTest](chapters/testing/googletest.md)
|
||||||
* [Catch](chapters/testing/catch.md)
|
* [Catch](chapters/testing/catch.md)
|
||||||
* [Tidy and Format (X)](chapters/tidy.md)
|
|
||||||
* [IDEs (X)](chapters/IDEs.md)
|
|
||||||
* [Debugging (X)](chapters/debug.md)
|
|
||||||
* [Exporting and Installing](chapters/exporting.md)
|
* [Exporting and Installing](chapters/exporting.md)
|
||||||
|
* [Built-in package discovery](chapters/builtin.md)
|
||||||
---
|
|
||||||
|
|
||||||
## Specific packages
|
|
||||||
* [CUDA](specifics/CUDA.md)
|
* [CUDA](specifics/CUDA.md)
|
||||||
* [OpenMP](specifics/OpenMP.md)
|
* [OpenMP](specifics/OpenMP.md)
|
||||||
* [Boost (X)](specifics/Boost.md)
|
* [Boost (X)](specifics/Boost.md)
|
||||||
* [MPI](specifics/MPI.md)
|
* [MPI](specifics/MPI.md)
|
||||||
|
* [Other common packages](chapters/external.md)
|
||||||
* [ROOT](specifics/ROOT.md)
|
* [ROOT](specifics/ROOT.md)
|
||||||
* [Simple Example](examples/root-simple/README.md)
|
* [Simple Example](examples/root-simple/README.md)
|
||||||
* [Simple Example CMake 3.11+](examples/root-simple-3.11/README.md)
|
* [Simple Example CMake 3.11+](examples/root-simple-3.11/README.md)
|
||||||
* [Dictionary Example](examples/root-dict/README.md)
|
* [Dictionary Example](examples/root-dict/README.md)
|
||||||
|
|
||||||
|
3
chapters/builtin.md
Normal file
3
chapters/builtin.md
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# Finding Package
|
||||||
|
|
||||||
|
There are two ways to find packages in CMake.
|
3
chapters/external.md
Normal file
3
chapters/external.md
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# Finding Package
|
||||||
|
|
||||||
|
There are two ways to find packages in CMake.
|
@ -14,24 +14,6 @@ target_link_libraries(MyTarget PUBLIC MPI::MPI_CXX)
|
|||||||
|
|
||||||
However, you can imitate this on CMake 3.1+ with:
|
However, you can imitate this on CMake 3.1+ with:
|
||||||
|
|
||||||
```cmake
|
|
||||||
find_package(MPI REQUIRED)
|
|
||||||
|
|
||||||
# For supporting CMake < 3.9:
|
|
||||||
if(NOT TARGET MPI::MPI_CXX)
|
|
||||||
add_library(MPI_LIB_TARGET INTERFACE)
|
|
||||||
add_library(MPI::MPI_CXX ALIAS MPI_LIB_TARGET)
|
|
||||||
|
|
||||||
target_compile_options(MPI_LIB_TARGET INTERFACE "${MPI_CXX_COMPILE_FLAGS}")
|
|
||||||
target_include_directories(MPI_LIB_TARGET INTERFACE "${MPI_CXX_INCLUDE_PATH}")
|
|
||||||
target_link_libraries(MPI_LIB_TARGET INTERFACE ${MPI_CXX_LINK_FLAGS} ${MPI_CXX_LIBRARIES})
|
|
||||||
endif()
|
|
||||||
|
|
||||||
message(STATUS "Run: ${MPIEXEC} ${MPIEXEC_NUMPROC_FLAG} ${MPIEXEC_MAX_NUMPROCS} ${MPIEXEC_PREFLAGS} EXECUTABLE ${MPIEXEC_POSTFLAGS} ARGS")
|
|
||||||
target_link_libraries(MyTarget PUBLIC MPI::MPI_CXX)
|
|
||||||
```
|
|
||||||
|
|
||||||
Or,
|
|
||||||
|
|
||||||
```cmake
|
```cmake
|
||||||
find_package(MPI REQUIRED)
|
find_package(MPI REQUIRED)
|
||||||
|
@ -12,23 +12,6 @@ endif()
|
|||||||
|
|
||||||
This not only is cleaner than the old method, it will also correctly set the library link line differently from the compile line if needed. However, if you need to support older CMake, the following works on CMake 3.1+:
|
This not only is cleaner than the old method, it will also correctly set the library link line differently from the compile line if needed. However, if you need to support older CMake, the following works on CMake 3.1+:
|
||||||
|
|
||||||
```cmake
|
|
||||||
# For CMake < 3.9, we need to make the target ourselves
|
|
||||||
if(NOT TARGET OpenMP::OpenMP_CXX)
|
|
||||||
add_library(OpenMP_TARGET INTERFACE)
|
|
||||||
add_library(OpenMP::OpenMP_CXX ALIAS OpenMP_TARGET)
|
|
||||||
target_compile_options(OpenMP_TARGET INTERFACE ${OpenMP_CXX_FLAGS})
|
|
||||||
# Only works if the same flag is passed to the linker; use CMake 3.9+ otherwise (Intel, AppleClang)
|
|
||||||
target_link_libraries(OpenMP_TARGET INTERFACE ${OpenMP_CXX_FLAGS})
|
|
||||||
find_package(Threads REQUIRED)
|
|
||||||
target_link_libraries(OpenMP_TARGET INTERFACE Threads::Threads)
|
|
||||||
endif()
|
|
||||||
target_link_libraries(MyTarget PUBLIC OpenMP::OpenMP_CXX)
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|
||||||
or,
|
|
||||||
|
|
||||||
|
|
||||||
```cmake
|
```cmake
|
||||||
# For CMake < 3.9, we need to make the target ourselves
|
# For CMake < 3.9, we need to make the target ourselves
|
||||||
|
Loading…
x
Reference in New Issue
Block a user