Skip to main content

A complete terminal implementation of Anthropic's Claude.

Project description

tclaude — Claude in the terminal   

A complete implementation of Claude in the terminal.

Unlike other tools that aim to support all kinds of LLMs, tclaude is designed specifically for Claude. As such, Claude-specific features like caching, Claude-native web search or code execution are implemented correctly and fully.

Highlights

  • Interactive chat with resumable sessions, extended thinking, and tool use
    • Built-in grounded web search, code execution, and file analysis
    • MCP server support (both remote and local)
  • Implement any custom tool in just a few lines of Python
  • Automatic caching (makes Claude up to 10x cheaper!)

Installation

pip install tclaude

Then set the ANTHROPIC_API_KEY environment variable to your Claude API key and you are good to go.

Usage

Running tclaude opens a new chat session. You can also directly pass a prompt to start a session.

tclaude "How do I make great pasta?"
# or: echo "How do I make great pasta?" | tclaude
> Great pasta starts with quality ingredients and proper technique. ...

Or use an outward pipe to integrate tclaude into unix workflows

git diff --staged | tclaude "Write a commit message for this diff." | xargs -0 git commit -m

Upload files with -f

tclaude -f paper.pdf "Summarize this paper."
tclaude -f cat.png "Is this a dog?"

Claude will use web search and server-side code execution when the request demands it:

tclaude "Tell me the factorials from 1 through 20."
> [Uses Python to compute the answer.]

tclaude "What is the state of the art in physically based rendering?"
> [Uses web search and responds with citations.]

Sessions

Once you're done chatting, the session will be automatically named and saved as <session-name>.json in the working directory.

You can resume the session with tclaude -s <session-name>.json or browse past sessions with fuzzy finding via tclaude -s.

Customize where sessions are saved by passing --sessions-dir <dir> or by setting sessions_dir in the configuration file.

Extended / adaptive thinking

Enable thinking with --thinking or by setting thinking = true in the configuration file.

tclaude --thinking "Write a quine in C++."
> [Claude thinks about how to write a quine before responding.]

Note that thinking is always on for Fable class models and can not be disabled. If thinking is disabled for these models, tclaude will omit thought summaries from the response, but the model still generates billed thinking tokens behind the scenes.

Commands

Several commands are available to do other things than chatting with Claude, such as /download to download files previously created by Claude. Use /help to see a list of available commands.

Custom system prompt

If you'd like to customize the behavior of Claude (e.g. tell it to be brief, or give it background information), create ~/.configs/tclaude/roles/default.md. The content of this file will be prepended as system prompt to all conversations.

If you'd like to load different system prompts on a case-by-case basis, you can pass them as command line argument or set role in the configuration file.

tclaude --role pirate.md "How do I make great pasta?"
> Ahoy there, matey! Ye be seekin' the secrets of craftin' the finest pasta this side of the Mediterranean, eh? ...

Custom tools

Simply implement your tool as a function in src/tclaude/tools.py and it will be callable by Claude. Make sure to document the tools' function thoroughly such that Claude uses it optimally.

Custom endpoints

tclaude can connect to any Anthropic-compatible endpoint. By default tclaude uses Anthropic's official API endpoint, but you can set up your own endpoint in the configuration file and then use it with tclaude --endpoint <name>.

MCP server support

tclaude supports two kinds of MCP servers. See the the configuration section for details on how to set up the servers.

  1. Remote servers (e.g. remote-mcp-servers)

    • Claude will connect directly to the server and use the tools it provides. The connection is not made by your machine.
    • Remote servers are useful for tools that require a lot of resources or need to be run in a server environment.
    • If the server needs authentication, it can be done via OAuth2 or a custom token.
  2. Local servers (running on your machine or in an internal network)

    • tclaude will connect to the MCP server via your machine and forward the tools to Claude.
    • Local servers are useful for tools that require access to local resources (e.g. files on your machine).
    • Two protocols are supported: STDIN (tclaude starts the server and pipes the input to it) and HTTPS (tclaude connects to the server via a URL).

Configuration

You can configure tclaude by creating the ~/.configs/tclaude/tclaude.toml file. If you have $XDG_CONFIG_HOME set, the file should be placed at $XDG_CONFIG_HOME/tclaude/tclaude.toml.

