Skip to main content

A command-line AI assistant that provides contextual help based on terminal history

Project description

wtf - Because working in the terminal often gets you asking wtf

A command-line AI assistant that provides contextual help based on terminal history and user queries.

📚 Full Documentation | 🚀 Quick Start Guide | ❓ FAQ

Quick install

curl -sSL https://raw.githubusercontent.com/davefowler/wtf-terminal-ai/main/install.sh | bash

⏪ Made a mistake? Just say wtf undo - it analyzes your history and reverses your last command intelligently. Works for git commits, file deletions, package installs, and more.

What is this?

wtf is a terminal AI assistant that is there for you when you f up. Hit an error? Just type wtf. Made a mistake? Just say wtf undo. Need to install something? Type wtf install [thing]. Forget the command? No problem just ask wtf can you back me out of this failed merge attempt?.

No flags to remember. No manual pages to consult. Just describe what you want.

Who is wtf for?

Non-engineers

More and more people are now able to work with code and command lines: data analysts using git for dbt models, designers and product managers vibe coding prototype features, marketers working with static sites. wtf helps with setups, remembering commands, and gets them out of jams.

Engineers

There are so many tools and commands to remember. You get stuck, you make mistakes, you get slowed down having to go read docs or switch over to ask your llm of choice. But now you can just stay in your terminal and have it answer or even fix your problems as they come up.

Installation

Via curl (recommended)

One-liner with automatic collision detection:

curl -sSL https://raw.githubusercontent.com/davefowler/wtf-terminal-ai/main/install.sh | bash

Via pip

pip install wtf-ai

From source (for development)

git clone https://github.com/davefowler/wtf-terminal-ai.git
cd wtf-terminal-ai
pip install -e .

Quick Start and Examples

First use: Just run wtf with any query. Setup happens automatically:

# First time use - setup wizard runs automatically
wtf "what's in my git status?"

# After setup, use naturally
wtf how do I exit vim

# Made a mistake?
wtf undo

# Install something
wtf install express

# Explain an error
wtf "what does this error mean?"

# Learn your preferences
wtf remember I prefer npm over yarn and I live in San Francisco

# Find documentation
wtf find me the react docs

# Get general knowledge
wtf what is rust programming language

Requirements

  • Python 3.9 or higher
  • An API key from Anthropic, OpenAI, or Google — OR run locally with Ollama (free, no API key needed!)

Optional: Web Search

wtf has limited web search by default (encyclopedic facts only). For full web search (weather, news, current events, documentation):

Get a free Brave Search API key:

  1. Sign up at https://brave.com/search/api/ (free tier: 2,000 searches/month, no credit card)
  2. Save your key: wtf here is my brave search api key YOUR_KEY_HERE

That's it! Now wtf can search for anything.

Hooks - Want wtf all the time?

Add wtf to your shell hooks for automatic assistance:

Error Hook

Automatically suggest wtf when commands fail:

wtf --setup-error-hook

Now whenever a command fails, you'll see:

💥 Command failed with exit code 1
   Run 'wtf' to analyze what went wrong

Command Not Found Hook

Suggest wtf when you mistype commands:

wtf --setup-not-found-hook

When you type a non-existent command:

❌ Command not found: gti
   Try: wtf how do I gti

Remove Hooks

Changed your mind?

wtf --remove-hooks

Supported shells: zsh, bash, fish

Configuration

Much of the configuration you can just do through telling wtf. Here are some config nouns that are useful in changing it:

  • memories - remembers things you tell it or it discovers like what text editor you prefer
  • personality - it has one. don't like it, just tell it to change
  • allow list - commands that can run without asking
  • history - its log of all your chats

Example config adjustments

# it will remember what you ask it to
wtf remember my name is dave and my favorite editor is emacs

# if you need more false encouragement in your life
wtf change your personality to be more of a super sycophant

# if you don't fear AI
wtf give yourself permission to run all commands

# if you're just too embarased
wtf forget everything we just did

If you're old fashioned you can also adjust these things as variables in a file. Configuration is stored in ~/.config/wtf/:

  • config.json - Main configuration
  • wtf.md - Your custom instructions
  • allowlist.json - Commands that can run without permission
  • memories.json - Your preferences and context
  • history.jsonl - Conversation history

Documentation

📖 Read the full documentation with terminal-style theming!

Topics covered:

For developers: See SPEC.md and TASKS.md

License

MIT License - see LICENSE file for details

Acknowledgments

wtf stands on the shoulders of:

  • tAI - Original terminal AI inspiration
  • Aider - Proved AI + version control works
  • llm - Model abstraction by Simon Willison
  • Rich - Terminal UI that doesn't suck

See full acknowledgments for details.

Contributing

Issues and PRs welcome at https://github.com/davefowler/wtf-terminal-ai

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

wtf_ai-0.3.3.tar.gz (67.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

wtf_ai-0.3.3-py3-none-any.whl (58.4 kB view details)

Uploaded Python 3

File details

Details for the file wtf_ai-0.3.3.tar.gz.

File metadata

  • Download URL: wtf_ai-0.3.3.tar.gz
  • Upload date:
  • Size: 67.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.8

File hashes

Hashes for wtf_ai-0.3.3.tar.gz
Algorithm Hash digest
SHA256 dc2eb4bf50008ab8483ba99facaf5efdd97b80d7cabb558f4e5638999423c45d
MD5 872b01d11eabb8b0d3f1c9044e67075c
BLAKE2b-256 6b66dbeeaf57605be438f78dd18b4b98a6bceea1cef571c92fb904b2600db197

See more details on using hashes here.

File details

Details for the file wtf_ai-0.3.3-py3-none-any.whl.

File metadata

  • Download URL: wtf_ai-0.3.3-py3-none-any.whl
  • Upload date:
  • Size: 58.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.8

File hashes

Hashes for wtf_ai-0.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 47dc14d872e4d58d1887a67a33b6fa9446f515fdc60d6207bf56d0f409c06dbe
MD5 6352d97461410ab6997c5d47c3e9428e
BLAKE2b-256 e2f3730c2d29d559a0b5852f2e9625bb52297641ee9c97572ef76ca24bc10b34

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page