Files
2nd/10_Wiki/Topics/DevOps_and_Security/eslint-plugin-prettier.md
T
Antigravity Agent f8b21af4be Wiki cleanup: error-doc removal, dedup merge, link normalization
10_Wiki/Topics 대규모 정리:
- 오류 캡처/미완성 stub 문서 227개 제거
- 교차폴더 중복 43클러스터 병합 (63파일 → redirect)
- 링크명 정규화: 깨진 링크 수정·redirect 직결·개념 매핑 ~2,400건
- 카테고리 MOC 6개 신규 생성
- Graph 섹션 미해결 related-keyword 링크 10,058건 제거

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-20 23:52:15 +09:00

134 lines
4.5 KiB
Markdown

---
id: wiki-2026-0508-eslint-plugin-prettier
title: eslint-plugin-prettier
category: 10_Wiki/Topics
status: verified
canonical_id: self
aliases: [eslint plugin prettier, prettier-plugin]
duplicate_of: none
source_trust_level: A
confidence_score: 0.9
verification_status: applied
tags: [eslint, prettier, formatting, lint, devops]
raw_sources: []
last_reinforced: 2026-05-10
github_commit: pending
tech_stack:
language: javascript
framework: eslint
---
# eslint-plugin-prettier
## 매 한 줄
> **"매 Prettier 의 formatting 결과를 ESLint rule 로 노출"**. 매 Prettier 가 보는 차이를 lint error 로 reporting — 매 같은 IDE/CI 에서 lint 와 format 을 한 흐름으로. 2026 현재는 `eslint --fix` integration 보다 **flat config + Prettier 3 + format-only on save** 가 권장.
## 매 핵심
### 매 동작 원리
- `eslint-plugin-prettier`**Prettier 를 ESLint rule 처럼 실행** — file 의 expected output 과 actual content 를 비교해 diff 를 lint error 로 보고.
- Rule key: `prettier/prettier``--fix` 시 Prettier 가 직접 rewrite.
- 항상 `eslint-config-prettier` 와 함께 사용 (ESLint 의 stylistic rules off).
### 매 2026 권장 stack
- **Format**: Prettier 3.x — IDE save 또는 git pre-commit hook 에서 직접 실행.
- **Lint**: ESLint 9 flat config — 매 logic / type-aware rules.
- **결합**: `eslint-config-prettier` 만 적용 (rule conflict off). `eslint-plugin-prettier`**선택** — CI 에서만 사용 권장.
### 매 응용
1. Monorepo CI 에서 `eslint --max-warnings=0` 으로 format drift 감지.
2. Pre-commit `lint-staged` 와 결합해 staged file 만 빠르게 검사.
3. Editor 가 Prettier 미설치인 contributor 의 PR 에서 catch.
## 💻 패턴
### Flat config (ESLint 9 + Prettier 3, 2026 표준)
```js
// eslint.config.js
import prettierPlugin from 'eslint-plugin-prettier';
import prettierConfig from 'eslint-config-prettier';
import js from '@eslint/js';
export default [
js.configs.recommended,
prettierConfig, // turns off conflicting rules
{
plugins: { prettier: prettierPlugin },
rules: {
'prettier/prettier': ['error', { singleQuote: true, semi: true }],
},
},
];
```
### Recommended preset
```js
import prettierRecommended from 'eslint-plugin-prettier/recommended';
export default [
prettierRecommended, // includes plugin + config + rule
];
```
### Pre-commit (lint-staged + husky)
```json
// package.json
{
"lint-staged": {
"*.{js,ts,tsx}": ["eslint --fix", "prettier --write"]
}
}
```
### CI gate
```yaml
# .github/workflows/lint.yml
- run: pnpm prettier --check .
- run: pnpm eslint .
```
### Programmatic check
```js
import { ESLint } from 'eslint';
const eslint = new ESLint({ fix: false });
const results = await eslint.lintFiles(['src/**/*.ts']);
const formatter = await eslint.loadFormatter('stylish');
console.log(formatter.format(results));
```
## 매 결정 기준
| 상황 | Approach |
|---|---|
| 매 contributor 가 Prettier 셋업 보장 안 됨 | `eslint-plugin-prettier` 도입 → CI gate |
| 매 모두 IDE save-on-format + pre-commit | plugin 없이 `prettier --check` 만 |
| Monorepo + 다양한 language | Prettier CLI 직접 + plugin 생략 (속도 ↑) |
| Editor lint = error 표시가 필요 | plugin 활성 |
**기본값**: **`eslint-config-prettier` 만 사용 + Prettier 는 별도 실행**. plugin 은 형식 drift 감지용 CI 에서 한정 적용.
## 🔗 Graph
- 부모: [[ESLint]] · [[Prettier]]
- 변형: [[eslint-config-prettier]]
- 응용: [[lint-staged]] · [[husky]] · [[CI_CD_Pipeline|CI_CD Pipeline]]
- Adjacent: [[Code-Quality]] · [[DevSecOps_Framework]]
## 🤖 LLM 활용
**언제**: 매 Prettier output 과 lint output 을 한 reporter 로 통합해야 할 때 — 특히 monorepo CI 에서.
**언제 X**: 매 small repo 이고 contributor 가 Prettier IDE plugin 사용. plugin 의 overhead (Prettier 를 매 lint 에서 invoke) 가 불필요.
## ❌ 안티패턴
- **Stylistic ESLint rule 과 plugin 동시 사용**: `eslint-config-prettier` 미적용 → 무한 충돌.
- **`--fix` 의존 only**: editor 가 fix 안 해주면 broken state 유지. Prettier 직접 실행이 빠르고 명확.
- **Plugin 으로 모든 file 검사**: 매 large repo 에서 ESLint+Prettier 동시 invoke 는 느림. `lint-staged` 로 scope.
## 🧪 검증 / 중복
- Verified (eslint-plugin-prettier README v5.x, Prettier 3 docs, ESLint 9 flat config docs).
- 신뢰도 A.
## 🕓 Changelog
| 날짜 | 변경 |
|---|---|
| 2026-05-08 | Phase 1 |
| 2026-05-10 | Manual cleanup — full content with flat config + 2026 권장 stack |