Metadata-Version: 2.4
Name: kacs
Version: 0.4.0
Summary: Keep a changelog, stupid! Generate changelogs from git commits using LLM.
Project-URL: Homepage, https://github.com/atasoglu/kacs
Project-URL: Repository, https://github.com/atasoglu/kacs.git
Author-email: Ahmet Atasoglu <ahmetatasoglu98@gmail.com>
License: MIT
License-File: LICENSE
Requires-Python: >=3.9
Requires-Dist: ask2api>=1.1.3
Requires-Dist: jinja2>=3.1.0
Provides-Extra: dev
Requires-Dist: pre-commit; extra == 'dev'
Description-Content-Type: text/markdown

# kacs

[![CI](https://github.com/atasoglu/kacs/actions/workflows/pre-commit.yml/badge.svg)](https://github.com/atasoglu/kacs/actions/workflows/pre-commit.yml)
[![PyPI version](https://img.shields.io/pypi/v/kacs)](https://pypi.org/project/kacs/)
[![Python 3.9+](https://img.shields.io/badge/python-3.9+-blue.svg)](https://www.python.org/downloads/)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

**Keep a changelog, stupid!**

A minimal Python CLI tool that generates changelogs from git commit messages using LLM analysis. Perfect for CI/CD pipelines and automated release workflows.

## Features

- 🚀 **Minimal dependencies** - Only requires `ask2api` + Python stdlib
- 📝 **Multiple formats** - Keep a Changelog, GitHub, GitLab, or custom templates
- 🤖 **LLM-powered analysis** - Automatically categorizes commits into Added, Changed, Fixed, etc.
- ⚡ **CI/CD ready** - Fast execution suitable for automated workflows
- 🎯 **Git tag based** - Extract commits between any two git tags

## Installation

```bash
pip install kacs
```

## Setup

Set your API key as an environment variable:

```bash
export ASK2API_API_KEY="your-api-key"
# or
export OPENAI_API_KEY="your-openai-key"
```

## Usage

### Basic Usage

```bash
# Generate changelog between two tags
kacs --from-tag v1.0.0 --to-tag v1.1.0

# With custom date
kacs --from-tag v1.0.0 --to-tag v1.1.0 --date 2017-07-17

# Save to file
kacs --from-tag v1.0.0 --to-tag v1.1.0 --output CHANGELOG.md
```

### Templates

```bash
# Use GitHub format
kacs --from-tag v1.0.0 --to-tag v1.1.0 --template github

# Use GitLab format
kacs --from-tag v1.0.0 --to-tag v1.1.0 --template gitlab

# Use custom template
kacs --from-tag v1.0.0 --to-tag v1.1.0 --custom-template ./my-template.j2
```

### Commit Links

```bash
# Include commit links (auto-detects repository URL)
kacs --from-tag v1.0.0 --to-tag v1.1.0 --include-links

# With explicit repository URL
kacs --from-tag v1.0.0 --to-tag v1.1.0 --include-links --repo-url https://github.com/user/repo
```

### Example Output

**Keep a Changelog format (default):**
```markdown
## [1.1.0] - 2024-01-15

### Added
- New user authentication system
- Support for multiple database backends

### Changed
- Improved error handling in API endpoints
- Updated documentation structure

### Fixed
- Fixed memory leak in background tasks
- Resolved issue with concurrent requests
```

**GitHub format:**
```markdown
## What's Changed in 1.1.0

### ✨ New Features
* New user authentication system
* Support for multiple database backends

### 🐛 Bug Fixes
* Fixed memory leak in background tasks

**Full Changelog**: https://github.com/user/repo/compare/v1.0.0...v1.1.0
```

### CI/CD Integration

```yaml
# GitHub Actions example
- name: Generate Changelog
  run: |
    pip install kacs
    kacs --from-tag ${{ github.event.release.tag_name }} --to-tag HEAD --output CHANGELOG.md
  env:
    ASK2API_API_KEY: ${{ secrets.ASK2API_API_KEY }}
```

## Documentation

- [Template System](docs/TEMPLATES.md) - Learn about built-in templates and creating custom ones

## License

MIT License - see [LICENSE](LICENSE) file for details.

## Contributing

1. Fork the repository
2. Create a feature branch
3. Make your changes
4. Run tests and linting
5. Submit a pull request

## Links

- [PyPI Package](https://pypi.org/project/kacs/)
- [GitHub Repository](https://github.com/atasoglu/kacs)
- [Keep a Changelog](https://keepachangelog.com/)
