# git-biance
[中文文档](./README-zh.md)
biance(鞭策,biān cè,spur)is a small rust program that shows and visualizes code contributions in a git repository.
<div align="center">⚠️*Do not* use it to harass your teammates⚠️</div>
|  |  |
## Installation
```shell
cargo install git-biance
```
## Usage
```
Usage: git-biance [OPTIONS] [AUTHOR]
Arguments:
[AUTHOR] Specify certain author
Options:
-s, --stat Show total insertions and deletions
-c, --commits Show total commits
-p, --plot Visualize contributions with a graph
-f, --file <FILE>... Show insertions and deletions on single file
-h, --help Print help
-V, --version Print version
```
## Integrations
### GitLab Integration
The following workflow can be used to achieve automatic spurring effect in merge requests, requires environment variable named
CI_AUTOCOMMENTER_API_KEY containing a personal access code:
```yaml
biance:
stage: deploy
variables:
GIT_DEPTH: 0
script:
- BIANCE_COMMIT=$(git biance -c | sed ':a; N; $!ba; s/ /%20/g; s/\n/%0A/g')
- BIANCE_STATS=$(find src/main/ -type f | xargs git biance -f | sed ':a; N; $!ba; s/ /%20/g; s/\n/%0A/g')
- BIANCE_MSG=$(echo "Beep%20boop%0A%0A$BIANCE_COMMIT%0A%0A$BIANCE_STATS")
- 'curl --request POST --header "PRIVATE-TOKEN: $CI_AUTOCOMMENTER_API_KEY" "https://gitlab.doc.ic.ac.uk/api/v4/projects/$CI_PROJECT_ID/merge_requests/$CI_MERGE_REQUEST_IID/notes?body=$BIANCE_MSG"'
rules:
- if: $CI_PIPELINE_SOURCE == 'merge_request_event'
```

## FAQ
> I see some names are repeated, what is going on?
`git-biance` use email to identify users, but shows them by user name. It's likely that some contributors are using git with http, which generates a new email each time they push a commit. One can get the correct output by using [git mailmap](https://git-scm.com/docs/gitmailmap). To get a list of authors, run:
```shell