Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Gazler/changex
Automated changelog generation from git logs
https://github.com/Gazler/changex
Last synced: 2 months ago
JSON representation
Automated changelog generation from git logs
- Host: GitHub
- URL: https://github.com/Gazler/changex
- Owner: Gazler
- License: mit
- Created: 2014-08-18T21:19:06.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2022-03-16T12:17:27.000Z (almost 3 years ago)
- Last Synced: 2024-10-27T11:49:27.958Z (3 months ago)
- Language: Elixir
- Homepage: https://hex.pm/packages/changex
- Size: 78.1 KB
- Stars: 47
- Watchers: 5
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
- freaking_awesome_elixir - Elixir - Automated changelog generation from GIT logs. (Release Management)
- fucking-awesome-elixir - changex - Automated changelog generation from GIT logs. (Release Management)
- awesome-elixir - changex - Automated changelog generation from GIT logs. (Release Management)
README
# Changex
Mix tasks for parsing git log.
[![Build Status](https://travis-ci.org/Gazler/changex.svg?branch=fix%2Ftravis-ci)](https://travis-ci.org/Gazler/changex)
## Usage
Add Changex as a dependency in your `mix.exs` file.
```elixir
def deps do
[ { :changex } ]
end
```After you are done, run `mix deps.get` to fetch and compile Changex. You will now have access to the changex mix tasks in your project.
## Mix Tasks
### Changex.Diff
If you run `mix changex.diff` then a diff based on your git commit history will be generated. This can be called in several way:
To generate a changelog from the most recent tag (the root commit will be used if there are no tags) to the git HEAD run:
```elixir
mix changex.diff
```To generate a changelog from a git reference (commit, tag, etc.) to HEAD run:
```elixir
mix changex.diff a87a32f
mix changex.diff v0.1.0
mix changex.diff HEAD~5
```To generate a changelog between two commit references:
```elixir
mix changex.diff a87a32f v0.1.0
mix changex.diff v0.1.0 v0.1.1
mix changex.diff HEAD~5 HEAD~2
```The following options are also available:
Option Description
---------- ------
--dir Run changex.diff using a directory other than the current one
--format Change the output format. One of terminal, markdown or elixir
--github Include link to commit on GitHub when outputting the hash of
the commit. Should be in the format `/user/repo`### Changex.Update
If you run `mix changex.update` then the changelog file in the repository will be updated. This will use the most recent tag if available, if not then it will use the root node of the repository.
To write to the file CHANGELOG.md run:
```elixir
mix changex.update
```The following options are also available:
Option Description
---------- ------
--file Change the file for the output to be written to. Defaults to CHANGELOG.md
--format Change the output format. One of markdown or elixir, defaults to markdown
--github Include link to commit on GitHub when outputting the hash of
the commit. Should be in the format `/user/repo`## Contributing
Changex uses [GitCop](http://gitcop.com) to automatically check for formatting of the commit messages. Any pull request will automatically be checked against the rules specified in this repository.
Please read [CONTRIBUTING.md](https://github.com/Gazler/changex/blob/master/CONTRIBUTING.md).
## License
Please read [LICENSE.txt](https://github.com/Gazler/changex/blob/master/LICENSE.txt).