cli command organizer written in rust
Alternatives To Hoard
Project NameStarsDownloadsRepos Using ThisPackages Using ThisMost Recent CommitTotal ReleasesLatest ReleaseOpen IssuesLicenseLanguage
Buku5,6851127 days ago31July 01, 202214gpl-3.0Python
:bookmark: Personal mini-web in text
2 months ago1December 03, 2019108apache-2.0Python
An EXIF-based photo assistant, organizer and workflow automation tool.
2 months ago26September 15, 202171mitPython
media file renamer and organizion tool
a month ago13December 21, 202222mitRust
cli command organizer written in rust
Addic7ed Cli56
14 years ago11August 26, 20193mitPython
Addic7ed command-line interface
a year ago9cc0-1.0JavaScript
Dark Souls Save Manager - A save manager for Dark Souls - Can be used with any game that uses only a single save file. Download: https://github.com/omgftw/DarkSoulsSaveManager/releases
Photo Cli22
14 days ago7apache-2.0C#
A photo organizer for your file system without sticking to any application or vendor. Extract when and where (reverse geocoding) your photos are taken, copy into a new organized folder with various folder & file naming strategies, export into CSV files.
6 days ago9November 28, 20217mitRust
An opinionated, fast music organiser.
Angular Organizer18
3 years ago4TypeScript
Organizer practice for youtube (angular + moment)
9 years ago2mitRuby
command organizer
Alternatives To Hoard
Select To Compare

Alternative Project Comparisons

Crates.io version Crates.io version Crates.io version

command organizer tool to hoard all your precious commands

Example usage

What is a command organizer?

A command organizer lets you save commands that you often use, but are too complicated or long to remember. For every hoarded command, hoard saves

  • the command ( parameterized with a customizable token, default # )
  • name
  • description
  • namespace where it lives in
  • tags ( Optional )

If you get lost in your massive command history, and can't find for example a specific docker command out of thousand docker commands you've already ran, just hoard it. With a name and description it will be much easier to find again. When you look for that command again a month later, take a look at your hoarded commands.

hoard is not supposed to replace shell history finder like fzf atuin or similar utilities. It rather should be used in conjunction with them.

Now with chatGPT integration

💌 Table of contents


From source

It's best to use rustup to get setup with a Rust toolchain, then you can run:

cargo install hoard-rs

Or build it yourself:

cargo build --release

Find the binaries in ./target/release/hoard Move it to wherever you need it ( Like /usr/local/bin/hoard ) Or run

cargo install --path .


Tested on:

  • Ubuntu
  • Arch
  • EndeavourOS

Install hoard by running


If you are running fish shell

LATEST_RELEASE=1.3.1 ./install.fish

AUR (Arch Linux)

paru -S hoard

Homebrew (macOS)

brew tap Hyde46/hoard
brew install hoard

MacPorts (macOS)

sudo port install hoard-cli

More info here


Best to install from source, good luck

Autocomplete with Shell plugin

Install hoard as a plugin to enable autocomplete. Depending on your shell, run one of the following commands. To keep it installed for your next shell session, add the source command with an absolute path to your .bashrc or copy-paste the plugins content to your .bashrc.


source src/shell/hoard.bash


source src/shell/hoard.zsh


source src/shell/hoard.fish


The hoard package is in the nixpkgs package repository.

Either install it with nix-env -iA hoard, get it temporarily with nix-shell -p hoard or add it to your configuration.


Save a new command

hoard new

If a parameter is not known when saving the command, put a # ( Or your customized token from your ~/.config/hoard/config.yml ) You can also name your parameters like this:

echo "My name is #first and I live at #city. Did I tell you my name, #first?" 

When putting #first you only have to do it once for each occurrence in the command. A parameter name is defined as everything followed by the token until the first space character is found. Alternatively you can determine where the named parameter ends by putting a ! ( Or your customized token from your ~/.config/hoard.config.yml)

echo "My name is #first named parameter! and I live at #city. Did I tell you my name, #first?" 

Search through command trove


Or alternatively, if not installed as a plugin, the interactive search can still be performed, though without autocomplete. This assumes the user to copy the command by mouse from the UI

hoard list

When running hoard list as a shell plugin and selecting a parameterized command, hoard will ask for all missing parameters to input before sending the complete command to your shell input.

If there is a trove.yml file present in the local directory, hoard will only load this trove file and not display your "global" trove! ( Edit ~/.config/hoard/config.yml read_from_current_directory to disable )

chatGPT integration

When running hoard list or through the hoard shortcut, press Ctrl-a to be asked for a prompt. Desribe what your command is supposed to do, and chatGPT will create and hoard a new command based on your prompt.

If you dont already have an OpenAI account to generate an API key, head to this page. ( Given the low amount of tokens consumed, this is extremly cheap. ~ 0.01$ for 30 generated commands )

You either need to set the env variable

export OPENAI_API_KEY=abcabcabc

Or for a permanent solution set gpt_api_key in your ~/.config/hoard/config.yml

chatGPT does not always reply in the same format. Sometimes the resulting command will be added to the description. Use the edit mode <TAB>/<Ctrl-E> to edit the hoarded command to its correct form.

Synchronize commands with another terminal

You can keep your commands in sync in multiple terminals by using hoard sync

First register a new account

hoard sync register

Then login with your new account

hoard sync login

Save your local commands online

hoard sync save

Login with the same account on a different computer/terminal and then run

hoard sync get

This will merge your local trove file with the cloud-based one. You will get prompted how to handle collisions if there are any. However, if you are unhappy with how the merge happened, you've got the option to revert the latest hoard sync get command

hoard sync revert

If you want to host your own sync server, checkout it's repository. Then, update your config file to point to the new server location ~/.config/hoard/config.yml

Delete a command

hoard remove <name>

Delete all commands in a namespace

hoard remove_namespace <namespace_name>

Edit a command

hoard edit <name>


Shows location of config file and trove file

hoard info

Set parameter token

Change parameter token of config file

hoard set_parameter_token <parameter_token>

Import other trove files from trove.yml or urls pointing to a trove.yml file

hoard import /path/to/trove.yml


hoard import https://troves.com/new_trove.yml

Export trove file

hoard export /path/to/exported/trove.yml

⚡️ Hoard list shortcuts

Show list of commands in the GUI


Next item in command list

<Ctrl-N> / <Down-Arrow>

Previous item in command list

<Ctrl-P> / <Ctrl-Y> / <Up-Arrow>

Next namespace tab

<Ctrl-L> / <Right-Arrow>

Previous namespace tab

<Ctrl-H> / <Left-Arrow>

Select command



<Esc> / <Ctrl-D> / <Ctrl-C> / <Ctrl-G>
Popular Command Line Projects
Popular Organizer Projects
Popular Command Line Interface Categories
Related Searches

Get A Weekly Email With Trending Projects For These Categories
No Spam. Unsubscribe easily at any time.
Command Line Tool