gfold

GitHub Latest SemVer GitHub Tag Crates.io Build Status

gfold is a CLI application that helps you keep track of multiple Git repositories.

bash user at hostname in ~/git % gfold great-journey unclean main git@github.com:truth/great-journey.git installation-zero bare main https://github.com/the-ark/installation-zero.git sierra clean dev https://github.com/forward-unto-dawn/sierra.git spark clean issue343 git@github.com:guilty/spark.git tartarus unclean delta git@github.com:covenant/tartarus.git voi clean main https://github.com/earth/voi.git

Description and Motivation

This app displays relevant information for multiple Git repositories in one, or multiple, directories. While this tool might seem limited in scope and purpose, that is by design.

It prints each repository in alphabetical order, and pads each result based on the longest directory, branch, and status string. By default, gfold looks at every Git repository in the current working directory. However, if you would like to target another directory, you can pass that path (relative or absolute) as the first argument.

Installation

There are multiple ways to install gfold, but here are some recommended methods...

Installation Methods | linux-gnu-amd64 | macos-amd64 | windows-amd64 --- | --- | --- | -- Homebrew | x | x | - Arch User Repository (AUR) | x | - | - Cargo Install | x | x | x GitHub Release Binary | x | x | x

Homebrew

You can use Homebrew to install the tap for gfold.

bash brew install nickgerace/gfold/gfold

Alternatively, you can do...

bash brew tap nickgerace/gfold brew install gfold

Running brew help or man brew can help you use brew locally. You can check out Homebrew's documentation as well.

Arch User Repository (AUR)

This application is available for all Linux distributions that support installing packages from the AUR.

Many people choose to use an AUR helper, such as yay (example: yay -S gfold), in order to install their AUR packages.

Cargo Install

You can install from crates.io by executing...

bash cargo install gfold

GitHub Release Binary

You can obtain gfold via the latest GitHub release. Once you have it downloaded, you can add it to your PATH. Here is an example on how to do that on macOS and Linux...

bash chmod +x gfold mv gfold /usr/local/bin/

You may have to reload your shell in order to see gfold in your PATH.

Advanced Management

You can use symbolic links to swap between versions, and manage multiple at a time. Here is a full install workflow example...

```bash wget https://github.com/nickgerace/gfold/releases/download/$VERSION/gfold-$PLATFORM mv gfold-$PLATFORM gfold-$VERSION chmod +x gfold-$VERSION

mkdir /usr/local/gfold/ mv gfold-$VERSION /usr/local/gfold/ ln -s /usr/local/gfold/gfold-$VERSION /usr/local/bin/gfold ```

Now, you can add/remove versions of the binary from /usr/local/gfold/, and change the symbolic link as needed.

Usage

For all the ways on how to use this application, pass in the -h, or --help, flag.

bash gfold --help

Here are some example invocations...

bash gfold gfold .. gfold $HOME gfold /this/is/an/absolute/path gfold ../../this/is/a/relative/path gfold ~/path/to/multiple/repositories/ -r gfold -r $HOME/path/to/multiple/repositories

Compatibility

gfold, and its external crates, support all three major desktop platforms. It is tested for the latest versions of the following systems, but may work on more...

Issues, Pull Requests, and Contributing

Please follow the issue template when filing an issue. If making a pull request, the requirements for merging are...

  1. An issue must be linked, whether it is a new one or an existing one.
  2. The pull request branch needs to be rebased with nickgerace/gfold on main.
  3. Pull request commits need to be squashed (there may be exceptions to this on a case-by-case basis).

Changelog

Please check out CHANGELOG.md for more information. It follows the Keep a Changelog format.

Code of Conduct

This repository follows and enforces the Rust programming language's Code of Conduct.

Additional Information

Special Thanks To...