Skip to main content

Interactive CLI tool for creating standardized commit messages following conventional commits

Project description

Conventional Commits Generator

Description

Interactive CLI tool for creating standardized commit messages following the conventional commits format. Includes support for commit body, emojis, and advanced commit management features.

Installation

Using pipx (recommended)

pipx install conventional-commits-generator

Using pip

pip install conventional-commits-generator

Development installation

# Clone the GitHub repository
git clone https://github.com/EgydioBNeto/conventional-commits-generator.git

# Navigate into the project directory
cd conventional-commits-generator

# Grant execute permission to the virtual environment setup script
chmod +x scripts/setup_venv.sh

# Run the script to create and set up the virtual environment
./scripts/setup_venv.sh

# Activate the virtual environment
source .venv/bin/activate

Usage

Basic commands

# Create interactive commit
ccg

# Generate commit message without committing
ccg --commit

# Push only without creating commit
ccg --push

# Edit existing commit
ccg --edit

# Delete existing commit
ccg --delete

# Create and push tag
ccg --tag

# Reset local and pull from remote
ccg --reset

# Show version
ccg --version

Interactive usage example

$ ccg

 ________      ________      ________
|\   ____\    |\   ____\    |\   ____\
\ \  \___|    \ \  \___|    \ \  \___|
 \ \  \        \ \  \        \ \  \  ___
  \ \  \____    \ \  \____    \ \  \|\  \
   \ \_______\   \ \_______\   \ \_______\
    \|_______|    \|_______|    \|_______|

 Conventional Commits Generator

┌──────────────────────┐
│ Commit Types         │
└──────────────────────┘

1. ✨ feat     - A new feature
2. 🐛 fix      - A bug fix
3. 🔧 chore    - Maintenance tasks
4. ♻️ refactor - Code refactoring
5. 💄 style    - Style changes
6. 📚 docs     - Documentation
...

Choose the commit type: 1

┌──────────────────────┐
│ Scope                │
└──────────────────────┘
Enter the scope (optional): auth

┌──────────────────────┐
│ Breaking Change      │
└──────────────────────┘
Is this a BREAKING CHANGE? (y/n): n

┌──────────────────────┐
│ Emoji                │
└──────────────────────┘
Include emoji in commit message? (y/n): n

┌──────────────────────┐
│ Commit Message       │
└──────────────────────┘
Enter the commit message: implement OAuth login

┌──────────────────────┐
│ Commit Body          │
└──────────────────────┘
Commit body (optional): Added Google OAuth 2.0 support
Integration with existing user system

┌──────────────────────┐
│ Review               │
└──────────────────────┘

┌─────────────────────────────────────────────────────────┐
│                                                         │
│  feat(auth): implement OAuth login                      │
│                                                         │
│  Added Google OAuth 2.0 support                         │
│  Integration with existing user system                  │
│                                                         │
└─────────────────────────────────────────────────────────┘

Confirm this commit message? (y/n): y
✓ New commit successfully created!

Do you want to push these changes? (y/n): y
✓ Changes pushed successfully!

Commit Types

Type Emoji Description
feat A new feature
fix 🐛 A bug fix
chore 🔧 Maintenance tasks
refactor ♻️ Code refactoring
style 💄 Style/formatting changes
docs 📚 Documentation changes
test 🧪 Adding or modifying tests
build 📦 Build system changes
revert Reverts a previous commit
ci 👷 CI/CD changes
perf Performance improvements

Requirements

  • Python 3.8+
  • Git

Contributing

See CONTRIBUTING.md for details on how to contribute.

Code of Conduct

Please read our Code of Conduct for details on our community standards.

Security

To report security vulnerabilities, see SECURITY.md.

License

This project is licensed under the MIT License.

Author

EgydioBNeto

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

conventional-commits-generator-2.1.1.tar.gz (23.2 kB view details)

Uploaded Source

File details

Details for the file conventional-commits-generator-2.1.1.tar.gz.

File metadata

File hashes

Hashes for conventional-commits-generator-2.1.1.tar.gz
Algorithm Hash digest
SHA256 7ff4697e9a95a6cefcdd6fcab878f3408b043aa1cc12068c1ee9ee3cfab52336
MD5 4665467e71949616e76b99c09751cc59
BLAKE2b-256 846c8fee0ac113e471ee1eaf7ecbf061eb8724cfe436d8d0c93ddfd5d14f3bd8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page