A minimalistic tool to automate source code cloning and building
Project description
forest
The forest project aims at automatizing the clone and build process for open source software. Differently from other systems such as Conda, or Conan, it is a non-intrusive system which does not aim at environment management.
Quickstart
Setup a new workspace and add new recipes. Optional arguments are surrounded by [square brackets].
[sudo] pip3 install hhcm-forest
mkdir my_ws && cd my_ws
forest init
source setup.bash
forest add-recipes git@github.com:advrhumanoids/multidof_recipes.git [--tag master]
Install the xbot2_examples
recipe with its dependencies.
forest grow xbot2_examples [-j8] [--clone-protocol https]
Command line interface
Forest's CLI is divided into three main verbs, i.e. init
, add-recipes
, and grow
.
forest init
Initialize the current folder as a forest workspace, i.e. it creates
- a
src
folder that will contain source code - a
recipes
folder that will contain forest's recipe files (more on this later) - a
build
folder to carry out compilation and store build artifacts - an
install
folder - a
setup.bash
file which makes installed items visible to the system
forest add-recipes
Adds recipes from a remote.
usage: forest add-recipes [-h] [--tag TAG] [--verbose] url
positional arguments:
url url of the remote (e.g. git@github.com:<username>/<reponame>.git
or https://github.com/<username>/<reponame>.git)
optional arguments:
-h, --help show this help message and exit
--tag TAG, -t TAG
--verbose, -v print additional information
forest grow
Builds a project according to the given recipe name, alongside its dependencies.
usage: forest grow [-h] [--jobs JOBS] [--mode MODE [MODE ...]]
[--config CONFIG [CONFIG ...]]
[--default-build-type {None,RelWithDebInfo,Release,Debug}]
[--force-reconfigure] [--list-eval-locals]
[--clone-protocol {ssh,https}] [--clone-depth CLONE_DEPTH]
[--cmake-args CMAKE_ARGS [CMAKE_ARGS ...]] [--no-deps]
[--uninstall] [--clean] [--pwd PWD] [--verbose]
[RECIPE]
positional arguments:
RECIPE name of recipe with fetch and build information
optional arguments:
-h, --help show this help message and exit
--jobs JOBS, -j JOBS parallel jobs for building
--mode MODE [MODE ...], -m MODE [MODE ...]
specify modes that are used to set conditional
compilation flags (e.g., cmake args)
--config CONFIG [CONFIG ...], -c CONFIG [CONFIG ...]
specify configuration variables that can be used
inside recipes
--default-build-type {None,RelWithDebInfo,Release,Debug}, -t {None,RelWithDebInfo,Release,Debug}
build type for cmake, it is overridden by recipe
--force-reconfigure force calling cmake before building with args from the
recipe
--list-eval-locals print available attributes when using conditional
build args
--clone-protocol {ssh,https}
override clone protocol
--clone-depth CLONE_DEPTH
set maximum history depth to save bandwidth
--cmake-args CMAKE_ARGS [CMAKE_ARGS ...]
specify additional cmake args to be appended to each
recipe (leading -D must be omitted)
--no-deps, -n skip dependency fetch and build step
--uninstall uninstall recipe
--clean uninstall recipe and remove build
--pwd PWD, -p PWD user password to be used when sudo permission is
required (if empty, user is prompted for password);
note: to be used with care, as exposing your password
might be harmful!
--verbose, -v print additional information
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file hhcm_forest-1.1.17.tar.gz
.
File metadata
- Download URL: hhcm_forest-1.1.17.tar.gz
- Upload date:
- Size: 25.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 12edc11f095a703004342c9a9e14e7147800d07704a2ad4f9e4849586ce583f3 |
|
MD5 | d1b2c999da4dbdd7f116bc16d49fd7e2 |
|
BLAKE2b-256 | 28df5a2efae4084f168980ec54ea469cc168fbe394d5a8664848c8a80ec97e50 |
File details
Details for the file hhcm_forest-1.1.17-py3-none-any.whl
.
File metadata
- Download URL: hhcm_forest-1.1.17-py3-none-any.whl
- Upload date:
- Size: 29.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 08d34a02c3858afe0f1196d19381a19e2d6a076cf3884483123ff6d350c6df9b |
|
MD5 | a4c9a64bf4069c36ea582b5df3b3ad5d |
|
BLAKE2b-256 | 0cd267c3f6037eca8b04bbab31373e97ac19eb6c471b2f6f391a4605ab55d7ae |