Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/passsy/git-revision

Git extension to generate a meaningful, human readable revision for each commit in a git repository.
https://github.com/passsy/git-revision

dart git

Last synced: 13 days ago
JSON representation

Git extension to generate a meaningful, human readable revision for each commit in a git repository.

Awesome Lists containing this project

README

        

# git revision

Git extension to generate a meaningful, human-readable revision for each commit in a git repository.

## Installing

```bash
dart pub global activate git_revision
```

or download the archive from [releases](https://github.com/passsy/git-revision/releases) and install it manually

## Usage

```
> git revision
73_feature/user_profile+0_996321c-dirty
```

```
> git revision --full
versionCode: 73
versionName: 73_feature/user_profile+0_996321c-dirty
baseBranch: master
currentBranch: feature/user_profile
sha1: 996321c8a38c0cd0c9ebeb4e9f82615796005202
sha1Short: 996321c
baseBranchCommitCount first-only: 50
baseBranchCommitCount: 50
baseBranchTimeComponent: 23
featureBranchCommitCount: 0
featureBranchTimeComponent: 0
featureOrigin: 996321c8a38c0cd0c9ebeb4e9f82615796005202
yearFactor: 1000
localChanges: 4 +35 -12
```

### Possible revisions

#### Examples

```
1_a541234

1235+1_1234567

432+43_a342123-dirty

1234_someBranch+43_3423123

1234_someBranch+43_3423123-dirty

1234_feature/topic_branch-something1234_cool+43_3423123-dirty

1234_topic_branch_name+0_3423123-dirty
```

#### Schema

Regex matching any possible revision (above)

```
(\d+)(?>_([\w_\-\/]+))?(?>\+(\d+))?_([0-9a-f]{7})(-dirty)?
```

### Help

```
> git revision -h
git revision creates a useful revision for your project beyond 'git describe'
-h, --help Print this usage information.
-v, --version Shows the version information of git revision
-C, --context Run as if git was started in instead of the current working directory
-b, --baseBranch The base branch where most of the development happens, (defaults to master, or main). Often what is set as baseBranch in github. Only on the baseBranch the revision can become only digits.
-y, --yearFactor revision increment count per year
(defaults to "1000")
-d, --stopDebounce time between two commits which are further apart than this stopDebounce (in hours) will not be included into the timeComponent. A project on hold for a few months will therefore not increase the revision drastically when development starts again.
(defaults to "48")
-n, --name a human readable name and identifier of a revision ('73_+21_996321c'). Can be anything which gives the revision more meaning i.e. the number of the PullRequest when building on CI. Allowed characters: [a-zA-Z0-9_-/] any letter, digits, underscore, dash and slash. Invalid characters will be removed.
--full shows full information about the current revision and extracted information
```

# License

```
Copyright 2018 Pascal Welsch

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
```