Skip to main content

A CLI programming assistant for computer-science tasks

Project description

aicheat

A command-line based AI coding assistant

demo

Features

  • Supports OpenAI-compatible inference servers (such as vLLM/llama.cpp/OpenAI, ...)
  • Powerful line editing/completion capabilities thanks to prompt-toolkit
  • Theming support using pygments
  • Extensibility via custom tool definitions
  • Skills support

Installation

# Install a stable version
uv pip install aicheat

# Install the latest main
uv pip install git+https://git.decapod.one/brethil/aicheat@main

# Install the latest dev (unstable)
uv pip install git+https://git.decapod.one/brethil/aicheat@dev

# Clone and install (development)
git clone https://git.decapod.one/brethil/aicheat
uv pip install -e ".[dev]"

Quick Start

Configuration requires an OpenAI API key or an a OpenAI-compatible server. These can be configured via environment variables or command-line arguments.

Environment Variables

  • AICHEAT_HOST: path to an OpenAI-compatible server, such as vllm, or llama.cpp, see instructions in docs
  • OPENAI_API_KEY: (optional) set if API Key is required to connect to AICHEAT_HOST
  • AICHEAT_MODEL: (optional) set default model. If a single model is available on AICHEAT_HOST, it is automatically selected. If multiple models are available, user is prompted to select the model.

Note: this should also work with the official OpenAI API, although this is untested.

Command-Line Flags

aicheat [--host <host or endpoint url>] [--api-key <api key>]

Provider Documentation

See docs/providers/ for detailed instructions on using aicheat with different OpenAI-compatible API providers:

Basic Usage

aicheat --help
# to start chatting:
aicheat
# optionally, a starting message can be provided:

aicheat "What's the current status of this git repo?"

In the aicheat "REPL":

  • Type /help for available commands
  • Type /tools to see available tools
  • Use /theme list to list/select available themes, using /config save to persist the theme choice.
  • Prefix messages with ! to run a shell command, e.g. !uptime calls uptime.
  • Type a question to start chatting

Additional command-line flags

# Skip confirmation prompts for tool calls (yolo mode)
aicheat --no-confirm "Fix this bug"

# Skip loading AGENTS.md and memory.md files
aicheat --no-agent-files --no-memory "Explain this code"

# Disable all tools
aicheat --no-tools

# Start a session with no initial prompts
aicheat --no-confirm --no-agent-files --no-memory

For a complete list of flags, use:

aicheat --help

In-Chat Commands

Once in the chat, you can use these commands:

  • /help - List available commands
  • /tools - List available tools
  • /clear - Clear the conversation history (or hit ctrl-c twice)
  • /multiline - Toggle multiline input mode, also see Editor/Multiline section below
  • /model - Show/set the active model
  • /fragment <file> [prompt] - Include a file in the session with optional instructions

Tool Calling

aicheat comes with several built-in tools

File Operations

  • read_file(filename) - Read the content of a file
  • write_file(filename, content) - Write content to a file
  • apply_patch(filename, content) - Patch a file
  • search(pattern, path) - Search for patterns in files using ripgrep

System & Shell

  • execute_shell_command(cmd) - Execute shell commands (with confirmation)
  • man(program_name) - Retrieve man pages for programs
  • pwd() - Get current working directory
  • cd(path) - Change directory

Git Integration

  • git_status() - Show git status as a diff
  • git_updates(from_refish) - Show commits since last tag/release
  • git_show_patch(commit_id) - Show patch for a specific commit
  • git_list_files() - List all git-tracked files

Code Execution

  • execute_python_code(code) - Execute Python code snippets (with confirmation)

Web & Documentation

  • cheat_sh_search(program_name) - Search cheat.sh for program documentation

Adding Custom Tools

You can extend aicheat with custom tools by creating new modules in src/aicheat/tools/.

Here's an example for a ping tool to check network status:

from aicheat.tools.core import tool
from subprocess import check_output, CalledProcessError, STDOUT
import re


@tool(
    message_template="🌐 Pinging {host} {count} times}"
    requires_confirmation=False,
)
def ping(host: str, count: int) -> str:
    """Pings a host using the unix `ping` tool"""
    if not host:
        return "No host provided"

    try:
        result = check_output(
            ["ping", "-c", str(count), host],
            text=True,
            stderr=STDOUT,  # redirect stderr to stdout
        )
    except CalledProcessError as exc:
        result = f"ping failed with returncode={exc.returncode}\noutput:\n{exc.stdout}"

    return result

Note: @tool() must always be called with parentheses.

For more examples, see:

  • aicheat.tools.shell - Shell-related tools
  • aicheat.tools.git - Git-related tools
  • aicheat.tools.code.python - Python-related code tools

Tips & Tricks

Shell Integration

Add an alias to aicheat so that it's prefixed by noglob, making it easier to give initial prompts from the shell without expanding globs:

echo "alias aicheat=\"noglob aicheat\"" >> ~/.zshrc

Editor/Multiline

The REPL uses prompt-toolkit to leverage its powerful line-editing capabilities. aicheat, depending on your $EDITOR value supports:

  • emacs-style line-editing shortcuts:
    • use ctrl-x ctrl-e to open the current line in your $EDITOR)
    • ctrl-a/ctrl-e to move to beginning/end of the current line and other emacs-style movements
  • vi-style line-editing shortcuts:
    • vv to open the current line in your $EDITOR
    • modal editing and other vi-style movement shortcuts

Multiline editing is also supported, either via /multiline or via ctrl-v. This can be useful to paste text/code.

Requirements

  • Python 3.8+
  • An OpenAI-compatible API server (like vLLM or llama.cpp)
  • ripgrep (optional, for improved search functionality)
  • cht.sh CLI tool (optional, for cheat.sh functionality)

License

MIT

  • aicheat.tools.shell shell-related tools
  • aicheat.tools.git git-related tools
  • aicheat.tools.code.python python-related code tools

Skills

Load skills using /skill load path/to/skill to extend aicheat's functionality with custom workflows and interaction patterns.

See doc/README.md for more information about bundled skills.

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

aicheat-0.5.0.tar.gz (640.5 kB view details)

Uploaded Source

Built Distribution

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

aicheat-0.5.0-py3-none-any.whl (51.3 kB view details)

Uploaded Python 3

File details

Details for the file aicheat-0.5.0.tar.gz.

File metadata

  • Download URL: aicheat-0.5.0.tar.gz
  • Upload date:
  • Size: 640.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for aicheat-0.5.0.tar.gz
Algorithm Hash digest
SHA256 e512336d939fb19cdd81a91110657aa446ea3bb587cbe41a0673aa84329bbbf0
MD5 cc1702a69a50cf68ed6a88b9591b01c1
BLAKE2b-256 b72a13d5c30a7854954277357310f94afe9962f66f036e169e7050f0e22b4aa2

See more details on using hashes here.

File details

Details for the file aicheat-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: aicheat-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 51.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for aicheat-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 04e7ce704b7f173c35281c8bea57b19a07746a0c60897ebd9d318938d5a7a41f
MD5 974363ceca0c7ba506c9f4e71d97b252
BLAKE2b-256 33da5a587f90b5319adf7bf515659604e1d5dbfecbdf0a42894b4e4a50ddff28

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