Skip to content
This repository has been archived by the owner on Mar 19, 2020. It is now read-only.
/ sup Public archive
forked from umurgdk/sup

Automatic changelog generator for git repositories.

License

Notifications You must be signed in to change notification settings

unumotors/sup

 
 

Repository files navigation

sup

Automatic changelog generator for git repositories.

$ sup --help
Allowed options:
  --help                prints this message
  --repository arg (=.) path to repository
  --version arg         new version number to be rendered as title

Install

Follow build instructions for Linux.

$ brew tap umurgdk/sup
$ brew install sup

Overview

Sup looks through your commit history since the last marked tag to your current head and extracts changelog data specified by .sup file in the repository root. Extracted changelog data then prepended to given changelog file. Sup needs to know which version you want to generate changelog for, so version defined at --version parameter will be used as prepended changelog title. Every captured commit will be grouped by their issue types. Features commits under feature title etc.

Sample

screenshot

Build

Sup has two dependencies libgit2 and boost. Tested on macOS and Ubuntu 16.04.

Install Dependencies

# macOS
$ brew cmake install libgit2 boost

# ubuntu
$ sudo apt install git cmake libboost-program-options-dev libboost-filesystem-dev libgit2-dev

Build & Install

$ git clone https://github.com/umurgdk/sup
$ cd sup
$ cmake . && make
$ sudo make install

Configuration (.sup file)

Line numbers are 1 indexed and parenthesis are required for regular expressions if they need to be captured. Don't forget to double escape backslashes (e.g \\d+)

{
  "file": "CHANGELOG.md",    // Optional changelog file path relative to repository root.
                             // default "CHANGELOG.md"
                          
  "filter": "--changeLog",   // Optional regex test to decide commit should be included in changelog
                             // default ".*" (which means all commits will be included)
                            
  "tagFilter": "v*",         // Optional regex which used to find latest created tag
  
  "issueIdRegex": "#(\\d+)", // Regex capture.
                             // default "#(\\d+)" which is github issue format.
                             
  "omitNewLinesInBody": true, // Boolean. If true new lines characters will be
                             // replaced by space character in the body.
                             // default false
                             

  // change log entry template
  // available variables are $issueId, $body, $issueType
  "template": "* $body\n[$issueId](https://github.com/umurgdk/sup/issues/$issueId)",
  
  "issueType": { 
    // Required issue type parser options. (feature, bugfix, error, etc.)
    // There are two different methods you can use. You should choose only one
    //   1. regex - data extracted by regex capture
    //      Parenthesis are required for capturing
    //      If you specify a line number as "searchAt" it will only check the given line
    //   2. line number - data extracted as whole line
    
    "regex": "(feature|hotfix)/",
    "searchAt": 1
    // "lineNumber": 2, // don't use lineNumber with regex and searchAt
  },
  
  "body": {
    // Required changelog entry message parser options.
    // There are three different methods you can use.
    //   1. regex - data extracted by regex capture
    //      You should specify only one capture otherwise first one will be chosen
    //   2. line number - message body will be given line's content
    //   3. until given marker
    //      - you can specify starting line (default is 3)
    
    // "regex": "\[(.*)\]", // it extracts all characters between [ and ] characters
    // "lineNumber": 3,
    "startingAt": 3,
    "endOfBody": "--endOfChangelog" // it will extract lines between startingAt and the line includes marker
  }
}

About

Automatic changelog generator for git repositories.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 96.2%
  • CMake 3.8%