Commit Skill
Use this skill when creating git commits. All commits must follow Angular Conventional Commits format because:
- •Git hooks enforce it (commit will be rejected otherwise)
- •Cocogitto parses commits to generate release changelogs
Commit Message Format
text
<type>(<scope>): <subject> [optional body] [optional footer]
Requirements:
- •Type: lowercase, from allowed list
- •Scope: mandatory, lowercase, describes what changed
- •Subject: lowercase start, imperative mood, no period
- •Breaking changes: add exclamation mark before colon (e.g. feat(api)!:)
Allowed Types
Angular standard types
| Type | Purpose | In Changelog |
|---|---|---|
feat | New feature | Yes |
fix | Bug fix | Yes |
docs | Documentation only | Yes |
refactor | Code change (no feat/fix) | Yes |
perf | Performance improvement | Yes |
build | Build system changes | Yes |
style | Formatting, whitespace | No |
test | Adding/fixing tests | No |
ci | CI/CD configuration | No |
Extended types (not in original Angular spec)
These are widely adopted extensions configured in cog.toml:
| Type | Purpose | In Changelog |
|---|---|---|
chore | Maintenance, deps, tooling | No |
revert | Revert previous commit | Yes |
Scope Naming Guidelines
Scopes should be consistent to group related changes in changelogs.
Component scopes
- •
lib- main library code (src/lib.rs) - •
loader- .env file loading logic - •
manager- environment variable management - •
patterns- pattern matching for env files - •
cli- command-line interface - •
error- error types and handling
NPM package scopes
- •
npm- npm package integration - •
napi- N-API bindings (dotenvage-napi) - •
nextjs- Next.js integration
Infrastructure scopes
- •
version- version bumps - •
deps- dependency updates - •
ci- CI/CD workflows (use withci:orchore:type) - •
config- configuration files - •
msrv- minimum supported Rust version
Documentation scopes
- •
readme- README.md changes - •
claude- CLAUDE.md, Claude Code skills
Testing scopes
- •
tests- general test changes
Examples
Good commit messages
text
feat(loader): add encrypted .env file support fix(patterns): handle nested variable references docs(readme): update installation instructions refactor(manager): extract validation logic test(loader): add tests for encrypted files chore(deps): update age-encryption to 0.10 ci(workflows): add npm publish workflow feat(npm): add Next.js preinit support feat(napi)!: change binding initialization API
Bad commit messages
text
feat: add feature # missing scope Fix(lib): Fix bug # uppercase type and subject feat(lib): Add feature. # uppercase subject, has period updated the readme # wrong format entirely feat(lib) add feature # missing colon feat(Lib): add feature # uppercase scope
Breaking Changes
For breaking changes, add an exclamation mark after the scope:
text
feat(loader)!: change default encryption algorithm BREAKING CHANGE: Now uses age encryption by default. Set DOTENVAGE_LEGACY=1 for backward compatibility.
This will appear prominently in the changelog.
Commit Process
- •Stage your changes:
git add <files> - •Commit with message:
git commit -m "type(scope): subject" - •Hooks automatically run:
- •pre-commit: fmt and clippy checks
- •commit-msg: validates conventional commit format
- •post-commit: verifies signature
If the commit is rejected, fix the issue and try again.
Multi-line Commits
For complex changes, use a body:
bash
git commit -m "feat(loader): add multi-file support Allows loading multiple .env files in sequence. Later files override earlier ones. Closes #42"
Checking Recent Commits
To see the commit style used in this repo:
bash
git log --oneline -20