1 stable release

new 2.0.0 Jan 27, 2025

#113 in Build Utils

Download history 78/week @ 2025-01-22

78 downloads per month

MIT license

370KB
8K SLoC

Garden

Garden grows and cultivates collections of Git trees.

Garden is a simple yet expressive command runner and multi-repo Git configuration tool. Garden helps you create development workflows over collections of self-contained, loosely-coupled and inter-dependent Git worktrees.

# Install the "garden" command-line tool.
cargo install garden-tools

# Install the "garden-gui" graphical user interface for Garden.
cargo install garden-gui

Documentation

Read the Garden User Guide for details on how to use and configure Garden.

Read the Garden API Documentation for details on how to use the Garden APIs for developing Garden.

Installation

Pre-built garden binaries are statically linked using musl libc so that they can run on any Linux system.

Pre-built binaries for Garden's graphical user interface (garden-gui) are only available as amd64/x86_64 Linux tarballs and Debian packages. garden-gui is provided by the garden-gui_*_amd64.deb and garden-gui-*-x86_64-unknown-linux-gnu.tar.gz artifacts.

Both garden and garden-gui must be installed in order to use garden-gui.

Use Cases

  • Garden bootstraps Git-based multi-repo development environments from source. Garden can store and apply git config and git remote configuration to existing or new Git worktrees that Garden can "grow" (clone) into existence.

  • Garden runs commands over collections of Git repositories. The simplicity of Garden's syntax and its dynamic expression variables makes it a viable replacement for make when used as a simple task runner.

  • Garden is configured using YAML files alongside a familiar UNIX shell syntax that leverages your existing shell knowledge. If you already know POSIX/bash/zsh shell then you can learn to use garden with minimal effort.

Code Status

Build status MIT License

Garden is actively maintained and its core functionality is stable and feature-complete.

Dependencies

~14–57MB
~883K SLoC