2
0

OpenCode in IDE

Kujtim Hoxha e3a62736db add license 10 сар өмнө
cmd cc07f7a186 rename to opencode 10 сар өмнө
internal c24e3c18e0 small improvements 10 сар өмнө
.gitignore 76b4065f17 update gitignore 10 сар өмнө
.opencode.json c24e3c18e0 small improvements 10 сар өмнө
LICENSE e3a62736db add license 10 сар өмнө
README.md bbfa60c787 reimplement agent,provider and add file history 10 сар өмнө
go.mod cc07f7a186 rename to opencode 10 сар өмнө
go.sum bbfa60c787 reimplement agent,provider and add file history 10 сар өмнө
main.go 36172979b4 Update agent prompt, improve TUI patch UI, remove obsolete tool tests 10 сар өмнө
sqlc.yaml 8daa6e774a add initial stuff 11 сар өмнө

README.md

OpenCode

⚠️ Early Development Notice: This project is in early development and is not yet ready for production use. Features may change, break, or be incomplete. Use at your own risk.

A powerful terminal-based AI assistant for developers, providing intelligent coding assistance directly in your terminal.

OpenCode Demo

Overview

OpenCode is a Go-based CLI application that brings AI assistance to your terminal. It provides a TUI (Terminal User Interface) for interacting with various AI models to help with coding tasks, debugging, and more.

Features

  • Interactive TUI: Built with Bubble Tea for a smooth terminal experience
  • Multiple AI Providers: Support for OpenAI, Anthropic Claude, and Google Gemini models
  • Session Management: Save and manage multiple conversation sessions
  • Tool Integration: AI can execute commands, search files, and modify code
  • Vim-like Editor: Integrated editor with Vim keybindings for text input
  • Persistent Storage: SQLite database for storing conversations and sessions

Installation

# Coming soon
go install github.com/kujtimiihoxha/opencode@latest

Configuration

OpenCode looks for configuration in the following locations:

  • $HOME/.opencode.json
  • $XDG_CONFIG_HOME/opencode/.opencode.json
  • ./.opencode.json (local directory)

You can also use environment variables:

  • ANTHROPIC_API_KEY: For Claude models
  • OPENAI_API_KEY: For OpenAI models
  • GEMINI_API_KEY: For Google Gemini models

Usage

# Start OpenCode
opencode

# Start with debug logging
opencode -d

Keyboard Shortcuts

Global Shortcuts

  • ?: Toggle help panel
  • Ctrl+C or q: Quit application
  • L: View logs
  • Backspace: Go back to previous page
  • Esc: Close current view/dialog or return to normal mode

Session Management

  • N: Create new session
  • Enter or Space: Select session (in sessions list)

Editor Shortcuts (Vim-like)

  • i: Enter insert mode
  • Esc: Enter normal mode
  • v: Enter visual mode
  • V: Enter visual line mode
  • Enter: Send message (in normal mode)
  • Ctrl+S: Send message (in insert mode)

Navigation

  • Arrow keys: Navigate through lists and content
  • Page Up/Down: Scroll through content

Architecture

OpenCode is built with a modular architecture:

  • cmd: Command-line interface using Cobra
  • internal/app: Core application services
  • internal/config: Configuration management
  • internal/db: Database operations and migrations
  • internal/llm: LLM providers and tools integration
  • internal/tui: Terminal UI components and layouts
  • internal/logging: Logging infrastructure
  • internal/message: Message handling
  • internal/session: Session management

Development

Prerequisites

  • Go 1.23.5 or higher

Building from Source

# Clone the repository
git clone https://github.com/kujtimiihoxha/opencode.git
cd opencode

# Build the diff script first
go run cmd/diff/main.go

# Build
go build -o opencode

# Run
./opencode

Acknowledgments

OpenCode builds upon the work of several open source projects and developers:

License

[License information coming soon]

Contributing

[Contribution guidelines coming soon]