OpenCode in IDE

GitHub Action 8552f3555e chore: format code 4 ماه پیش
.github 64617c113a ignore: tweak permissions 4 ماه پیش
.husky fcbc78180b ci: fix 5 ماه پیش
.opencode 285cc4b9fd docs: fix misspelled word (#3211) 4 ماه پیش
github 1c1380d3c8 adjust action 4 ماه پیش
infra 477586835a ci: try regional hostname again 4 ماه پیش
packages 47d9e01765 wip: css/ui and desktop work 4 ماه پیش
patches 854f9227a2 Patch Start to preload route css in SSR (#2389) 5 ماه پیش
script 7474788778 ci: fix 4 ماه پیش
sdks 2517b22552 release: v0.15.5 4 ماه پیش
specs f993541e0b Refactor to support multiple instances inside single opencode process (#2360) 5 ماه پیش
.editorconfig dd22cb2bb0 chore: add .editorconfig (#536) 7 ماه پیش
.gitignore 8acd537d1d ci: turborepo typecheck 5 ماه پیش
AGENTS.md cc955098cd wip: desktop work 4 ماه پیش
LICENSE ef3fd5900f docs: cleanup casing 8 ماه پیش
README.md 2d2d4641cb ignore: update readme 4 ماه پیش
STATS.md 9159afb54b ignore: update download stats 2025-10-16 4 ماه پیش
bun.lock 8552f3555e chore: format code 4 ماه پیش
bunfig.toml 1472efcbfe Optimize package management with catalog and exact versions 8 ماه پیش
install 6404bd006d ignore: more reliable install script, handle non prettified json responses (#2745) 5 ماه پیش
opencode.json 14cb2d2af6 feat: improve file watcher with chokidar and better ignore patterns (#2621) 5 ماه پیش
package.json 47d9e01765 wip: css/ui and desktop work 4 ماه پیش
sst-env.d.ts 70da3a9399 wip: zen 4 ماه پیش
sst.config.ts bfe3f03e03 ci: fix deploy 5 ماه پیش
tsconfig.json 925ce6503e sync 5 ماه پیش
turbo.json 8bea479df9 ci: wtf 5 ماه پیش

README.md

OpenCode logo

The 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 and Linux
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 1.3 or higher
  • Golang 1.24.x

And run.

$ bun install
$ bun dev

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.
  • Out of the box LSP support
  • 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 | X.com