The default configuration file looks as follows. (Or use tclaude --print-default-config to print it to stdout.) You can copy it as a starting point for your own configuration or you can only set the settings you want to differ from the defaults. Comments indicate optional settings such as custom endpoints or MCP servers.

Nearly all settings can be overridden via command line arguments, e.g. tclaude --thinking or tclaude --no-web-search. Run tclaude --help to see all available arguments.

# Default configuration for the tclaude CLI tool.
# All settings can be omitted in your own config, in which case the defaults from this file will be used.

model = "claude-opus-4-8"
max_tokens = 16384
role = "default.md"  # Custom system prompt file. Should be placed ~/.config/tclaude/roles/

code_execution = true
web_search = true
thinking = false
thinking_budget = "auto"  # Models >=4.6: 'low', 'medium', 'high', or 'max'; earlier models: integer token count.

sessions_dir = "."  # Directory for storing session data.

endpoint = "anthropic"

[endpoints.anthropic]
kind = "anthropic"
url = "https://api.anthropic.com"
api_key = "$ANTHROPIC_API_KEY"

# Example vertex endpoint

# [endpoints.custom]
# kind = "vertex"
# url = "https://aiplatform.googleapis.com/v1/projects/<VERTEX_API_PROJECT>/locations/global/publishers/anthropic/models/<MODEL>:streamRawPredict"
# api_key = "$(gcloud auth print-access-token)"
# code_execution = false # This endpoint does not support code execution
# web_search = false # This endpoint does not support web search

# Example configuration for remote Model Context Protocol (MCP) servers

# [[mcp.local_servers]]
# name = "filesystem"
# command = "npx" # command and arguments to start the MCP server
# args = [
#     "-y",
#     "@modelcontextprotocol/server-filesystem",
#     "~", # access to the home directory
# ]
# or: url = "http://localhost:3000" # if the server is already running

# [[mcp.remote_servers]]
# name = "example-mcp"
# url = "https://example-server.modelcontextprotocol.io/sse"

# authentication = "oauth2" # opens a browser window to authenticate on first use
# or: authentication = "none"
# or: authentication = "token", authorization_token = "<your-authorization-token>"

# Optional: restrict the tools that can be used with this MCP server
# authorization_token = "<your-authorization-token>"
# tool_configuration.enabled = true
# tool_configuration.allowed_tools = [
#   "example_tool_1",
#   "example_tool_2",
# ]
#
# [[mcp.remote_servers]]
# name = "another-mcp"
# ...

License

GPLv3; see LICENSE for details.

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

tclaude-1.1.4.tar.gz (66.9 kB view details)

Uploaded Source

Built Distribution

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

tclaude-1.1.4-py3-none-any.whl (82.1 kB view details)

Uploaded Python 3

File details

Details for the file tclaude-1.1.4.tar.gz.

File metadata

  • Download URL: tclaude-1.1.4.tar.gz
  • Upload date:
  • Size: 66.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tclaude-1.1.4.tar.gz
Algorithm Hash digest
SHA256 99c721eb53a4b567b84d34c3520042b888122619a42802860af97a203af81176
MD5 c998d511bb7f9e8b3b78e687287d39dd
BLAKE2b-256 cf49599299dfdc46ed4761712dd645606b70bdb3942ad84720bb58ada7337c5e

See more details on using hashes here.

Provenance

The following attestation bundles were made for tclaude-1.1.4.tar.gz:

Publisher: pypi.yml on Tom94/tclaude

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tclaude-1.1.4-py3-none-any.whl.

File metadata

  • Download URL: tclaude-1.1.4-py3-none-any.whl
  • Upload date:
  • Size: 82.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tclaude-1.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 70734fc00e6ef836d938c7006da7a5213be04ad49e02ed755217d05646d55e2c
MD5 4cc8983336716c4e8e4afcbb99eacac4
BLAKE2b-256 902bc62d389def3804f36322de45e70b948d06cbd68eb2548ca822ac77a0085e

See more details on using hashes here.

Provenance

The following attestation bundles were made for tclaude-1.1.4-py3-none-any.whl:

Publisher: pypi.yml on Tom94/tclaude

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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