Yet another dependency manager for projects using CMake.
According to CMake documentation, the best way to consume a CMake dependency is to install it and find it. Using includes just creates mess.
This helper can fetch, build and install CMake dependencies in a specific directory that you can add to your project with -DCMAKE_PREFIX_PATH
.
It keeps your system environment clean as you won't mix libraries up.
This can be also convenient for Fortran projects where installing libraries is not the standard due to the volatility of mod
files.
Simply install the project with pip
:
pip install dependencmake
This package is managed with Poetry:
pip install poetry
Install from downloaded repository with:
poetry install --no-dev
The generic usage of the command is:
ENV=value dependencmake action path/to/cmake/dir
which is pretty close to how CMake is called.
The program will fetch/build/install desired dependencies and stored the result of the different actions in a dependencmake
directory in the current directory.
The program will look for a dependencmake.yaml
file in the specified directory, where dependencies are listed:
dependencies:
- name: My dependency
url: file://my_server/my_dep.zip
cmake_args: -DUSE_MPI=ON
- name: My other dependency
url: http://my_repo/my_other_dep.git
git_hash: 25481515
More info on the accepted parameters in the configuration file section.
The program accepts several actions:
create-config
to create a new configuration file;list
to list dependencies collected in the configuration file;fetch
to fetch dependencies and copy them on local disk;build
to fetch and build dependencies;install
to fetch, build and install dependencies;clean
to clean the cache.
The build
and install
actions will take any other arguments and pass them directly to CMake at configure step.
If you call fetch
, build
or install
a second time, already fetched dependencies will most likely not be fetched again.
Git dependencies will be pulled (unless git_no_update
is set) and other kind of dependencies will rest untouched.
Example of workflow:
mkdir build
cd build
dependencmake install .. -DCMAKE_BUILD_TYPE=Release
cmake .. -DCMAKE_PREFIX_PATH=$PWD/dependencmake/install -DCMAKE_BUILD_TYPE=Release
make
the -DCMAKE_INSTALL_PREFIX
argument is required to tell CMake where dependencies are installed.
It is possible to set the install prefix to a custom value with the install-prefix
argument.
In this case dependencies will be installed in this directory instead of in the DependenCmake cache:
mkdir build
cd build
dependencmake install --install-prefix lib/extern .. -DCMAKE_BUILD_TYPE=Release
cmake .. -DCMAKE_PREFIX_PATH=$PWD/lib/extern -DCMAKE_BUILD_TYPE=Release
make
The configuration file uses the YAML format.
It stores dependencies information in the dependencies
key as a list.
Each item contains the following possible keys:
name
: Name of the dependency, used for display. Mandatory;url
: URL where to get the dependency. Can be a Git repository, online only (must end by.git
), an archive, online or local (must end by.zip
,.tar
,.tar.bz2
,.tbz2
,.tar.gz
,.tgz
,.tar.xz
or.txz
), or a plain directory, local only. Mandatory;git_hash
: Git hash to checkout to in case of Git repository. The hash can be a commit hash or a tag. Optional;git_no_update
: When set totrue
, if the Git repository has been cloned, it will not been pulled on another run. Optional;cmake_subdir
: Subdirectory where to find the CMakeLists.txt file if it is not in the top directory. Optional;cmake_args
: Specific arguments to pass to CMake at configuration time. Optional;jobs
: Number of jobs to use when building the dependency. By default, number of CPU cores * 2 + 1. Optional.
DependenCmake will put generated data in a dependencmake
cache folder in the current working directory:
dependencmake/
+-- build/
+-- fetch/
+-- install/
It's pretty clear what the purpose of each subfolder of the cache is.
fetch
and build
both contain a subfolder for each dependency.
The dependency directory name is the lower case and slugified name of the dependency, appended with a MD5 hash of the URL.
This allows to make the directory unique per couple name/URL and humanly readable.
install
has no logic enforced and is populated according to the install
directives of the CMakeLists.txt
files of the dependencies.
After fetching dependencies, they are checked to detect patterns not managed by the program. For now, diamond dependencies (where the same dependency is requested by two others) are invalid if they are not strictly equivalent.