Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nickgerace/gfold
CLI tool to help keep track of your Git repositories, written in Rust
https://github.com/nickgerace/gfold
cli git git-cli rust rust-cli
Last synced: 2 months ago
JSON representation
CLI tool to help keep track of your Git repositories, written in Rust
- Host: GitHub
- URL: https://github.com/nickgerace/gfold
- Owner: nickgerace
- License: apache-2.0
- Created: 2020-04-04T19:59:43.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-07-28T05:11:00.000Z (6 months ago)
- Last Synced: 2024-10-13T14:14:58.720Z (3 months ago)
- Topics: cli, git, git-cli, rust, rust-cli
- Language: Rust
- Homepage: https://crates.io/crates/gfold
- Size: 1.3 MB
- Stars: 284
- Watchers: 6
- Forks: 20
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-rust - nickgerace/gfold - CLI tool to help keep track of multiple Git repositories [![build](https://img.shields.io/github/workflow/status/nickgerace/gfold/merge/main)](https://github.com/nickgerace/gfold/actions?query=workflow%3Amerge+branch%3Amain) (Applications / System tools)
- awesome-rust-cn - nickgerace/gfold - (应用程序 Applications / 系统工具 System tools)
- awesome-rust - nickgerace/gfold - CLI tool to help keep track of multiple Git repositories [![build](https://img.shields.io/github/workflow/status/nickgerace/gfold/merge/main)](https://github.com/nickgerace/gfold/actions?query=workflow%3Amerge+branch%3Amain) (Applications / System tools)
- fucking-awesome-rust - nickgerace/gfold - CLI tool to help keep track of multiple Git repositories [![build](https://img.shields.io/github/workflow/status/nickgerace/gfold/merge/main)](https://github.com/nickgerace/gfold/actions?query=workflow%3Amerge+branch%3Amain) (Applications / System tools)
- fucking-awesome-rust - nickgerace/gfold - CLI tool to help keep track of multiple Git repositories [![build](https://img.shields.io/github/workflow/status/nickgerace/gfold/merge/main)](https://github.com/nickgerace/gfold/actions?query=workflow%3Amerge+branch%3Amain) (Applications / System tools)
README
# gfold
[![latest release tag](https://img.shields.io/github/v/tag/nickgerace/gfold?sort=semver&logo=git&logoColor=white&label=version&style=flat-square&color=blue)](https://github.com/nickgerace/gfold/releases/latest)
[![crates.io version](https://img.shields.io/crates/v/gfold?style=flat-square&logo=rust&color=orange)](https://crates.io/crates/gfold)
[![license](https://img.shields.io/github/license/nickgerace/gfold?style=flat-square&logo=apache&color=silver)](./LICENSE)
[![build status](https://img.shields.io/github/actions/workflow/status/nickgerace/gfold/ci.yml?branch=main&style=flat-square&logo=github&logoColor=white)](https://github.com/nickgerace/gfold/actions)`gfold` is a CLI tool that helps you keep track of multiple Git repositories.
[![A GIF showcasing gfold in action](https://raw.githubusercontent.com/nickgerace/gfold/main/assets/demo.gif)](https://raw.githubusercontent.com/nickgerace/gfold/main/assets/demo.gif)
If you'd prefer to use the classic display mode by default, and avoid setting the flag every time, you can set it in the config file (see **Usage** section).
## Description
This app displays relevant information for multiple Git repositories in one to many directories.
It only reads from the filesystem and will never write to it.
While this tool might seem limited in scope and purpose, that is by design.By default, `gfold` looks at every Git repository via traversal from the current working directory.
If you would like to target another directory, you can pass its path (relative or absolute) as the first argument or change the default path in the config file.After traversal, `gfold` leverages [rayon](https://github.com/rayon-rs/rayon) to perform concurrent, read-only analysis of all Git repositories detected.
Analysis is performed by leveraging the [git2-rs](https://github.com/rust-lang/git2-rs) library.## Usage
Provide the `-h/--help` flag to see all the options for using this application.
```shell
# Operate in the current working directory or in the location provided by a config file, if one exists.
gfold# Operate in the parent directory.
gfold ..# Operate in the home directory (first method).
gfold $HOME# Operate in the home directory (second method).
gfold ~/# Operate with an absolute path.
gfold /this/is/an/absolute/path# Operate with a relative path.
gfold ../../this/is/a/relative/path
```### Config File
If you find yourself providing the same arguments frequently, you can create and use a config file.
`gfold` does not come with a config file by default and config files are entirely optional.How does it work?
Upon execution, `gfold` will look for a config file at the following path on macOS, Linux and similar operating systems.```shell
$HOME/.config/gfold.toml
```On Windows, the lookup path will be in a similar location.
```powershell
{FOLDERID_Profile}\.config\gfold.toml
```For config file creation, you can use the `--dry-run` flag to print valid TOML.
Here is an example config file creation workflow on macOS, Linux and similar platforms:```shell
gfold -d classic -c never ~/ --dry-run > $HOME/.config/gfold.toml
```Here are the contents of the resulting config file:
```toml
path = '/home/neloth'
display_mode = 'Classic'
color_mode = 'Never'
```Let's say you created a config file, but wanted to execute `gfold` with entirely different settings _and_ you want to ensure that
you do not accidentally inherit options from the config file.
In that scenario you can ignore your config file by using the `-i` flag.```shell
gfold -i
```You can restore the config file to its defaults by using the same flag.
```shell
gfold -i > $HOME/.config/gfold.toml
```In addition, you can ignore the existing config file, configure specific options, and use defaults for unspecified options all at once.
Here is an example where we want to use the classic display mode and override all other settings with their default values:```shell
gfold -i -d classic > $HOME/.config/gfold.toml
```You can back up a config file and track its history with `git`.
On macOS, Linux, and most systems, you can link the file back to a `git` repository.```shell
ln -s /gfold.toml $HOME/.config/gfold.toml
```Now, you can update the config file within your repository and include the linking as part of your environment setup workflow.
## Installation
[![Packaging status](https://repology.org/badge/vertical-allrepos/gfold.svg)](https://repology.org/project/gfold/versions)
### Homebrew
You can use [Homebrew](https://brew.sh) to install `gfold` with a choice of two methods.
#### Core (macOS and Linux)
`gfold` is now available in the [core formulae](https://formulae.brew.sh/formula/gfold)!
However, you may run into a naming collision on macOS if [coreutils](https://formulae.brew.sh/formula/coreutils) is installed via `brew`.
See the [troubleshooting](#troubleshooting-and-known-issues) section for a workaround and more information.```shell
brew install gfold
```#### Tap (macOS only)
The [tap](https://github.com/nickgerace/homebrew-nickgerace/blob/main/Formula/gfold.rb) is still available if you would like to use it.
This is subject to change.```shell
brew install nickgerace/nickgerace/gfold
```### Arch Linux
You can use [pacman](https://wiki.archlinux.org/title/Pacman) to install `gfold` from the [extra repository](https://archlinux.org/packages/extra/x86_64/gfold/).
```shell
pacman -S gfold
```### Nix and NixOS
You can install `gfold` from [nixpkgs](https://github.com/NixOS/nixpkgs/blob/master/pkgs/applications/version-management/gfold/default.nix):
```shell
nix-env --install gfold
```If you are using [flakes](https://nixos.wiki/wiki/Flakes), you can install using the `nix` command directly.
```shell
nix profile install "nixpkgs#gfold"
```### Cargo
You can use [cargo](https://crates.io) to install the [crate](https://crates.io/crates/gfold) on almost any platform.
```shell
cargo install gfold
```Use the `--locked` flag if you'd like Cargo to use `Cargo.lock`.
```shell
cargo install --locked gfold
```Keeping the crate up to date is easy with [cargo-update](https://crates.io/crates/cargo-update).
```shell
cargo install cargo-update
cargo install-update -a
```### Download a Binary
If you do not want to use one of the above installation methods and do not want to clone the repository, you can download a binary from the [releases](https://github.com/nickgerace/gfold/releases) page.
For an example on how to do that, refer to the [manual install](./docs/MANUAL_INSTALL.md) guide.### Build From Source
If you would like an example on how to build from source, refer to the [manual install](./docs/MANUAL_INSTALL.md) guide.
### Preferred Installation Method Not Listed?
Please [file an issue](https://github.com/nickgerace/gfold/issues/new)!
## Compatibility
`gfold` is intended to be ran on _any_ tier one Rust 🦀 target.
Please [file an issue](https://github.com/nickgerace/gfold/issues) if your platform is unsupported.## Usage as a Library
There are two ways to use `gfold` as a "library".
1) Use the [`libgfold`](./lib/libgfold/README.md) crate that powers `gfold`
1) Consume valid JSON results from `gfold -d json` (not a library, but useful for non-Rust applications)## Troubleshooting and Known Issues
If you encounter unexpected behavior or a bug and would like to see more details, please run `gfold` with the following
environment variables:```shell
# You may also want to add relevant arg(s) and flag(s).
RUST_BACKTRACE=1 RUST_LOG=debug gfold
```If the issue persists, please [file an issue](https://github.com/nickgerace/gfold/issues).
### Tuning Environment Variables
Since [`RUST_BACKTRACE`](https://doc.rust-lang.org/std/backtrace/index.html) and
[`RUST_LOG`](https://docs.rs/env_logger/latest/env_logger/) do not have `gfold`-specific behaviors, you can adjust
them just as you would in other projects to aid investigation.
Please attach relevant logs from execution with _sensitive bits redacted_ in order to help resolve your issue.### Coreutils Collision on macOS
If `fold` from [GNU Coreutils](https://www.gnu.org/software/coreutils/) is installed on macOS via `brew`, it will be named `gfold`.
You can avoid this collision with shell aliases, shell functions, and/or `PATH` changes.
Here is an example with the `o` dropped from `gfold`:```shell
alias gfld=$HOME/.cargo/bin/gfold
```### Upstream `libgit2` Issue
If you are seeing `unsupported extension name extensions.worktreeconfig` or similar errors, it may be related to
[libgit2/libgit2#6044](https://github.com/libgit2/libgit2/issues/6044).This repository's tracking issue is [#205](https://github.com/nickgerace/gfold/issues/205).
## Community
For more information and thanks to contributors, users, and the "community" at large, please refer to the **[THANKS](./docs/THANKS.md)** file.
- [Packages for NixOS, Arch Linux and more](https://repology.org/project/gfold/versions)
- ["One Hundred Rust Binaries"](https://www.wezm.net/v2/posts/2020/100-rust-binaries/page2/), an article that featured `gfold`
- [nvim-gfold.lua](https://github.com/AckslD/nvim-gfold.lua), a `neovim` plugin for `gfold` _([announcement Reddit post](https://www.reddit.com/r/neovim/comments/t209wy/introducing_nvimgfoldlua/))_