Cliff (Command Line InterFace Friend) is an AI assistant that helps you come up with Unix commands. Given an objective (for example, "kill the process running on port 8080"), Cliff will generate a command that does the objective and add it to your paste buffer for you to easily paste into your terminal.
Cliff is compatible with LLMs from closed-source providers (OpenAI, Anthropic etc.), inference providers (Groq, Cerebras, etc.), as well as local models running with Ollama.
It's annoying having to open the browser when I forget how to do something in the terminal.
- At least one of the following:
- A Unix-like operating system
- Python >= 3.10
You can install Cliff with homebrew:
brew install pkelaita/tap/cliffOr with pip:
pip install cliff-cliIf installing with pip, it's recommended to use pipx or another isolated environment manager since Cliff is a globally-installed application.
If you'd like to use models from an API-based provider, add its credentials as follows:
cliff --config add [provider] [api key]
The provider can be any of openai, anthropic, google, cohere, groq, replicate, mistral, or cerebras.
Otherwise if you want to use a local model, add it like this:
cliff --config add ollama [model]
For the full list of supported models and providers, see Cliff's Supported Models.
Configuration tips
- In order to use local models, make sure you have Ollama installed and running and have the model loaded (their docs).
- If you add multiple models, you can set your default model with:
cliff --config default-model [model].
For a full overview of the configuration system, run cliff --config help.
Get started by running cliff with an objective.
cliff kill the process running on port 8080
Cliff will automatically add the command to your paste buffer, so no need to copy-paste it.
If needed (i.e., to avoid escaping special characters), you can use quotes.
cliff "kill the process that's running on port 8080"If you want to specify which model to use, you can do so with the --model or -m flag.
cliff --model gpt-5-mini kill the process running on port 8080
To view the man page, run cliff with no arguments.
By default, Cliff has chat memory enabled with a sliding window size of 10 turns. You can view your memory with cliff --memory show and clear it with cliff --memory clear.
If you'd like to change the window size, run cliff --config memory-window [new size]. If you want to disable memory, just set the window size to 0.
Cliff's chat memory does not have access to command outputs, but you can optionally share them with Cliff to help it debug and improve its responses via its command notepad.
- To run a command and store its output for Cliff, run
cliff --notepad run [command]. - To view your command notepad, run
cliff --notepad show, and to clear it, runcliff --notepad clear. -ncan be used as an alias for--notepad.
Tip: You'll usually have to put quotes around your command if it contains special characters – e.g., cliff --notepad run "ps ax | head -n 10" – for Cliff to properly capture and execute it.
- The default generation timeout is 20 seconds. You can change it by running
cliff --config timeout [new timeout]. - To view your configuration, run
cliff --config show. - You can run
cliff --clearas a shortcut to clear both Cliff's chat memory and command notepad.
That's it! It's pretty simple which is the point.
- Regular updates with new models, etc.
- UX improvements: cosmetic updates, model aliases, etc.
- Not sure what else this thing really needs, but open to suggestions!
