@kood/claude-code 0.4.0 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.js +53 -7
- package/package.json +2 -1
- package/templates/.claude/PARALLEL_AGENTS.md +737 -0
- package/templates/.claude/agents/analyst.md +416 -0
- package/templates/.claude/agents/architect.md +569 -0
- package/templates/.claude/agents/code-reviewer.md +132 -133
- package/templates/.claude/agents/dependency-manager.md +93 -94
- package/templates/.claude/agents/deployment-validator.md +64 -65
- package/templates/.claude/agents/designer.md +655 -0
- package/templates/.claude/agents/document-writer.md +500 -0
- package/templates/.claude/agents/explore.md +499 -0
- package/templates/.claude/agents/git-operator.md +74 -75
- package/templates/.claude/agents/implementation-executor.md +138 -109
- package/templates/.claude/agents/ko-to-en-translator.md +18 -22
- package/templates/.claude/agents/lint-fixer.md +250 -93
- package/templates/.claude/agents/planner.md +356 -0
- package/templates/.claude/agents/refactor-advisor.md +135 -136
- package/templates/.claude/commands/bug-fix.md +296 -207
- package/templates/.claude/commands/git-all.md +199 -46
- package/templates/.claude/commands/git-session.md +113 -57
- package/templates/.claude/commands/lint-fix.md +219 -153
- package/templates/.claude/commands/lint-init.md +113 -76
- package/templates/.claude/commands/pre-deploy.md +190 -124
- package/templates/.claude/commands/refactor.md +407 -162
- package/templates/.claude/commands/version-update.md +138 -37
- package/templates/.claude/instructions/context-engineering/ANTHROPIC_CONTEXT_ENGINEERING.md +178 -0
- package/templates/.claude/instructions/context-engineering/references/claude-4x.md +215 -0
- package/templates/.claude/instructions/context-engineering/references/core-principles.md +137 -0
- package/templates/.claude/instructions/context-engineering/references/examples.md +351 -0
- package/templates/.claude/instructions/context-engineering/references/techniques.md +162 -0
- package/templates/.claude/instructions/parallel-agent-execution.md +874 -0
- package/templates/.claude/skills/docs-creator/AGENTS.md +238 -0
- package/templates/.claude/{commands/docs-creator.md → skills/docs-creator/SKILL.md} +61 -75
- package/templates/.claude/skills/docs-refactor/AGENTS.md +270 -0
- package/templates/.claude/{commands/docs-refactor.md → skills/docs-refactor/SKILL.md} +30 -44
- package/templates/.claude/skills/execute/SKILL.md +451 -0
- package/templates/.claude/skills/figma-to-code/AGENTS.md +287 -0
- package/templates/.claude/skills/figma-to-code/SKILL.md +225 -225
- package/templates/.claude/skills/figma-to-code/references/design-tokens.md +75 -73
- package/templates/.claude/skills/figma-to-code/references/figma-mcp-tools.md +73 -73
- package/templates/.claude/skills/figma-to-code/references/layout-mapping.md +104 -104
- package/templates/.claude/skills/figma-to-code/references/responsive-design.md +99 -99
- package/templates/.claude/skills/figma-to-code/references/verification.md +91 -91
- package/templates/.claude/skills/global-uiux-design/AGENTS.md +317 -0
- package/templates/.claude/skills/global-uiux-design/SKILL.md +738 -0
- package/templates/.claude/skills/global-uiux-design/references/accessibility.md +401 -0
- package/templates/.claude/skills/global-uiux-design/references/color-system.md +275 -0
- package/templates/.claude/skills/global-uiux-design/references/design-philosophy.md +206 -0
- package/templates/.claude/skills/global-uiux-design/references/design-systems.md +446 -0
- package/templates/.claude/skills/korea-uiux-design/AGENTS.md +307 -0
- package/templates/.claude/skills/korea-uiux-design/SKILL.md +170 -0
- package/templates/.claude/skills/nextjs-react-best-practices/AGENTS.md +95 -116
- package/templates/.claude/skills/nextjs-react-best-practices/SKILL.md +134 -152
- package/templates/.claude/skills/nextjs-react-best-practices/rules/advanced-event-handler-refs.md +6 -6
- package/templates/.claude/skills/nextjs-react-best-practices/rules/advanced-use-latest.md +5 -5
- package/templates/.claude/skills/nextjs-react-best-practices/rules/async-api-routes.md +5 -5
- package/templates/.claude/skills/nextjs-react-best-practices/rules/async-defer-await.md +22 -22
- package/templates/.claude/skills/nextjs-react-best-practices/rules/async-dependencies.md +5 -5
- package/templates/.claude/skills/nextjs-react-best-practices/rules/async-parallel.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/async-suspense-boundaries.md +21 -21
- package/templates/.claude/skills/nextjs-react-best-practices/rules/bundle-barrel-imports.md +18 -18
- package/templates/.claude/skills/nextjs-react-best-practices/rules/bundle-conditional.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/bundle-defer-third-party.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/bundle-dynamic-imports.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/bundle-preload.md +5 -5
- package/templates/.claude/skills/nextjs-react-best-practices/rules/client-event-listeners.md +9 -9
- package/templates/.claude/skills/nextjs-react-best-practices/rules/client-swr-dedup.md +7 -7
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-batch-dom-css.md +13 -13
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-cache-function-results.md +14 -14
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-cache-property-access.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-cache-storage.md +10 -10
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-combine-iterations.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-early-exit.md +7 -7
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-hoist-regexp.md +6 -6
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-index-maps.md +6 -6
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-length-check-first.md +14 -14
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-min-max-loop.md +16 -16
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-set-map-lookups.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/js-tosorted-immutable.md +17 -17
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rendering-activity.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rendering-animate-svg-wrapper.md +11 -11
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rendering-conditional-render.md +8 -8
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rendering-content-visibility.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rendering-hoist-jsx.md +6 -6
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rendering-hydration-no-flicker.md +14 -14
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rendering-svg-precision.md +5 -5
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rerender-defer-reads.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rerender-dependencies.md +7 -7
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rerender-derived-state.md +5 -5
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rerender-functional-setstate.md +34 -34
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rerender-lazy-state-init.md +15 -15
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rerender-memo.md +5 -5
- package/templates/.claude/skills/nextjs-react-best-practices/rules/rerender-transitions.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/server-after-nonblocking.md +24 -24
- package/templates/.claude/skills/nextjs-react-best-practices/rules/server-cache-lru.md +10 -10
- package/templates/.claude/skills/nextjs-react-best-practices/rules/server-cache-react.md +4 -4
- package/templates/.claude/skills/nextjs-react-best-practices/rules/server-parallel-fetching.md +5 -5
- package/templates/.claude/skills/nextjs-react-best-practices/rules/server-serialization.md +6 -6
- package/templates/.claude/skills/plan/SKILL.md +594 -0
- package/templates/.claude/skills/prd/SKILL.md +496 -0
- package/templates/.claude/skills/ralph/AGENTS.md +393 -0
- package/templates/.claude/skills/ralph/SKILL.md +1035 -0
- package/templates/.claude/skills/tanstack-start-react-best-practices/AGENTS.md +100 -121
- package/templates/.claude/skills/tanstack-start-react-best-practices/SKILL.md +139 -157
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/async-defer-await.md +22 -22
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/async-dependencies.md +5 -5
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/async-loader.md +7 -7
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/async-parallel.md +4 -4
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/bundle-barrel-imports.md +18 -18
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/bundle-conditional.md +4 -4
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/bundle-defer-third-party.md +4 -4
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/bundle-lazy-routes.md +12 -12
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/bundle-preload.md +5 -5
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/client-event-listeners.md +9 -9
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/client-tanstack-query.md +12 -12
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-batch-dom-css.md +13 -13
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-cache-function-results.md +14 -14
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-cache-property-access.md +4 -4
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-cache-storage.md +10 -10
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-combine-iterations.md +4 -4
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-early-exit.md +7 -7
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-hoist-regexp.md +6 -6
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-index-maps.md +6 -6
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-length-check-first.md +14 -14
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-min-max-loop.md +16 -16
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-set-map-lookups.md +4 -4
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/js-tosorted-immutable.md +17 -17
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rendering-animate-svg-wrapper.md +11 -11
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rendering-conditional-render.md +8 -8
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rendering-content-visibility.md +4 -4
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rendering-hoist-jsx.md +6 -6
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rendering-svg-precision.md +5 -5
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rerender-defer-reads.md +4 -4
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rerender-dependencies.md +7 -7
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rerender-derived-state.md +5 -5
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rerender-functional-setstate.md +34 -34
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rerender-lazy-state-init.md +15 -15
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rerender-memo.md +5 -5
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/rerender-transitions.md +4 -4
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/server-cache-lru.md +12 -12
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/server-deferred-data.md +14 -14
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/server-parallel-fetching.md +9 -9
- package/templates/.claude/skills/tanstack-start-react-best-practices/rules/server-serialization.md +6 -6
- package/templates/.claude/commands/agent-creator.md +0 -370
- package/templates/.claude/commands/command-creator.md +0 -524
- package/templates/.claude/commands/execute.md +0 -469
- package/templates/.claude/commands/git.md +0 -98
- package/templates/.claude/commands/plan.md +0 -531
- package/templates/.claude/commands/prd.md +0 -629
|
@@ -3,35 +3,19 @@ description: 프로젝트 분석 후 ESLint flat config 설정
|
|
|
3
3
|
allowed-tools: Read, Write, Edit, Glob, Bash, mcp__sequential-thinking__sequentialthinking
|
|
4
4
|
---
|
|
5
5
|
|
|
6
|
-
|
|
7
|
-
<critical_instruction>
|
|
8
|
-
|
|
9
|
-
**CRITICAL: 사용자와의 모든 커뮤니케이션은 반드시 한국어로 작성하세요.**
|
|
10
|
-
|
|
11
|
-
- 내부 사고와 분석은 영어로 해도 됨
|
|
12
|
-
- 설명, 요약, 보고서, 피드백 등 사용자에게 전달하는 모든 내용은 반드시 한국어
|
|
13
|
-
- 사용자가 영어로 말하더라도 답변은 한국어로
|
|
14
|
-
- 진행 상황 업데이트와 상태 보고는 반드시 한국어
|
|
15
|
-
|
|
16
|
-
이 규칙은 절대적이며 예외가 없습니다.
|
|
17
|
-
|
|
18
|
-
</critical_instruction>
|
|
19
|
-
|
|
20
|
-
---
|
|
21
|
-
|
|
22
6
|
@../instructions/sequential-thinking-guide.md
|
|
23
7
|
|
|
24
8
|
# Lint Init Command
|
|
25
9
|
|
|
26
|
-
|
|
10
|
+
프로젝트 분석 → ESLint flat config 자동 생성.
|
|
27
11
|
|
|
28
12
|
<requirements>
|
|
29
13
|
|
|
30
|
-
|
|
|
31
|
-
|
|
32
|
-
| **Thinking** | Sequential 5-7
|
|
14
|
+
| 분류 | 필수 |
|
|
15
|
+
|------|------|
|
|
16
|
+
| **Thinking** | Sequential 5-7단계 (@sequential-thinking-guide.md) |
|
|
33
17
|
| **Config** | ESLint v9+ flat config (`eslint.config.js`) |
|
|
34
|
-
| **Detection** |
|
|
18
|
+
| **Detection** | 언어/프레임워크/런타임 자동 감지 |
|
|
35
19
|
|
|
36
20
|
</requirements>
|
|
37
21
|
|
|
@@ -40,28 +24,28 @@ Analyze project → automatically generate ESLint flat config.
|
|
|
40
24
|
<workflow>
|
|
41
25
|
|
|
42
26
|
<step number="1">
|
|
43
|
-
<action>
|
|
44
|
-
<detail
|
|
27
|
+
<action>Sequential Thinking 시작</action>
|
|
28
|
+
<detail>프로젝트 구조, 의존성, 기존 설정 분석 (5-7단계)</detail>
|
|
45
29
|
</step>
|
|
46
30
|
|
|
47
31
|
<step number="2">
|
|
48
|
-
<action
|
|
49
|
-
<tools>Read (package.json, tsconfig.json,
|
|
32
|
+
<action>핵심 파일 수집</action>
|
|
33
|
+
<tools>Read (package.json, tsconfig.json, 기존 ESLint 설정)</tools>
|
|
50
34
|
</step>
|
|
51
35
|
|
|
52
36
|
<step number="3">
|
|
53
|
-
<action
|
|
54
|
-
<detail
|
|
37
|
+
<action>프로젝트 특성 감지</action>
|
|
38
|
+
<detail>언어(TS/JS), 런타임(Node/Browser), 프레임워크(React/Vue/등)</detail>
|
|
55
39
|
</step>
|
|
56
40
|
|
|
57
41
|
<step number="4">
|
|
58
|
-
<action>
|
|
42
|
+
<action>ESLint 설정 생성</action>
|
|
59
43
|
<deliverable>eslint.config.js</deliverable>
|
|
60
44
|
</step>
|
|
61
45
|
|
|
62
46
|
<step number="5">
|
|
63
|
-
<action
|
|
64
|
-
<detail
|
|
47
|
+
<action>패키지 설치 안내</action>
|
|
48
|
+
<detail>필요 패키지 목록 + npm/yarn/pnpm 명령어</detail>
|
|
65
49
|
</step>
|
|
66
50
|
|
|
67
51
|
</workflow>
|
|
@@ -70,30 +54,30 @@ Analyze project → automatically generate ESLint flat config.
|
|
|
70
54
|
|
|
71
55
|
<detection>
|
|
72
56
|
|
|
73
|
-
##
|
|
57
|
+
## 프로젝트 특성 감지
|
|
74
58
|
|
|
75
|
-
###
|
|
59
|
+
### 언어
|
|
76
60
|
|
|
77
|
-
|
|
|
78
|
-
|
|
79
|
-
| `tsconfig.json`
|
|
61
|
+
| 조건 | 판단 |
|
|
62
|
+
|------|------|
|
|
63
|
+
| `tsconfig.json` 존재 | TypeScript |
|
|
80
64
|
| `devDependencies.typescript` | TypeScript |
|
|
81
|
-
| `src/**/*.{ts,tsx}`
|
|
82
|
-
|
|
|
65
|
+
| `src/**/*.{ts,tsx}` 파일 | TypeScript |
|
|
66
|
+
| 그 외 | JavaScript |
|
|
83
67
|
|
|
84
|
-
###
|
|
68
|
+
### 프레임워크
|
|
85
69
|
|
|
86
|
-
|
|
|
87
|
-
|
|
70
|
+
| 의존성 | 프레임워크 | 추가 플러그인 |
|
|
71
|
+
|--------|-----------|-------------|
|
|
88
72
|
| `react` | React | `eslint-plugin-react`, `eslint-plugin-react-hooks` |
|
|
89
|
-
| `next` | Next.js | React + Next.js
|
|
73
|
+
| `next` | Next.js | React + Next.js 규칙 |
|
|
90
74
|
| `vue` | Vue | `eslint-plugin-vue`, `vue-eslint-parser` |
|
|
91
|
-
| `express`, `hono`, `fastify` | Node.js
|
|
75
|
+
| `express`, `hono`, `fastify` | Node.js 서버 | - |
|
|
92
76
|
|
|
93
|
-
###
|
|
77
|
+
### 런타임
|
|
94
78
|
|
|
95
|
-
|
|
|
96
|
-
|
|
79
|
+
| 조건 | globals |
|
|
80
|
+
|------|---------|
|
|
97
81
|
| `express`, `fastify`, `hono` | `globals.node` |
|
|
98
82
|
| `react`, `vue`, `angular` | `globals.browser` |
|
|
99
83
|
| `next`, `nuxt` | `globals.node` + `globals.browser` |
|
|
@@ -104,9 +88,9 @@ Analyze project → automatically generate ESLint flat config.
|
|
|
104
88
|
|
|
105
89
|
<templates>
|
|
106
90
|
|
|
107
|
-
## ESLint Flat Config
|
|
91
|
+
## ESLint Flat Config 패턴
|
|
108
92
|
|
|
109
|
-
###
|
|
93
|
+
### 기본 구조 (TypeScript + Node.js)
|
|
110
94
|
|
|
111
95
|
```javascript
|
|
112
96
|
import eslint from '@eslint/js'
|
|
@@ -145,10 +129,10 @@ export default [
|
|
|
145
129
|
]
|
|
146
130
|
```
|
|
147
131
|
|
|
148
|
-
###
|
|
132
|
+
### React 추가 시
|
|
149
133
|
|
|
150
134
|
```javascript
|
|
151
|
-
//
|
|
135
|
+
// 위 기본 구조에 추가:
|
|
152
136
|
import reactPlugin from 'eslint-plugin-react'
|
|
153
137
|
import reactHooksPlugin from 'eslint-plugin-react-hooks'
|
|
154
138
|
|
|
@@ -165,7 +149,7 @@ export default [
|
|
|
165
149
|
react: { version: 'detect' },
|
|
166
150
|
},
|
|
167
151
|
rules: {
|
|
168
|
-
// ...
|
|
152
|
+
// ... 위 rules +
|
|
169
153
|
...reactPlugin.configs.recommended.rules,
|
|
170
154
|
...reactHooksPlugin.configs.recommended.rules,
|
|
171
155
|
'react/react-in-jsx-scope': 'off',
|
|
@@ -175,7 +159,7 @@ export default [
|
|
|
175
159
|
]
|
|
176
160
|
```
|
|
177
161
|
|
|
178
|
-
### JavaScript
|
|
162
|
+
### JavaScript Only
|
|
179
163
|
|
|
180
164
|
```javascript
|
|
181
165
|
import eslint from '@eslint/js'
|
|
@@ -208,19 +192,19 @@ export default [
|
|
|
208
192
|
|
|
209
193
|
<packages>
|
|
210
194
|
|
|
211
|
-
##
|
|
195
|
+
## 필요 패키지
|
|
212
196
|
|
|
213
|
-
|
|
|
214
|
-
|
|
215
|
-
|
|
|
216
|
-
| **TypeScript** |
|
|
217
|
-
| **React** |
|
|
218
|
-
| **Vue** |
|
|
197
|
+
| 조건 | 패키지 |
|
|
198
|
+
|------|--------|
|
|
199
|
+
| **기본** | `eslint @eslint/js globals` |
|
|
200
|
+
| **TypeScript** | 위 + `@typescript-eslint/parser @typescript-eslint/eslint-plugin` |
|
|
201
|
+
| **React** | 위 + `eslint-plugin-react eslint-plugin-react-hooks` |
|
|
202
|
+
| **Vue** | 위 + `eslint-plugin-vue vue-eslint-parser` |
|
|
219
203
|
|
|
220
|
-
###
|
|
204
|
+
### 설치 명령어
|
|
221
205
|
|
|
222
206
|
```bash
|
|
223
|
-
#
|
|
207
|
+
# 기본 (JavaScript)
|
|
224
208
|
npm install -D eslint @eslint/js globals
|
|
225
209
|
|
|
226
210
|
# TypeScript
|
|
@@ -236,18 +220,18 @@ npm install -D eslint @eslint/js globals @typescript-eslint/parser @typescript-e
|
|
|
236
220
|
|
|
237
221
|
<migration>
|
|
238
222
|
|
|
239
|
-
##
|
|
223
|
+
## 기존 설정 처리
|
|
240
224
|
|
|
241
|
-
|
|
|
242
|
-
|
|
243
|
-
| `.eslintrc.{json,js,yml}` |
|
|
244
|
-
| `package.json` `eslintConfig` |
|
|
225
|
+
| 파일 | 처리 |
|
|
226
|
+
|------|------|
|
|
227
|
+
| `.eslintrc.{json,js,yml}` | flat config 변환 → 백업 후 제거 |
|
|
228
|
+
| `package.json` `eslintConfig` | flat config 변환 → `package.json`에서 제거 |
|
|
245
229
|
|
|
246
|
-
|
|
247
|
-
1.
|
|
248
|
-
2.
|
|
249
|
-
3.
|
|
250
|
-
4.
|
|
230
|
+
**변환 방법:**
|
|
231
|
+
1. 기존 `rules`, `extends`, `plugins` 추출
|
|
232
|
+
2. flat config 형식으로 변환
|
|
233
|
+
3. 원본 백업 (`.eslintrc.backup`)
|
|
234
|
+
4. `eslint.config.js` 생성
|
|
251
235
|
|
|
252
236
|
</migration>
|
|
253
237
|
|
|
@@ -255,7 +239,7 @@ npm install -D eslint @eslint/js globals @typescript-eslint/parser @typescript-e
|
|
|
255
239
|
|
|
256
240
|
<scripts>
|
|
257
241
|
|
|
258
|
-
## package.json
|
|
242
|
+
## package.json 스크립트
|
|
259
243
|
|
|
260
244
|
```json
|
|
261
245
|
{
|
|
@@ -266,24 +250,77 @@ npm install -D eslint @eslint/js globals @typescript-eslint/parser @typescript-e
|
|
|
266
250
|
}
|
|
267
251
|
```
|
|
268
252
|
|
|
269
|
-
|
|
253
|
+
설정 완료 후 자동 추가 제안.
|
|
270
254
|
|
|
271
255
|
</scripts>
|
|
272
256
|
|
|
273
257
|
---
|
|
274
258
|
|
|
259
|
+
<parallel_agent_execution>
|
|
260
|
+
|
|
261
|
+
## 병렬 Agent 실행
|
|
262
|
+
|
|
263
|
+
### Recommended Agents
|
|
264
|
+
|
|
265
|
+
| Agent | Model | 역할 |
|
|
266
|
+
|-------|-------|------|
|
|
267
|
+
| **@implementation-executor** | sonnet | ESLint 설정 구현 |
|
|
268
|
+
| **@explore** | haiku | 프로젝트 구조 탐색 |
|
|
269
|
+
| **@analyst** | sonnet | 프로젝트 패턴 분석 |
|
|
270
|
+
|
|
271
|
+
### Parallel Execution Patterns
|
|
272
|
+
|
|
273
|
+
| 패턴 | 병렬 작업 | 효과 |
|
|
274
|
+
|------|-----------|------|
|
|
275
|
+
| **탐색 + 분석** | explore (haiku) + analyst (sonnet) | 프로젝트 이해 속도 향상 |
|
|
276
|
+
| **설정 + 문서** | implementation-executor + document-writer | 구현과 문서화 동시 진행 |
|
|
277
|
+
|
|
278
|
+
### Model Routing
|
|
279
|
+
|
|
280
|
+
| 복잡도 | 모델 | 조건 |
|
|
281
|
+
|--------|------|------|
|
|
282
|
+
| **LOW** | haiku / sonnet | 기본 JS/TS 프로젝트, 단일 프레임워크 |
|
|
283
|
+
| **MEDIUM** | sonnet | 커스텀 룰 설정, 여러 프레임워크 혼재 |
|
|
284
|
+
| **HIGH** | opus | 복잡한 모노레포, 레거시 마이그레이션 |
|
|
285
|
+
|
|
286
|
+
### Practical Examples
|
|
287
|
+
|
|
288
|
+
```typescript
|
|
289
|
+
// ✅ 탐색 + 분석 병렬
|
|
290
|
+
Task(subagent_type="explore", model="haiku",
|
|
291
|
+
prompt="프로젝트 파일 구조 파악 (package.json, tsconfig.json, src/)")
|
|
292
|
+
|
|
293
|
+
Task(subagent_type="analyst", model="sonnet",
|
|
294
|
+
prompt="코드 패턴 및 스타일 분석 (import 방식, 파일명 컨벤션)")
|
|
295
|
+
|
|
296
|
+
// ✅ 설정 + 문서 병렬
|
|
297
|
+
Task(subagent_type="implementation-executor", model="sonnet",
|
|
298
|
+
prompt="ESLint flat config 생성 (TypeScript + React)")
|
|
299
|
+
|
|
300
|
+
Task(subagent_type="document-writer", model="haiku",
|
|
301
|
+
prompt="린트 설정 가이드 작성 (패키지 설치 명령어, 사용법)")
|
|
302
|
+
|
|
303
|
+
// ✅ 복잡한 마이그레이션
|
|
304
|
+
Task(subagent_type="implementation-executor", model="opus",
|
|
305
|
+
prompt=".eslintrc.json → flat config 변환 (커스텀 룰 200+ 보존)")
|
|
306
|
+
```
|
|
307
|
+
|
|
308
|
+
</parallel_agent_execution>
|
|
309
|
+
|
|
310
|
+
---
|
|
311
|
+
|
|
275
312
|
<validation>
|
|
276
313
|
|
|
277
|
-
##
|
|
314
|
+
## 검증 단계
|
|
278
315
|
|
|
279
316
|
```bash
|
|
280
|
-
# 1.
|
|
317
|
+
# 1. 설정 문법 확인
|
|
281
318
|
npx eslint --print-config src/index.ts
|
|
282
319
|
|
|
283
|
-
# 2.
|
|
320
|
+
# 2. Lint 실행
|
|
284
321
|
npm run lint
|
|
285
322
|
|
|
286
|
-
# 3.
|
|
323
|
+
# 3. 자동 수정 테스트
|
|
287
324
|
npm run lint:fix
|
|
288
325
|
```
|
|
289
326
|
|