FetchDependency is a CMake module that provides a mechanism to download, configure, build and install (local to the calling project) a dependency package at configuration time.
FetchDependency is designed to enable dependency handling in CMake according to a specific philosophy:
- A project's dependencies should be made available automatically, to enable the quickest turnaround time from fetching a project from source control to a successful build of that project.
- A project's dependencies should be stored with it by default, rather than in a global location, in order to isolate the project from changes made outside the project itself.
- A project's dependencies should not pollute the targets of the project or any other dependencies, in order to avoid target name collisions and keep a the project's target list focused.
The cost of the aforementioned features is increased configuration time when using FetchDependency, especially during the initial configuration, as all dependencies are downloaded and built from source. To alleviate that impact, FetchDependency tracks the version of each dependency in order to avoid unneccessarily invoking a build.
The recommended way to automatically include FetchDependency in your project is to use CMake's FetchContent module:
include(FetchContent)
FetchContent_Declare(FetchDependency
GIT_REPOSITORY https://github.com/jpetrie/fetch-dependency.git
GIT_TAG origin/main
)
FetchContent_MakeAvailable(FetchDependency)
include(${fetchdependency_SOURCE_DIR}/FetchDependency.cmake)
FetchDependency requires CMake 3.25 or later.
FetchDependency provides a single function, fetch_dependency()
, which will fetch and find a dependency package:
fetch_dependency(Catch2 GIT_REPOSITORY https://github.com/catchorg/Catch2.git GIT_TAG v2.13.8)
This will fetch, configure, build and install Catch2 within the calling project's
CMake binary directory. It will then call find_package()
to locate the dependency and make it available to future
targets immediately:
target_link_libraries(... Catch2::Catch2)
Download, build and locally install a dependency named <name>
during configuration.
fetch_dependency(
<name>
GIT_REPOSITORY <url>
GIT_TAG <tag>
[CONFIGURATION <configuration>]
[GENERATE_OPTIONS <options...>]
[BUILD_OPTIONS <options...>]
[CMAKELIST_SUBDIRECTORY <path>]
)
<name>
is used to create the directory where the dependency's source and artifacts will be stored and doesn't need to
correspond to the official name of the dependency.
Options:
-
GIT_REPOSITORY <url>
URL of the Git repository. If the globalFETCH_DEPENDENCY_PREFIX
is set, the dependency will be cloned beneath that directory. Otherwise, the dependency will be cloned underneathCMAKE_BINARY_DIR/External
. Using `FETCH_DEPENDENCY_PREFIX can be useful when a project has many configurations, as it will allow all configurations to share the dependency artifacts. -
GIT_TAG <tag>
Git branch name, tag or commit hash. A commit hash is the recommended means of specifying a dependency version. Branches and tags should generally be specified as remote names to ensure the local clone will be correctly updated in the event of a tag move, branch rebase, or history rewrite. -
CONFIGURATION <name>
Use the named configuration instead of the default for the dependency. Specifying a configuration via this option will work correctly regardless of whether or not the generator in use is a single- or multi-configuration generator. If not specified, "Release" is assumed. -
GENERATE_OPTIONS <options...>
Pass the following options to CMake when generating the dependency. -
BUILD_OPTIONS <options...>
Pass the following options to CMake's--build
command when building the dependency. -
CMAKELIST_SUBDIRECTORY <path>
The path to the directory containing theCMakeLists.txt
for the dependency if it is not located at the dependency root. Always interpreted as a path relative to the dependency root.