TUI
OpenCode 터미널 사용자 인터페이스 사용.
OpenCode는 LLM과 함께 프로젝트 작업을 하기 위한 대화형 터미널 인터페이스(TUI)를 제공합니다.
OpenCode를 실행하면 현재 디렉토리에서 TUI가 시작됩니다.
opencode또는 특정 작업 디렉토리에 대해 시작할 수 있습니다.
opencode /path/to/projectTUI에 들어가면 메시지를 입력하여 프롬프트할 수 있습니다.
Give me a quick summary of the codebase.파일 참조
@를 사용하여 메시지에서 파일을 참조할 수 있습니다. 이것은 현재 작업 디렉토리에서 퍼지(fuzzy) 파일 검색을 수행합니다.
How is auth handled in @packages/functions/src/api/index.ts?파일의 내용이 자동으로 대화에 추가됩니다.
Bash 명령
!로 메시지를 시작하여 셸 명령을 실행합니다.
!ls -la명령의 출력은 도구 결과로 대화에 추가됩니다.
명령
OpenCode TUI를 사용할 때 / 뒤에 명령 이름을 입력하여 작업을 빠르게 실행할 수 있습니다. 예를 들어:
/help대부분의 명령에는 기본 리더 키인 ctrl+x를 사용하는 키바인드도 있습니다. 더 알아보기.
사용 가능한 모든 슬래시 명령은 다음과 같습니다:
connect
OpenCode에 공급자를 추가합니다. 사용 가능한 공급자 중에서 선택하고 API 키를 추가할 수 있습니다.
/connectcompact
현재 세션을 압축합니다. 별칭: /summarize
/compact키바인드: ctrl+x c
details
도구 실행 세부 정보 토글.
/details키바인드: ctrl+x d
editor
메시지 작성을 위한 외부 편집기를 엽니다. EDITOR 환경 변수에 설정된 편집기를 사용합니다. 더 알아보기.
/editor키바인드: ctrl+x e
exit
OpenCode를 종료합니다. 별칭: /quit, /q
/exit키바인드: ctrl+x q
export
현재 대화를 Markdown으로 내보내고 기본 편집기에서 엽니다. EDITOR 환경 변수에 설정된 편집기를 사용합니다. 더 알아보기.
/export키바인드: ctrl+x x
help
도움말 대화 상자를 표시합니다.
/help키바인드: ctrl+x h
init
AGENTS.md 파일을 생성하거나 업데이트합니다. 더 알아보기.
/init키바인드: ctrl+x i
models
사용 가능한 모델 목록을 표시합니다.
/models키바인드: ctrl+x m
new
새 세션을 시작합니다. 별칭: /clear
/new키바인드: ctrl+x n
redo
이전에 실행 취소한 메시지를 다시 실행합니다. /undo를 사용한 후에만 사용할 수 있습니다.
내부적으로 Git을 사용하여 파일 변경 사항을 관리합니다. 따라서 프로젝트가 Git 저장소여야 합니다.
/redo키바인드: ctrl+x r
sessions
세션 목록을 표시하고 세션 간을 전환합니다. 별칭: /resume, /continue
/sessions키바인드: ctrl+x l
share
현재 세션을 공유합니다. 더 알아보기.
/share키바인드: ctrl+x s
themes
사용 가능한 테마 목록을 표시합니다.
/themes키바인드: ctrl+x t
thinking
대화에서 생각/추론 블록의 가시성을 토글합니다. 활성화하면 확장된 사고를 지원하는 모델의 추론 과정을 볼 수 있습니다.
/thinkingundo
대화의 마지막 메시지를 실행 취소합니다. 가장 최근의 사용자 메시지, 모든 후속 응답 및 모든 파일 변경 사항을 제거합니다.
내부적으로 Git을 사용하여 파일 변경 사항을 관리합니다. 따라서 프로젝트가 Git 저장소여야 합니다.
/undo키바인드: ctrl+x u
unshare
현재 세션 공유를 취소합니다. 더 알아보기.
/unshareEditor setup
/editor와 /export 명령 모두 EDITOR 환경 변수에 지정된 편집기를 사용합니다.
# Example for nano or vimexport EDITOR=nanoexport EDITOR=vim
# For GUI editors, VS Code, Cursor, VSCodium, Windsurf, Zed, etc.# include --waitexport EDITOR="code --wait"영구적으로 설정하려면 셸 프로필(~/.bashrc, ~/.zshrc 등)에 추가하십시오.
set EDITOR=notepad
# For GUI editors, VS Code, Cursor, VSCodium, Windsurf, Zed, etc.# include --waitset EDITOR=code --wait영구적으로 설정하려면 시스템 속성 > 환경 변수를 사용하십시오.
$env:EDITOR = "notepad"
# For GUI editors, VS Code, Cursor, VSCodium, Windsurf, Zed, etc.# include --wait$env:EDITOR = "code --wait"영구적으로 설정하려면 PowerShell 프로필에 추가하십시오.
인기 있는 편집기 옵션은 다음과 같습니다:
code- Visual Studio Codecursor- Cursorwindsurf- Windsurfnvim- Neovim editorvim- Vim editornano- Nano editornotepad- Windows Notepadsubl- Sublime Text
일부 편집기는 차단 모드에서 실행하려면 명령줄 인수가 필요합니다. --wait 플래그는 편집기 프로세스가 닫힐 때까지 차단되도록 합니다.
구성
tui.json (또는 tui.jsonc) 파일을 통해 TUI 동작을 사용자 정의할 수 있습니다.
{ "$schema": "https://opencode.ai/tui.json", "theme": "opencode", "keybinds": { "leader": "ctrl+x" }, "scroll_speed": 3, "scroll_acceleration": { "enabled": true }, "diff_style": "auto"}이는 서버/런타임 동작을 구성하는 opencode.json과는 별개입니다.
옵션
theme- UI 테마를 설정합니다. 더 알아보기.keybinds- 키보드 단축키를 사용자 정의합니다. 더 알아보기.scroll_acceleration.enabled- 부드럽고 자연스러운 스크롤을 위해 macOS 스타일의 스크롤 가속을 활성화합니다. 활성화하면 빠른 스크롤 제스처로 스크롤 속도가 증가하고 느린 움직임에서는 정밀하게 유지됩니다. 이 설정은scroll_speed보다 우선하며 활성화 시 이를 덮어씁니다.scroll_speed- 스크롤 명령을 사용할 때 TUI 스크롤 속도를 제어합니다 (최소:0.001, 소수점 값 지원). 기본값은3입니다. 참고:scroll_acceleration.enabled가true로 설정되면 무시됩니다.diff_style- diff 렌더링 방식을 제어합니다."auto"는 터미널 너비에 적응하고,"stacked"는 항상 단일 열 레이아웃을 표시합니다.
OPENCODE_TUI_CONFIG를 사용하여 사용자 정의 TUI 설정 경로를 로드할 수 있습니다.
사용자 정의
명령 팔레트(ctrl+x h 또는 /help)를 사용하여 TUI 보기의 다양한 측면을 사용자 정의할 수 있습니다. 설정은 다시 시작해도 유지됩니다.
사용자 이름 표시
채팅 메시지에 사용자 이름이 표시되는지 여부를 토글합니다. 다음을 통해 액세스:
- 명령 팔레트: “username” 또는 “hide username” 검색
- 설정은 자동으로 유지되며 TUI 세션 간에 기억됩니다.