Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/simonrenoult/git-log-to-json
Print git log in json
https://github.com/simonrenoult/git-log-to-json
git json nodejs npm
Last synced: 2 months ago
JSON representation
Print git log in json
- Host: GitHub
- URL: https://github.com/simonrenoult/git-log-to-json
- Owner: simonrenoult
- License: mit
- Created: 2016-04-21T16:35:23.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2023-02-27T17:45:36.000Z (almost 2 years ago)
- Last Synced: 2024-11-01T17:02:52.305Z (3 months ago)
- Topics: git, json, nodejs, npm
- Language: JavaScript
- Size: 190 KB
- Stars: 9
- Watchers: 2
- Forks: 3
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# git-log-to-json
[![Style Status][style-image]][style-url]
[![Build Status][travis-image]][travis-url]
[![Coverage Status][coverage-image]][coverage-url]
[![NPM Version][npm-image]][npm-url]> Print a configurable git log in json
## Install
```
$ npm install git-log-to-json
```## CLI
```
Usage: git-log-to-json|git log-to-jsonPrint a configurable git log in json
Options:
-h, --help output usage information
-V, --version output the version number
-H, --hash output the commit hash
-D, --date output the commit date
-N, --author-name output the commit author name
-E, --author-email output the commit author email
-S, --subject output the commit subject
-B, --body output the commit body
-L, --limit limit the number of commit logged
-P, --pretty format the output with "\t"Examples:
$ git log-to-json .
$ git log-to-json . --limit 3
$ git log-to-json . --hash --date --author-name
$ git log-to-json . -H -D --subject
$ git log-to-json . -H -D -S -B --pretty
$ ./bin/git-log-to-json . > history.json
```## API
`require('git-log-to-json')(directory[, options])`
* `directory` _<String>_ The directory to analyze. Must contain a `.git` directory
* `options` _<Object>_ An optional map of flags to configure the `git log` command:
* `hash` _<Boolean>_ Includes the commit hash
* `date` _<Boolean>_ Includes the commit date
* `subject` _<Boolean>_ Includes the commit subject
* `body` _<Boolean>_ Includes the commit body
* `authorEmail` _<Boolean>_ Includes the commit author email
* `authorName` _<Boolean>_ Includes the commit author name
* `limit` _<Integer>_ Limit the number of commit logged
* `pretty` _<Boolean>_ Format the output with \t
* Return: _<Promise>_ The promise resolved once the `git log` command is executed.## Examples
Given the commit:
```
feat(#420): node.js rocksLorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor
incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis
nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
``````js
require('git-log-to-json')('.')
.then((log) => {
/* log will contain:
[{
"hash": "",
"date": "2016-04-21T19:00:13+02:00",
"subject": "feat(#420): node.js rocks",
"body": "Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor
incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis
nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. ",
"author": {
"name": "Simon Renoult",
"email": "[email protected]"
}
}]
*/
})
.catch((err) => {
// do something
})require('git-log-to-json')('.', {hash: true, date: true, authorEmail: true})
.then((log) => {
/* log will contain:
[{
"hash": "",
"date": "2016-04-21T19:00:13+02:00",
"author": {
"email": "[email protected]"
}
}]
*/
})
.catch((err) => {
// do something
})
```## Troubleshooting
> The tests fail to run locally.
The `test/mock/repo` submodule might be missing. Clone `git-log-to-json` with the `--recursive` flag.
> I installed `git-log-to-json` globally but the command is not found.
The command is still available, not to autocompletion though. This is due to
`git` doing some fancy work. The autocompletion will work with `git log-to-json`.[travis-image]: https://travis-ci.org/simonrenoult/git-log-to-json.svg?branch=master
[travis-url]: https://travis-ci.org/simonrenoult/git-log-to-json
[style-image]: https://img.shields.io/badge/code%20style-standard-brightgreen.svg
[style-url]: http://standardjs.com/
[coverage-image]: https://coveralls.io/repos/github/simonrenoult/git-log-to-json/badge.svg?branch=master
[coverage-url]: https://coveralls.io/github/simonrenoult/git-log-to-json?branch=master
[npm-image]: https://img.shields.io/npm/v/git-log-to-json.svg?style=flat-squared
[npm-url]: https://www.npmjs.com/package/git-log-to-json