Skip to main content
ClaudeWave
Slash Command388 estrellas del repoactualizado 25d ago

commit-smart

The commit-smart slash command guides users through creating well-formatted commits with integrated quality checks. It validates staged changes for syntax errors and secrets, prompts users to specify commit type and scope following Conventional Commits format, verifies message formatting, and executes the commit while offering post-commit options like pushing. Use this command to ensure code changes meet quality standards before entering the repository history.

Instalar en Claude Code
Copiar
mkdir -p ~/.claude/commands && curl -fsSL https://raw.githubusercontent.com/alirezarezvani/ClaudeForge/HEAD/.claude/commands/github/commit-smart.md -o ~/.claude/commands/commit-smart.md
Después abre una sesión nueva de Claude Code; el slash command carga automáticamente.

commit-smart.md

# Smart Commit with Quality Gates

You are helping the user create a well-formatted commit with pre-commit validation.

## Workflow

1. **Check Staged Changes**
   ```bash
   git status
   git diff --cached --stat
   ```
   - Show what files are staged
   - If nothing staged, ask user what to add

2. **Pre-Commit Quality Checks**

   Run local quality gates before committing:

   **Python syntax** (if .py files changed):
   ```bash
   flake8 skill/ --count --select=E9,F63,F7,F82 --show-source
   ```

   **Bash syntax** (if .sh files changed):
   ```bash
   bash -n install.sh
   bash -n hooks/pre-commit.sh
   ```

   **Secret scan**:
   ```bash
   git diff --cached | grep -iE "(api_key|api_secret|password|token|AWS_ACCESS)" || echo "No secrets detected"
   ```

3. **Generate Conventional Commit Message**

   Ask user about the change:
   - Type: feat, fix, docs, style, refactor, perf, test, build, ci, chore
   - Scope: installer, skill, command, agent, docs, ci, workflows
   - Description: what changed (imperative mood)
   - Why: reason for change (optional body)
   - Issue: related issue number

   **Format:**
   ```
   <type>(<scope>): <description>

   [optional body explaining why]

   [optional footer: Closes #123]
   ```

4. **Validate Message Format**
   - Check format matches Conventional Commits
   - Ensure subject is imperative mood ("add" not "added")
   - Verify no period at end
   - Check length < 50 characters for subject

5. **Create Commit**
   ```bash
   git commit -m "<generated message>"
   ```

6. **Post-Commit Actions**
   - Show commit hash
   - Show commit in log
   - Ask if user wants to push

## Examples

**Feature commit:**
```bash
git commit -m "feat(installer): add Windows PowerShell support

Adds install.ps1 script with equivalent functionality to
install.sh for Windows users.

Closes #42"
```

**Fix commit:**
```bash
git commit -m "fix(skill): correct Python syntax validation

Fix flake8 configuration to properly detect syntax errors.
Previous config was too permissive.

Fixes #156"
```

**Docs commit:**
```bash
git commit -m "docs: update GitHub workflows documentation

Add troubleshooting section and configuration examples."
```

## Quality Gates

Before committing, ensure:
- ✅ No syntax errors
- ✅ No hardcoded secrets
- ✅ Conventional Commits format
- ✅ Related issue linked (for feat/fix)
- ✅ Files staged are relevant to commit message

## Interactive Flow

1. Show staged changes
2. Run quality checks
3. Ask for commit details (type, scope, description)
4. Generate commit message
5. Show preview
6. Confirm with user
7. Execute commit
8. Display result

Use clear prompts and provide the exact commands for the user to run.