AI coding agent, built for the terminal. https://opencode.ai
Find a file
2025-06-20 14:55:41 -04:00
.github/workflows ci: share 2025-06-19 13:26:15 -04:00
infra Infra: fix DO tag 2025-06-19 17:20:13 -04:00
packages add getModel function per provider 2025-06-20 14:55:41 -04:00
patches fix issue with tool schemas and google 2025-06-17 11:27:07 -04:00
scripts hooks 2025-06-19 00:20:03 -04:00
.gitignore feat(tui): configurable keybinds and mouse scroll 2025-06-18 13:56:51 -05:00
bun.lock add getModel function per provider 2025-06-20 14:55:41 -04:00
bunfig.toml Optimize package management with catalog and exact versions 2025-05-30 21:56:37 -04:00
install fix(install): check if the path export command already exists (#28) 2025-06-13 23:28:33 -04:00
LICENSE sync 2025-05-30 20:48:36 -04:00
opencode.json docs: remove opencode.json 2025-06-20 01:00:15 -04:00
package.json hooks 2025-06-19 00:20:03 -04:00
README.md docs: Update README.md 2025-06-19 18:19:06 -04:00
sst-env.d.ts Infra: use Astro component 2025-06-07 23:46:56 -04:00
sst.config.ts sync 2025-05-30 20:48:36 -04:00
tsconfig.json sync 2025-05-30 20:48:36 -04:00

opencode logo

AI coding agent, built for the terminal.

View docs npm Build status

opencode Terminal UI


Installation

# YOLO
curl -fsSL https://opencode.ai/install | bash

# Package managers
npm i -g opencode-ai@latest        # or bun/pnpm/yarn
brew install sst/tap/opencode      # macOS
paru -S opencode-bin               # Arch Linux

Note: Remove versions older than 0.1.x before installing

Documentation

For more info on how to configure opencode head over to our docs.

Contributing

To run opencode locally you need.

  • Bun
  • Golang 1.24.x

And run.

$ bun install
$ bun run packages/opencode/src/index.ts

FAQ

How do I use this with OpenRouter?

OpenRouter is not in the Models.dev database yet, but you can configure it manually.

{
  "$schema": "https://opencode.ai/config.json",
  "provider": {
    "openrouter": {
      "npm": "@openrouter/ai-sdk-provider",
      "name": "OpenRouter",
      "options": {},
      "models": {
        "anthropic/claude-3.5-sonnet": {
          "name": "Claude 3.5 Sonnet"
        }
      }
    }
  }
}

And then to configure an api key you can do opencode auth login and select "Other -> 'openrouter'"

How is this different than Claude Code?

It's very similar to Claude Code in terms of capability. Here are the key differences:

  • 100% open source
  • Not coupled to any provider. Although Anthropic is recommended, opencode can be used with OpenAI, Google or even local models. As models evolve the gaps between them will close and pricing will drop so being provider agnostic is important.
  • A focus on TUI. opencode is built by neovim users and the creators of terminal.shop; we are going to push the limits of what's possible in the terminal.
  • A client/server architecture. This for example can allow opencode to run on your computer, while you can drive it remotely from a mobile app. Meaning that the TUI frontend is just one of the possible clients.

What about Windows support?

There are some minor problems blocking opencode from working on windows. We are working on on them now. You'll need to use WSL for now.

What's the other repo?

The other confusingly named repo has no relation to this one. You can read the story behind it here.


Join our community YouTube | X.com