Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/linusu/emoji-commit
https://github.com/linusu/emoji-commit
emoji git github hacktoberfest
Last synced: 5 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/linusu/emoji-commit
- Owner: LinusU
- Created: 2016-10-19T22:19:00.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2022-12-28T16:16:01.000Z (about 2 years ago)
- Last Synced: 2025-01-01T09:05:08.976Z (8 days ago)
- Topics: emoji, git, github, hacktoberfest
- Language: Rust
- Homepage:
- Size: 65.4 KB
- Stars: 44
- Watchers: 4
- Forks: 6
- Open Issues: 6
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# Emoji Commit
Make your git logs beautiful and readable with the help of emojis π
The idea with the emoji committer is to tag each of your commit with an emoji that corresponds to a bump in [semver][1]. This information can the be used to automatically publish new versions, generate a change log and make the git log give you a quicker glance over whats been happening.
![The emoji committer in action](https://cloud.githubusercontent.com/assets/189580/20077151/7dcf0b3e-a53b-11e6-9043-55f6743f898a.gif)
## Table of contents
- [Installation](#installation)
- [Usage](#usage)
- [The emojis](#the-emojis)## Installation
```sh
cargo install emoji-commit
```## Usage
The emoji committer can be used in two ways. Either invoked directly, or by configuring git to invoke it.
### Invoke directly
Simply call `emoji-commit` as you would any other command:
```sh
emoji-commit
```### Configure Git
You can set the `core.editor` configuration in git the the emoji committer to always use it when committing.
```sh
git config --global core.editor 'emoji-commit'
```## The emojis
The following emojis where chosenΒ for the emoji committer:
|Emoji | Name | Semver | Meaning |
|------|--------------|--------|-----------------------|
|π₯ | Collision | major | Breaking change |
|π | Party popper | minor | New feature |
|π | Bug | patch | Bugfix |
|π₯ | Fire | patch | Cleanup / Performance |
|πΉ | Rose | | Meta |### π₯ Breaking change
Use this commit type if your change is in any way breaking to the intended consumer. Keep in mind that "breaking" has different meaning in different contexts, e.g. adding a field to a struct is a breaking change in Rust, but is generally considered a backwards compatible change in Node.js.
### π New feature
Use this commit type if you have added a new feature in a fully backwards compatible way. Keep in mind that adding documentation for a previous undocumented feature can qualify under this type, since undocumented APIs aren't a part of the public API.
### π Bugfix
Use this commit type if you have fixed a bug. The rationale for having two "patch" types is to be able to quickly get a list of all the bugs that have been fixed.
### π₯ Cleanup / Performance
Use this commit if your change will impact the consumer in some way, be it a documentation change, optimizing an if-statement or simply removing some unnecessary semicolons.
### πΉ Meta
Use this commit when you change _won't have any impact_ on the consumer. This _does not_ include changes to the code that still should have it "behave the same" since those changes should result in a new build being published.
A common use case for this emoji is editing your `.travis.yml` file to change something with the build, or adding some more tests.
## The version bump
Many publishing tools, e.g. npm, have a step where you'll bump the version in some file, committing that, and then publish everything to a registry. For this specific use case we have introduced a special emoji.
### π’ Release
Use this commit type when cutting a new release. Commits with this emoji should preferably be made automatically by some sort of continues delivery system, which also publishes the package.
I hope to release some tools for making this easier in the near future. In the mean time, you can use this handy shortcut for `npm`:
```sh
npm version -m 'π’ %s'
```## Troubleshooting
### `git log` doesn't show emojis on macOS
macOS ships with a very outdated `less` that doesn't support showing emojis out-of-the box. Read more [in this blogpost][2] for a proper solution, or run the following command to make it workβ’.
```sh
git config --global core.pager 'less -r'
```[1]: http://semver.org
[2]: http://www.recursion.org/2016/6/19/displaying-emoji-in-git-log