AI coding agent, built for the terminal. https://opencode.ai
Find a file
2025-04-03 17:23:41 +02:00
cmd add initial lsp support 2025-04-03 17:23:41 +02:00
internal add initial lsp support 2025-04-03 17:23:41 +02:00
.gitignore rework llm 2025-04-01 13:38:54 +02:00
go.mod add initial lsp support 2025-04-03 17:23:41 +02:00
go.sum rework llm 2025-04-01 13:38:54 +02:00
main.go add initial lsp support 2025-04-03 17:23:41 +02:00
README.md add initial lsp support 2025-04-03 17:23:41 +02:00
sqlc.yaml add initial stuff 2025-03-23 19:19:08 +01:00

TermAI

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

TermAI Demo

Overview

TermAI 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/termai@latest

Configuration

TermAI looks for configuration in the following locations:

  • $HOME/.termai.json
  • $XDG_CONFIG_HOME/termai/.termai.json
  • ./.termai.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 TermAI
termai

# Start with debug logging
termai -d

Keyboard Shortcuts

  • L: View logs
  • N: Create new session
  • Esc: Close current view
  • Backspace: Go back
  • Ctrl+C or q: Quit
  • ?: Toggle help

Architecture

TermAI 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/termai.git
cd termai

# Build
go build -o termai

# Run
./termai

Acknowledgments

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

License

[License information coming soon]

Contributing

[Contribution guidelines coming soon]