docs(rules): simplify conventional commits rule to avoid diff issues

This commit is contained in:
Nicola Zangrandi 2025-02-21 08:02:06 +01:00
parent 6ccbec281a
commit bf8f53621e
Signed by: wasp
GPG key ID: 43C1470D890F23ED

View file

@ -3,68 +3,55 @@ description: Automatically commit changes made by CursorAI using conventional co
globs: **/*
---
<rule>
filters:
- type: event
pattern: "build_success"
- type: file_change
pattern: "*"
Before committing changes:
actions:
- type: execute
command: |
# Extract the change type and scope from the changes
CHANGE_TYPE=""
case "$CHANGE_DESCRIPTION" in
*"add"*|*"create"*|*"implement"*) CHANGE_TYPE="feat";;
*"fix"*|*"correct"*|*"resolve"*) CHANGE_TYPE="fix";;
*"refactor"*|*"restructure"*) CHANGE_TYPE="refactor";;
*"test"*) CHANGE_TYPE="test";;
*"doc"*|*"comment"*) CHANGE_TYPE="docs";;
*"style"*|*"format"*) CHANGE_TYPE="style";;
*"perf"*|*"optimize"*) CHANGE_TYPE="perf";;
*) CHANGE_TYPE="chore";;
esac
1. Always review changed files:
```bash
git status # Check which files were modified
```
# Extract scope from file path
SCOPE=$(dirname "$FILE" | tr '/' '-')
2. Follow conventional commits format:
```
<type>(<scope>): <description>
```
# Commit the changes
git add "$FILE"
git commit -m "$CHANGE_TYPE($SCOPE): $CHANGE_DESCRIPTION"
3. Types:
- feat: A new feature
- fix: A bug fix
- docs: Documentation only changes
- style: Changes that do not affect the meaning of the code
- refactor: A code change that neither fixes a bug nor adds a feature
- perf: A code change that improves performance
- test: Adding missing tests or correcting existing tests
- chore: Changes to the build process or auxiliary tools
- type: suggest
message: |
Changes should be committed using conventional commits format:
4. Guidelines:
- Scope should be derived from the file path or affected component
- special cases:
- `notes`, `feeds` and `links` indicate the three subapplication scopes
- `rules` indicates changes to cursor rules
- `frontend` and `go` indicates broad changes to the typescript or go code respectively
- `infra` is for changes to the repo "infrastructure": scripts, ci configs etc
- Description should be clear, concise, and in imperative mood
- If changes span multiple scopes, use comma separation or omit scope
- If changes are breaking, add ! after type/scope: feat!: or feat(scope)!:
Format: <type>(<scope>): <description>
Types:
- feat: A new feature
- fix: A bug fix
- docs: Documentation only changes
- style: Changes that do not affect the meaning of the code
- refactor: A code change that neither fixes a bug nor adds a feature
- perf: A code change that improves performance
- test: Adding missing tests or correcting existing tests
- chore: Changes to the build process or auxiliary tools
The scope should be derived from the file path or affected component.
The description should be clear and concise, written in imperative mood.
metadata:
priority: high
version: 1.0
</rule>
examples:
- input: |
# After adding a new function
git status
CHANGE_DESCRIPTION="add user authentication function"
FILE="src/auth/login.ts"
output: "feat(src-auth): add user authentication function"
- input: |
# After fixing a bug
git status
CHANGE_DESCRIPTION="fix incorrect date parsing"
FILE="lib/utils/date.js"
output: "fix(lib-utils): fix incorrect date parsing"
metadata:
priority: high
version: 1.0
</rule>