mirror of
https://gitea.toothfairyai.com/ToothFairyAI/tf_code.git
synced 2026-04-07 09:18:41 +00:00
345 lines
8.8 KiB
Plaintext
345 lines
8.8 KiB
Plaintext
---
|
|
title: 소개
|
|
description: OpenCode를 시작해 보세요.
|
|
---
|
|
|
|
import { Tabs, TabItem } from "@astrojs/starlight/components"
|
|
import config from "../../../../config.mjs"
|
|
export const console = config.console
|
|
|
|
[**OpenCode**](/)는 오픈 소스 AI coding agent입니다. 터미널 기반 인터페이스, 데스크톱 앱, IDE 확장으로 사용할 수 있습니다.
|
|
|
|

|
|
|
|
바로 시작해 보겠습니다.
|
|
|
|
---
|
|
|
|
#### 사전 준비
|
|
|
|
터미널에서 OpenCode를 사용하려면 다음이 필요합니다.
|
|
|
|
1. 다음과 같은 최신 터미널 에뮬레이터
|
|
- [WezTerm](https://wezterm.org), 크로스 플랫폼
|
|
- [Alacritty](https://alacritty.org), 크로스 플랫폼
|
|
- [Ghostty](https://ghostty.org), Linux 및 macOS
|
|
- [Kitty](https://sw.kovidgoyal.net/kitty/), Linux 및 macOS
|
|
|
|
2. 사용할 LLM 제공자의 API 키
|
|
|
|
---
|
|
|
|
## 설치
|
|
|
|
OpenCode를 설치하는 가장 쉬운 방법은 설치 스크립트를 사용하는 것입니다.
|
|
|
|
```bash
|
|
curl -fsSL https://opencode.ai/install | bash
|
|
```
|
|
|
|
다음 명령으로도 설치할 수 있습니다.
|
|
|
|
- **Node.js 사용**
|
|
|
|
<Tabs>
|
|
|
|
<TabItem label="npm">
|
|
```bash
|
|
npm install -g opencode-ai
|
|
```
|
|
|
|
</TabItem>
|
|
|
|
<TabItem label="Bun">
|
|
```bash
|
|
bun install -g opencode-ai
|
|
```
|
|
|
|
</TabItem>
|
|
|
|
<TabItem label="pnpm">
|
|
```bash
|
|
pnpm install -g opencode-ai
|
|
```
|
|
|
|
</TabItem>
|
|
|
|
<TabItem label="Yarn">
|
|
```bash
|
|
yarn global add opencode-ai
|
|
```
|
|
|
|
</TabItem>
|
|
|
|
</Tabs>
|
|
|
|
- **macOS/Linux에서 Homebrew 사용**
|
|
|
|
```bash
|
|
brew install anomalyco/tap/opencode
|
|
```
|
|
|
|
> 최신 릴리스를 사용하려면 OpenCode tap 사용을 권장합니다. 공식 `brew install opencode` formula는 Homebrew 팀이 관리하며 업데이트 주기가 더 깁니다.
|
|
|
|
- **Arch Linux에 설치**
|
|
|
|
```bash
|
|
sudo pacman -S opencode # Arch Linux (Stable)
|
|
paru -S opencode-bin # Arch Linux (Latest from AUR)
|
|
```
|
|
|
|
#### Windows
|
|
|
|
:::tip[권장: WSL 사용]
|
|
Windows에서는 [Windows Subsystem for Linux (WSL)](/docs/windows-wsl) 사용을 권장합니다. 성능이 더 좋고 OpenCode 기능과의 완전한 호환성을 제공합니다.
|
|
:::
|
|
|
|
- **Chocolatey 사용**
|
|
|
|
```bash
|
|
choco install opencode
|
|
```
|
|
|
|
- **Scoop 사용**
|
|
|
|
```bash
|
|
scoop install opencode
|
|
```
|
|
|
|
- **NPM 사용**
|
|
|
|
```bash
|
|
npm install -g opencode-ai
|
|
```
|
|
|
|
- **Mise 사용**
|
|
|
|
```bash
|
|
mise use -g github:anomalyco/opencode
|
|
```
|
|
|
|
- **Docker 사용**
|
|
|
|
```bash
|
|
docker run -it --rm ghcr.io/anomalyco/opencode
|
|
```
|
|
|
|
현재 Windows에서 Bun을 사용한 OpenCode 설치 지원은 준비 중입니다.
|
|
|
|
[Releases](https://github.com/anomalyco/opencode/releases)에서 바이너리를 직접 받아 설치할 수도 있습니다.
|
|
|
|
---
|
|
|
|
## 구성
|
|
|
|
OpenCode는 API 키를 설정하면 원하는 LLM 제공자를 사용할 수 있습니다.
|
|
|
|
LLM 제공자를 처음 사용한다면 [OpenCode Zen](/docs/zen) 사용을 권장합니다.
|
|
OpenCode 팀이 테스트하고 검증한 모델 목록입니다.
|
|
|
|
1. TUI에서 `/connect` 명령을 실행하고 `opencode`를 선택한 다음 [opencode.ai/auth](https://opencode.ai/auth)로 이동합니다.
|
|
|
|
```txt
|
|
/connect
|
|
```
|
|
|
|
2. 로그인하고 결제 정보를 추가한 뒤 API 키를 복사합니다.
|
|
|
|
3. API 키를 붙여 넣습니다.
|
|
|
|
```txt
|
|
┌ API key
|
|
│
|
|
│
|
|
└ enter
|
|
```
|
|
|
|
또는 다른 제공자 중 하나를 선택할 수도 있습니다. [더 알아보기](/docs/providers#directory).
|
|
|
|
---
|
|
|
|
## 초기화
|
|
|
|
이제 제공자 구성을 마쳤으니 작업하려는 프로젝트로 이동합니다.
|
|
|
|
```bash
|
|
cd /path/to/project
|
|
```
|
|
|
|
그리고 OpenCode를 실행합니다.
|
|
|
|
```bash
|
|
opencode
|
|
```
|
|
|
|
다음 명령을 실행해 프로젝트에서 OpenCode를 초기화합니다.
|
|
|
|
```bash frame="none"
|
|
/init
|
|
```
|
|
|
|
이 명령을 실행하면 OpenCode가 프로젝트를 분석하고 프로젝트 루트에 `AGENTS.md` 파일을 생성합니다.
|
|
|
|
:::tip
|
|
프로젝트의 `AGENTS.md` 파일은 Git에 커밋하는 것을 권장합니다.
|
|
:::
|
|
|
|
이렇게 하면 OpenCode가 프로젝트 구조와 사용 중인 코딩 패턴을 더 잘 이해할 수 있습니다.
|
|
|
|
---
|
|
|
|
## 사용법
|
|
|
|
이제 OpenCode로 프로젝트 작업을 시작할 준비가 되었습니다. 무엇이든 물어보세요.
|
|
|
|
AI coding agent를 처음 사용한다면 도움이 될 수 있는 예시를 소개합니다.
|
|
|
|
---
|
|
|
|
### 질문하기
|
|
|
|
OpenCode에 코드베이스 설명을 요청할 수 있습니다.
|
|
|
|
:::tip
|
|
프로젝트 파일은 `@` 키로 퍼지 검색할 수 있습니다.
|
|
:::
|
|
|
|
```txt frame="none" "@packages/functions/src/api/index.ts"
|
|
How is authentication handled in @packages/functions/src/api/index.ts
|
|
```
|
|
|
|
이 방법은 직접 작업하지 않은 코드 영역을 이해할 때 유용합니다.
|
|
|
|
---
|
|
|
|
### 기능 추가
|
|
|
|
OpenCode에 프로젝트의 새 기능 추가를 요청할 수 있습니다. 다만 먼저 계획을 만들도록 요청하는 것을 권장합니다.
|
|
|
|
1. **계획 만들기**
|
|
|
|
OpenCode에는 변경 작업 기능을 비활성화하고 기능을 구현할 방법만 제안하는 *Plan mode*가 있습니다.
|
|
|
|
**Tab** 키를 눌러 전환하세요. 화면 오른쪽 아래에서 모드 표시를 확인할 수 있습니다.
|
|
|
|
```bash frame="none" title="Switch to Plan mode"
|
|
<TAB>
|
|
```
|
|
|
|
이제 수행하길 원하는 작업을 설명해 보겠습니다.
|
|
|
|
```txt frame="none"
|
|
When a user deletes a note, we'd like to flag it as deleted in the database.
|
|
Then create a screen that shows all the recently deleted notes.
|
|
From this screen, the user can undelete a note or permanently delete it.
|
|
```
|
|
|
|
OpenCode가 원하는 작업을 이해할 수 있도록 충분한 세부 정보를 제공해야 합니다. 팀의 주니어 개발자에게 말하듯이 설명하면 도움이 됩니다.
|
|
|
|
:::tip
|
|
OpenCode가 원하는 작업을 이해하도록 충분한 맥락과 예시를 제공하세요.
|
|
:::
|
|
|
|
2. **계획 다듬기**
|
|
|
|
계획이 나오면 피드백을 주거나 세부 사항을 더 추가할 수 있습니다.
|
|
|
|
```txt frame="none"
|
|
We'd like to design this new screen using a design I've used before.
|
|
[Image #1] Take a look at this image and use it as a reference.
|
|
```
|
|
|
|
:::tip
|
|
이미지를 터미널에 드래그 앤 드롭해 prompt에 추가하세요.
|
|
:::
|
|
|
|
OpenCode는 제공한 이미지를 스캔해 prompt에 추가할 수 있습니다. 이미지를 터미널에 드래그 앤 드롭하면 됩니다.
|
|
|
|
3. **기능 구현**
|
|
|
|
계획이 충분히 마음에 들면 **Tab** 키를 다시 눌러 *Build mode*로 전환하세요.
|
|
|
|
```bash frame="none"
|
|
<TAB>
|
|
```
|
|
|
|
그리고 변경을 적용해 달라고 요청하세요.
|
|
|
|
```bash frame="none"
|
|
Sounds good! Go ahead and make the changes.
|
|
```
|
|
|
|
---
|
|
|
|
### 바로 변경하기
|
|
|
|
비교적 간단한 변경은 계획을 먼저 검토하지 않고 바로 구현하도록 요청할 수 있습니다.
|
|
|
|
```txt frame="none" "@packages/functions/src/settings.ts" "@packages/functions/src/notes.ts"
|
|
We need to add authentication to the /settings route. Take a look at how this is
|
|
handled in the /notes route in @packages/functions/src/notes.ts and implement
|
|
the same logic in @packages/functions/src/settings.ts
|
|
```
|
|
|
|
OpenCode가 올바른 변경을 하도록 충분한 세부 정보를 제공해야 합니다.
|
|
|
|
---
|
|
|
|
### 변경 되돌리기
|
|
|
|
예를 들어 OpenCode에 변경을 요청했다고 해보겠습니다.
|
|
|
|
```txt frame="none" "@packages/functions/src/api/index.ts"
|
|
Can you refactor the function in @packages/functions/src/api/index.ts?
|
|
```
|
|
|
|
그런데 원하는 결과가 아니었다면 `/undo` 명령으로 변경을 **되돌릴 수** 있습니다.
|
|
|
|
```bash frame="none"
|
|
/undo
|
|
```
|
|
|
|
OpenCode가 방금 적용한 변경을 되돌리고 원래 메시지를 다시 보여줍니다.
|
|
|
|
```txt frame="none" "@packages/functions/src/api/index.ts"
|
|
Can you refactor the function in @packages/functions/src/api/index.ts?
|
|
```
|
|
|
|
여기에서 prompt를 수정해 다시 요청할 수 있습니다.
|
|
|
|
:::tip
|
|
`/undo`는 여러 번 연속으로 실행할 수 있습니다.
|
|
:::
|
|
|
|
또는 `/redo` 명령으로 변경을 **다시 적용**할 수 있습니다.
|
|
|
|
```bash frame="none"
|
|
/redo
|
|
```
|
|
|
|
---
|
|
|
|
## 공유
|
|
|
|
OpenCode와의 대화는 [팀과 공유](/docs/share)할 수 있습니다.
|
|
|
|
```bash frame="none"
|
|
/share
|
|
```
|
|
|
|
이 명령을 실행하면 현재 대화 링크를 생성하고 클립보드에 복사합니다.
|
|
|
|
:::note
|
|
대화는 기본값으로 공유되지 않습니다.
|
|
:::
|
|
|
|
다음은 OpenCode [대화 예시](https://opencode.ai/s/4XP1fce5)입니다.
|
|
|
|
---
|
|
|
|
## 사용자 지정
|
|
|
|
이제 OpenCode 사용법을 익혔습니다.
|
|
|
|
원하는 방식에 맞추려면 [테마 선택](/docs/themes), [키바인드 사용자 지정](/docs/keybinds), [코드 formatter 설정](/docs/formatters), [custom command 만들기](/docs/commands), [OpenCode config 설정](/docs/config)을 권장합니다.
|