Files
gh-wasabeef-claude-code-coo…/commands/commit-message.md
2025-11-30 09:05:40 +08:00

355 lines
8.9 KiB
Markdown

## Commit Message
스테이징된 변경사항(git diff --staged)에서 적절한 커밋 메시지를 생성합니다. git 명령은 실행하지 않고, 메시지 생성과 클립보드 복사만 수행합니다.
### 사용법
```bash
/commit-message [옵션]
```
### 옵션
- `--format <형식>` : 메시지 형식 지정(conventional, gitmoji, angular)
- `--lang <언어>` : 메시지 언어 강제 지정(en, ko)
- `--breaking` : Breaking Change 감지 및 표시
### 기본 예제
```bash
# 스테이징된 변경사항을 기반으로 메시지 생성(언어 자동 판별)
# 메인 후보가 자동으로 클립보드에 복사됩니다
/commit-message
# 언어를 강제로 지정
/commit-message --lang ko
/commit-message --lang en
# Breaking Change 감지
/commit-message --breaking
```
### 전제 조건
**중요**: 이 명령어는 스테이징된 변경사항만 분석합니다. 먼저 `git add`로 변경사항을 스테이징해야 합니다.
```bash
# 스테이징되지 않은 경우 경고가 표시됩니다
$ /commit-message
스테이징된 변경사항이 없습니다. 먼저 git add 를 실행하세요.
```
### 자동 클립보드 기능
생성된 메인 후보는 `git commit -m "메시지"`의 완전한 형태로 자동으로 클립보드에 복사됩니다. 터미널에서 바로 붙여넣기해서 실행할 수 있습니다.
**구현 시 주의사항**:
- 커밋 명령을 `pbcopy`에 전달할 때는 메시지 출력과는 별도 프로세스로 실행할 것
- `echo` 대신 `printf`를 사용해서 끝의 개행을 피할 것
### 프로젝트 규약 자동 감지
**중요**: 프로젝트별 규약이 있으면 그것을 우선 적용합니다.
#### 1. CommitLint 설정 확인
다음 파일에서 설정을 자동 감지:
- `commitlint.config.js`
- `commitlint.config.mjs`
- `commitlint.config.cjs`
- `commitlint.config.ts`
- `.commitlintrc.js`
- `.commitlintrc.json`
- `.commitlintrc.yml`
- `.commitlintrc.yaml`
- `package.json``commitlint` 섹션
```bash
# 설정 파일 검색
find . -name "commitlint.config.*" -o -name ".commitlintrc.*" | head -1
```
#### 2. 커스텀 타입 감지
프로젝트별 타입 예시:
```javascript
// commitlint.config.mjs
export default {
extends: ["@commitlint/config-conventional"],
rules: {
"type-enum": [
2,
"always",
[
"feat",
"fix",
"docs",
"style",
"refactor",
"test",
"chore",
"wip", // 작업중
"hotfix", // 긴급 수정
"release", // 릴리스
"deps", // 의존성 업데이트
"config", // 설정 변경
],
],
},
};
```
#### 3. 언어 설정 감지
```javascript
// 프로젝트가 한국어 메시지를 사용하는 경우
export default {
rules: {
"subject-case": [0], // 한국어 대응을 위해 비활성화
"subject-max-length": [2, "always", 72], // 한국어는 글자수 제한 조정
},
};
```
#### 4. 기존 커밋 히스토리 분석
```bash
# 최근 커밋에서 사용 패턴 학습
git log --oneline -50 --pretty=format:"%s"
# 사용 타입 통계
git log --oneline -100 --pretty=format:"%s" | \
grep -oE '^[a-z]+(\([^)]+\))?' | \
sort | uniq -c | sort -nr
```
### 언어 자동 판별
다음 조건으로 자동으로 한국어/영어를 전환합니다:
1. **CommitLint 설정**에서 언어 설정 확인
2. **git log 분석**을 통한 자동 판별
3. **프로젝트 파일**의 언어 설정
4. **변경 파일 내**의 주석・문자열 분석
기본값은 영어. 한국어 프로젝트로 판별되면 한국어로 생성.
### 메시지 형식
#### Conventional Commits (기본값)
```text
<type>: <description>
```
**중요**: 항상 1 줄 커밋 메시지를 생성합니다. 여러 줄 메시지는 생성하지 않습니다.
**주의**: 프로젝트별 규약이 있으면 그것을 우선합니다.
### 표준 타입
**필수 타입**:
- `feat`: 새로운 기능(사용자가 볼 수 있는 기능 추가)
- `fix`: 버그 수정
**선택 타입**:
- `build`: 빌드 시스템이나 외부 의존성 변경
- `chore`: 기타 변경사항(릴리스에 영향 없음)
- `ci`: CI 설정 파일이나 스크립트 변경
- `docs`: 문서만 변경
- `style`: 코드 의미에 영향 없는 변경(공백, 포맷, 세미콜론 등)
- `refactor`: 버그 수정이나 기능 추가 없는 코드 변경
- `perf`: 성능 개선
- `test`: 테스트 추가나 수정
### 출력 예시(영어 프로젝트)
```bash
$ /commit-message
📝 커밋 메시지 제안
━━━━━━━━━━━━━━━━━━━━━━━━━
✨ 메인 후보:
feat: implement JWT-based authentication system
📋 대안:
1. feat: add user authentication with JWT tokens
2. fix: resolve token validation error in auth middleware
3. refactor: extract auth logic into separate module
`git commit -m "feat: implement JWT-based authentication system"` 클립보드에 복사됨
```
**구현 예시(수정판)**:
```bash
# 커밋 명령을 먼저 클립보드에 복사(개행 없이)
printf 'git commit -m "%s"' "$COMMIT_MESSAGE" | pbcopy
# 그 다음 메시지 표시
cat << EOF
📝 커밋 메시지 제안
━━━━━━━━━━━━━━━━━━━━━━━━━
✨ 메인 후보:
$COMMIT_MESSAGE
📋 대안:
1. ...
2. ...
3. ...
✅ \`git commit -m "$COMMIT_MESSAGE"\` 클립보드에 복사됨
EOF
```
### 출력 예시(한국어 프로젝트)
```bash
$ /commit-message
📝 커밋 메시지 제안
━━━━━━━━━━━━━━━━━━━━━━━━━
✨ 메인 후보:
feat: JWT 인증 시스템 구현
📋 대안:
1. feat: JWT 토큰으로 사용자 인증 추가
2. fix: 인증 미들웨어 토큰 검증 오류 해결
3. docs: 인증 로직을 별도 모듈로 분리
`git commit -m "feat: JWT 인증 시스템 구현"` 클립보드에 복사됨
```
### 동작 개요
1. **분석**: `git diff --staged`의 내용 분석
2. **생성**: 적절한 커밋 메시지 생성
3. **복사**: 메인 후보를 자동으로 클립보드에 복사
**주의**: 이 명령어는 git add 나 git commit 을 실행하지 않습니다. 커밋 메시지 생성과 클립보드 복사만 수행합니다.
### 스마트 기능
#### 1. 변경 내용 자동 분류(스테이징된 파일만)
- 새 파일 추가 → `feat`
- 에러 수정 패턴 → `fix`
- 테스트 파일만 → `test`
- 설정 파일 변경 → `chore`
- README/docs 업데이트 → `docs`
#### 2. 프로젝트 규약 자동 감지
- `.gitmessage` 파일
- `CONTRIBUTING.md` 내의 규약
- 과거 커밋 히스토리 패턴
#### 3. 언어 판별 상세(스테이징된 변경사항만)
```bash
# 판별 기준(우선순위)
1. git diff --staged 의 내용에서 언어 판별
2. 스테이징된 파일의 주석 분석
3. git log --oneline -20 의 언어 분석
4. 프로젝트의 메인 언어 설정
```
#### 4. 스테이징 분석 상세
분석에 사용하는 정보(읽기 전용):
- `git diff --staged --name-only` - 변경 파일 목록
- `git diff --staged` - 실제 변경 내용
- `git status --porcelain` - 파일 상태
### Breaking Change 감지 시
API 의 파괴적 변경이 있는 경우:
**영어**:
```bash
feat!: change user API response format
BREAKING CHANGE: user response now includes additional metadata
```
또는
```bash
feat(api)!: change authentication flow
```
**한국어**:
```bash
feat!: 사용자 API 응답 형식 변경
BREAKING CHANGE: 응답에 추가 메타데이터가 포함되도록 변경됨
```
또는
```bash
feat(api)!: 인증 플로우 변경
```
### 베스트 프랙티스
1. **프로젝트에 맞추기**: 기존 커밋 언어를 따름
2. **간결성**: 50 자 이내로 명확하게
3. **일관성**: 언어를 섞지 않음(영어면 영어로 통일)
4. **OSS**: 오픈소스라면 영어 권장
5. **1 줄 엄수**: 항상 1 줄 커밋 메시지로 작성(자세한 설명이 필요하면 PR 에서 보충)
### 자주 쓰는 패턴
**영어**:
```text
feat: add user registration endpoint
fix: resolve memory leak in cache manager
docs: update API documentation
```
**한국어**:
```text
feat: 사용자 등록 엔드포인트 추가
fix: 캐시 매니저 메모리 누수 해결
docs: API 문서 업데이트
```
### Claude 와의 연계
```bash
# 스테이징된 변경사항과 함께 사용
git add -p # 인터랙티브하게 스테이징
/commit-message
"최적의 커밋 메시지를 생성해줘"
# 특정 파일만 스테이징해서 분석
git add src/auth/*.js
/commit-message --lang en
"인증 관련 변경에 적합한 메시지를 생성해줘"
# Breaking Change 감지와 대응
git add -A
/commit-message --breaking
"파괴적 변경이 있으면 적절히 마킹해줘"
```
### 주의사항
- **전제조건**: 변경사항은 먼저 `git add`로 스테이징되어야 합니다
- **제한사항**: 스테이징되지 않은 변경사항은 분석 대상이 아닙니다
- **권장사항**: 프로젝트의 기존 커밋 규약을 먼저 확인하세요