Skip to main content

Your agentic CLI developer.

Project description

tunacode-cli

tunacode

PyPI version Downloads Python 3.11+ License: MIT Discord Shield

A terminal-based AI coding agent with a NeXTSTEP-inspired interface.

Early stage software — not production ready. Under active development, expect bugs and breaking changes.

Features

  • Any model - Works with any OpenAI-compatible API
  • File operations - Read files with hash-tagged lines, create files, and edit existing files with hash-validated references
  • Shell access - Run bash commands with output capture
  • Repository discovery - Use discover for natural-language code search and repository exploration
  • Session persistence - Resume previous conversations with /resume
  • Themeable UI - CSS-based theming with NeXTSTEP-inspired design
  • Text selection + clipboard copy - Mouse selection works across Rich-rendered chat content; copy with ctrl+y or ctrl+shift+c
  • Agent loop - Powered by tinyAgent

Built With

  • tinyAgent - Core agent loop handling LLM interaction and tool execution
  • alchemy-rs - Rust-powered tokenizer and utilities via PyO3 bindings
  • Textual - Terminal UI framework with CSS-based styling
  • Rich - Terminal rendering with syntax highlighting
  • Typer - CLI framework

Installation

End Users

uv tool install tunacode-cli

Or with pip:

pip install tunacode-cli

Developers (Fresh Clone)

git clone https://github.com/alchemiststudiosDOTai/tunacode.git
cd tunacode
make install

Or without make:

git clone https://github.com/alchemiststudiosDOTai/tunacode.git
cd tunacode
./scripts/dev-setup.sh

Development

Common development tasks:

make install    # Cleanly bootstrap the verified dev environment
make dev-setup  # Alias for make install
make run        # Run the development server
make test       # Run test suite
make lint       # Run linters
make clean      # Clean build artifacts

make install also installs repo-managed pre-commit and pre-push hooks from .githooks/ using relative symlinks, so moving the checkout does not strand the hooks on an old absolute virtualenv path.

View technical debt:

uv run python scripts/todo_scanner.py --format text

Quick Start

# Configure API key
tunacode --setup

# Start coding
tunacode

Configuration

Set your API key as an environment variable:

export ANTHROPIC_API_KEY="your-key"
# or
export OPENAI_API_KEY="your-key"

Config file: ~/.config/tunacode.json

TunaCode deep-merges partial config files onto built-in defaults and validates the merged result at startup. If the file is malformed, the app reports a configuration error instead of silently guessing.

For local models and advanced settings, see the Configuration Guide.

Commands

Slash commands are command objects in tunacode.ui.commands; each one is a Command subclass and is registered in COMMANDS. handle_command() also routes shell commands (!<cmd>), legacy exit, and slash /exit.

Command Description
/cancel Cancel the current request or shell command.
/help Show available commands
/clear Clear transient agent state while preserving message history.
/compact Force context compaction
/debug Toggle debug logging to screen (includes parallel tool-call lifecycle lines)
/model Open model picker or switch model
/resume List, load, or delete persisted sessions.
/skills Browse, search, or load session skills.
/theme Open theme picker or switch theme
/thoughts Toggle the streaming thought panel.
/update Check for or install updates.
!<cmd> Run shell command
/exit Exit TunaCode
exit Legacy alias for exit

The agent has access to:

Tool Description
bash Execute shell commands
discover Search and explore the repository with a natural-language query
read_file Read file contents with content-hash tagged lines
hashline_edit Edit existing files using hash-validated line references from read_file
web_fetch Fetch web page content
write_file Create new files

Important tool rules:

  • bash accepts optional cwd, env, timeout, and capture_output arguments in addition to the required command.
  • discover is the semantic repository mapper; use it to find code related to a concept or feature instead of manually chaining search tools.
  • read_file supports paging with offset and limit, wraps results in <file>...</file>, and each read replaces the editable cache window for that file.
  • hashline_edit only supports replace, replace_range, and insert_after using <line>:<hash> refs from the current read_file output.
  • write_file is create-only: it creates missing parent directories but refuses to overwrite an existing file.
  • web_fetch only fetches public http or https URLs and blocks localhost, private, and reserved addresses.
hashline-edit tool in tunacode

Security

TunaCode has full shell access with no permission prompts. If you're concerned:

  • Use git so you can revert changes
  • Run in a container/sandbox

Discord

Discord

License

MIT

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

tunacode_cli-0.2.2.tar.gz (1.9 MB view details)

Uploaded Source

Built Distribution

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

tunacode_cli-0.2.2-py3-none-any.whl (419.3 kB view details)

Uploaded Python 3

File details

Details for the file tunacode_cli-0.2.2.tar.gz.

File metadata

  • Download URL: tunacode_cli-0.2.2.tar.gz
  • Upload date:
  • Size: 1.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for tunacode_cli-0.2.2.tar.gz
Algorithm Hash digest
SHA256 efb1817c794a932d6d64ec67ca0ece301cd756da7ff0f68fb08d48199ed3d7b6
MD5 7d89d245e696dbbb64c840c100f1f759
BLAKE2b-256 d7d2e612ed2e19cd5c62a15500f85483266a1bf345600c1f81da0505b0650b38

See more details on using hashes here.

File details

Details for the file tunacode_cli-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: tunacode_cli-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 419.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for tunacode_cli-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 7444f2a432559a47a619e84044ffb3494afb23d53311485aa4a00c84ca112ee1
MD5 5982455c0f0f05758b3aac5da808c430
BLAKE2b-256 b34fbc1081ad1e022d4bc312c27fc5c22ff2e675e8a32aa673fd9d12f09b2d2c

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