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-forestmkdir my_ws && cd my_wsforest initsource setup.bashforest 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
srcfolder that will contain source code - a
recipesfolder that will contain forest's recipe files (more on this later) - a
buildfolder to carry out compilation and store build artifacts - an
installfolder - a
setup.bashfile 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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file hhcm_forest-1.1.19.tar.gz.
File metadata
- Download URL: hhcm_forest-1.1.19.tar.gz
- Upload date:
- Size: 24.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.8.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f37fabd9d22d42df638adfeae5e872e76fd31657f08d3998ba39491b01e948d3
|
|
| MD5 |
8ca89d41f627ef189349ce408248a436
|
|
| BLAKE2b-256 |
731700cabd6bddd86a31ffc8fabfc8a8257c2c3a852cd627e6375f1199a56165
|
File details
Details for the file hhcm_forest-1.1.19-py3-none-any.whl.
File metadata
- Download URL: hhcm_forest-1.1.19-py3-none-any.whl
- Upload date:
- Size: 29.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.8.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
23a27f5feb2e452d8dd8201beac21c5dcdd2437527fecf66a265907f5ae83a7f
|
|
| MD5 |
afec25b38dc7b7b49e3bf7e25e608af7
|
|
| BLAKE2b-256 |
b0f9f02ccb6371bae3277e2b5c29555daf330f801f920cb383e32133bcc88500
|