EasyBuild.CommitParser
                             
                            
                                2.2.0
                            
                        
                    See the version list below for details.
dotnet add package EasyBuild.CommitParser --version 2.2.0
NuGet\Install-Package EasyBuild.CommitParser -Version 2.2.0
<PackageReference Include="EasyBuild.CommitParser" Version="2.2.0" />
<PackageVersion Include="EasyBuild.CommitParser" Version="2.2.0" />
<PackageReference Include="EasyBuild.CommitParser" />
paket add EasyBuild.CommitParser --version 2.2.0
#r "nuget: EasyBuild.CommitParser, 2.2.0"
#:package EasyBuild.CommitParser@2.2.0
#addin nuget:?package=EasyBuild.CommitParser&version=2.2.0
#tool nuget:?package=EasyBuild.CommitParser&version=2.2.0
EasyBuild.Parser
Common commit parser library used by other EasyBuild tools like EasyBuild.ChangelogGen or EasyBuild.CommitLinter.
It aims to provide helpful contextual error messages like:
Example of error messages:
Invalid commit message format.
Expected a commit message with the following format: '<type>[optional scope]: <description>'.
Where <type> is one of the following:
- feat: A new feature
- fix: A bug fix
- ci: Changes to CI/CD configuration
- chore: Changes to the build process or auxiliary tools and libraries such as documentation generation
- docs: Documentation changes
- test: Adding missing tests or correcting existing tests
- style: Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
- refactor: A code change that neither fixes a bug nor adds a feature
Example:
-------------------------
feat: some description
-------------------------
or
Unkonwn tag(s) in the footer.
Received:
- some-tag
But allowed tags are:
- converter
- web
Usage
open EasyBuild.CommitParser
open EasyBuild.CommitParser.Types
let commitText = "..."
// If you need the commit message information
Parser.tryParseCommitMessage CommitParserConfig.Default commitText
// > it: Result<CommitMessage,string>
// If you just want to validate the commit message
Parser.tryValidateCommitMessage CommitParserConfig.Default commitText
// > it: Result<unit,string>
For the configuration, you can use the default configuration or provide a custom one.
open EasyBuild.CommitParser.Types
// Default configuration
CommitParserConfig.Default
// My custom configuration
{
    Types =
        [
            // ...
        ]
    Tags =
        [
            // ...
        ] |> Some
}
// You can also use a configuration file by passing the JSON content to the included Decoder
open Thoth.Json.Newtonsoft
let configurationJson = "..."
match Decode.fromString CommitParserConfig.decoder configContent with
| Ok config -> config
| Error error ->
    failwithf "Error while parsing the configuration file: %s" error
Commit Format
EasyBuild.CommitParser format is based on Conventional Commits
It add a special Tag footer, allowing it to be used in a mono-repo context.
Tools like EasyBuild.ChangelogGen can use the tag to filter the commits to include in the changelog.
<type>[optional scope][optional !]: <description>
[optional body]
[optional footer]
- [optional body]is a free-form text.- This is a single line body.- This is a multi-line body.
- [optional footer]is inspired by git trailer format- key: valuebut also allows- key #value- BREAKING CHANGE: <description> Signed-off-by: Alice <alice@example.com> Signed-off-by: Bob <bob@example.com> Refs #123 Tag: cli- 💡 The - Tagfooter can be provided multiple times.
Configuration
EasyBuild.CommitParser comes with a default configuration to validate your commit.
The default configuration allows the following commit types with no tags required:
- feat- A new feature
- fix- A bug fix
- ci- Changes to CI/CD configuration
- chore- Changes to the build process or auxiliary tools and libraries such as documentation generation
- docs- Documentation changes
- test- Adding missing tests or correcting existing tests
- style- Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
- refactor- A code change that neither fixes a bug nor adds a feature
If needed, you can provide a custom configuration either by code directly or by using a configuration file using JSON format.
Configuration File Format
The configuration file is a JSON file with the following properties:
types
- Required: ✅
- Type: { name: string, description?: string, skipTagFooter?: bool } []
List of accepted commit types.
| Property | Type | Required | Description | 
|---|---|---|---|
| name | string | ✅ | The name of the commit type. | 
| description | string | ❌ | The description of the commit type. | 
| skipTagFooter | bool | ❌ | If trueskip the tag footer validation. <br> Iffalse, checks that the tag footer is provided and contains knows tags. <br><br>Default istrue. | 
tags
- Required: ❌
- Type: string []
List of accepted commit tags.
Examples
{
    "types": [
        { "name": "feat", "description": "A new feature", "skipTagFooter": false },
        { "name": "fix", "description": "A bug fix", "skipTagFooter": false },
        { "name": "docs", "description": "Documentation changes", "skipTagFooter": false },
        { "name": "test", "description": "Adding missing tests or correcting existing tests", "skipTagFooter": false },
        { "name": "style", "description": "Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)", "skipTagFooter": false },
        { "name": "refactor", "description": "A code change that neither fixes a bug nor adds a feature", "skipTagFooter": false },
        { "name": "ci", "description": "Changes to CI/CD configuration" },
        { "name": "chore", "description": "Changes to the build process or auxiliary tools and libraries such as documentation generation" }
    ],
    "tags": [
        "cli",
        "converter"
    ]
}
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
| .NET Core | netcoreapp3.0 was computed. netcoreapp3.1 was computed. | 
| .NET Standard | netstandard2.1 is compatible. | 
| MonoAndroid | monoandroid was computed. | 
| MonoMac | monomac was computed. | 
| MonoTouch | monotouch was computed. | 
| Tizen | tizen60 was computed. | 
| Xamarin.iOS | xamarinios was computed. | 
| Xamarin.Mac | xamarinmac was computed. | 
| Xamarin.TVOS | xamarintvos was computed. | 
| Xamarin.WatchOS | xamarinwatchos was computed. | 
- 
                                                    .NETStandard 2.1- FSharp.Core (>= 7.0.300)
- FsToolkit.ErrorHandling (>= 4.18.0)
- Thoth.Json.Newtonsoft (>= 0.1.0)
 
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
## 2.2.0
### 🚀 Features
- Skip lines starting with `#` when at the end of the body or footer ([6684bb1](https://github.com/easybuild-org/EasyBuild.CommitParser/commit/6684bb1ef7f86e30dfb1e73adf1416791feb955d))