A lightweight terminal-based AI coding assistant
Project description
nanocode
A lightweight terminal-based AI coding assistant.
nanocode is used to help building itself, including features such as @file path completion.
Pre-1.0 note: nanocode is still evolving quickly. Functionality, commands, configuration, and behavior may change incompatibly before a 1.0 release.
Screenshots
Features
- Constrained Output: Force model replies into auditable action frames.
- Verified Edits: Reject stale range edits before they touch files.
- Autonomous Loop: Chain reading, editing, running, and verification.
- Live Telemetry: Stream tool intent, token use, and status.
Install
uv tool install nanocode-cli
Upgrade an existing install:
uv tool upgrade nanocode-cli
For local development:
uv sync --extra dev
uv run nanocode
Usage
Start nanocode:
nanocode
Show available commands:
/help
Ask a source-aware question about nanocode itself:
/help how does compact work?
CLI arguments:
--yolo: Skip tool execution confirmations.--plan: Plan changes without editing files or running commands.--debug: Write request prompts to the current session directory under~/.nanocode/sessions/.--config <path>: Path to config file (default:~/.nanocode/config.toml).--init-config: Create a default config file.-v,--version: Show program version.
Safety
nanocode does NOT provide sandbox protection. It can run shell commands and edit files in the environment where you start it.
If you do not fully trust the model, tools, prompts, or workspace, run nanocode inside your own sandbox, container, VM, or other isolated environment.
USE AT YOUR OWN RISK.
Tools
- File:
Read,LineCount,ListDir,Search. - Edit:
Edit,ReplaceRange. - Shell:
Bash,Git. - Memory:
Recallreads stored tool results by key.
Commands
- Info:
/help [question],/status,/rules,/knowledge,/compact. - Config:
/config,/set <key> <value>,/model [model_name],/reason,/provider [name],/plan [on|off|question],/yolo. - Maintenance:
/clean. - Exit:
/exit,/quit.
Selectors support j/k, arrows, /keyword, Enter, and Esc. /model lists configured models before discovered ones, then prompts for reasoning; /model <name> and /reason are direct shortcuts.
Configuration
Run nanocode --init-config to create ~/.nanocode/config.toml.
- Provider config:
[provider] active = "<name>"plus[provider.<name>]url, key, model,available_models, and model options.reasoning_payloadcontrols whether effort is sent asreasoning,reasoning_effort, or not sent. - Path config:
[paths] data_dir = "~/.nanocode". - Runtime config:
[runtime]. - Session data: debug prompts and tool-result logs are stored under
~/.nanocode/sessions/<session_id>/. - Tool-result logs from inactive sessions are auto-cleaned after
runtime.auto_clean_recent(default3d; useoffto disable)./cleanremoves inactive session logs immediately. - Project data: user rules are stored under
~/.nanocode/projects/<project_key>/.
Status
- Status bar: active model, reasoning, active yolo/plan modes, conversation context, current-turn tool calls, tokens, elapsed time, and active model-call time.
/status: active provider, model state, session id, runtime state, conversation/tool counters, per-model calls/tokens, task, goal, and verification.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nanocode_cli-0.3.34.tar.gz.
File metadata
- Download URL: nanocode_cli-0.3.34.tar.gz
- Upload date:
- Size: 79.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5cf9eed1553bb7e56058e848d5d00cf38c7d75b7baceed1c76851da84f94cd22
|
|
| MD5 |
c7c1ce832b93d8f171da89948911a0e6
|
|
| BLAKE2b-256 |
433a484dac5d68f10a42e0b96dd8d43598fd3c63fd881491383c4cfb3d5dc1aa
|
File details
Details for the file nanocode_cli-0.3.34-py3-none-any.whl.
File metadata
- Download URL: nanocode_cli-0.3.34-py3-none-any.whl
- Upload date:
- Size: 78.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c639af083721e137318064278595f0be4a42eb387f1974887f5bf2c561d6f5ac
|
|
| MD5 |
b7737dbd451ba9fb675c3c54082d5af7
|
|
| BLAKE2b-256 |
e7804bc1b798a6932f45f141c3e87cdf66364908b3e2a2c33773576aab0eb7b2
|