OpenCode in IDE

Dax Raad 2051e85e96 remove providers path 7 hónapja
.github ce064b8b0e wip: github action 7 hónapja
infra 1c4fd7f28f Api: add endpoint for getting github app token 7 hónapja
packages 2051e85e96 remove providers path 7 hónapja
scripts 10c8b49590 chore: generate sdk into packages/sdk 7 hónapja
sdks 638ec7bc50 Allow multiline prompts for github agent (#1225) 7 hónapja
.editorconfig dd22cb2bb0 chore: add .editorconfig (#536) 7 hónapja
.gitignore 5a0910ea79 chore: better local dev with stainless script 7 hónapja
AGENTS.md 6d2ffa82de ignore: lock changes 7 hónapja
LICENSE ef3fd5900f docs: cleanup casing 8 hónapja
README.md 01e7dc2d02 Added install dir priority & user feedback (#1129) 7 hónapja
STATS.md 6c9ec54129 ignore: update download stats 2025-07-23 7 hónapja
bun.lock 6d2ffa82de ignore: lock changes 7 hónapja
bunfig.toml 1472efcbfe Optimize package management with catalog and exact versions 8 hónapja
install c87a7469a0 ci: rollback install script 7 hónapja
opencode.json 6d2ffa82de ignore: lock changes 7 hónapja
package.json d4f9375548 fix: type 'reasoning' was provided without its required following item (#1072) 7 hónapja
sst-env.d.ts 1c4fd7f28f Api: add endpoint for getting github app token 7 hónapja
sst.config.ts f3da73553c sync 8 hónapja
stainless-workspace.json 5a0910ea79 chore: better local dev with stainless script 7 hónapja
stainless.yml 10c8b49590 chore: generate sdk into packages/sdk 7 hónapja
tsconfig.json 780419ecae ci: daily stats script 7 hónapja

README.md

opencode logo

AI coding agent, built for the terminal.

Discord 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

[!TIP] Remove versions older than 0.1.x before installing.

Installation Directory

The install script respects the following priority order for the installation path:

  1. $OPENCODE_INSTALL_DIR - Custom installation directory
  2. $XDG_BIN_DIR - XDG Base Directory Specification compliant path
  3. $HOME/bin - Standard user binary directory (if exists or can be created)
  4. $HOME/.opencode/bin - Default fallback

    # Examples
    OPENCODE_INSTALL_DIR=/usr/local/bin curl -fsSL https://opencode.ai/install | bash
    XDG_BIN_DIR=$HOME/.local/bin curl -fsSL https://opencode.ai/install | bash
    

Documentation

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

Contributing

opencode is an opinionated tool so any fundamental feature needs to go through a design process with the core team.

[!IMPORTANT] We do not accept PRs for core features.

However we still merge a ton of PRs - you can contribute:

  • Bug fixes
  • Improvements to LLM performance
  • Support for new providers
  • Fixes for env specific quirks
  • Missing standard behavior
  • Documentation

Take a look at the git history to see what kind of PRs we end up merging.

[!NOTE] If you do not follow the above guidelines we might close your PR.

To run opencode locally you need.

  • Bun
  • Golang 1.24.x

And run.

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

Development Notes

API Client: After making changes to the TypeScript API endpoints in packages/opencode/src/server/server.ts, you will need the opencode team to generate a new stainless sdk for the clients.

FAQ

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'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 Discord | YouTube | X.com