EasyBuild.CommitParser 1.2.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package EasyBuild.CommitParser --version 1.2.0                
NuGet\Install-Package EasyBuild.CommitParser -Version 1.2.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="EasyBuild.CommitParser" Version="1.2.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add EasyBuild.CommitParser --version 1.2.0                
#r "nuget: EasyBuild.CommitParser, 1.2.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install EasyBuild.CommitParser as a Cake Addin
#addin nuget:?package=EasyBuild.CommitParser&version=1.2.0

// Install EasyBuild.CommitParser as a Cake Tool
#tool nuget:?package=EasyBuild.CommitParser&version=1.2.0                

EasyBuild.Parser

NuGet alternate text is missing from this package README image

Common commit parser library used by other EasyBuild tools like EasyBuild.ChangelogGen or EasyBuild.CommitLinter.

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

[!NOTE] EasyBuild.CommitParser format is based on Conventional Commits and extends it to work in a monorepo environment.

<type>[optional scope][optional !]: <description>

[optional tags]

[optional body]

[optional footer]
  • [optional tags] format is as follows:

    [tag1][tag2][tag3]
    
  • [optional body] is a free-form text.

    This is a single line body.
    
    This is a
    
    multi-line body.
    
  • [optional footer] follows git trailer format

    BREAKING CHANGE: <description>
    Signed-off-by: Alice <alice@example.com>
    Signed-off-by: Bob <bob@example.com>
    

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, skipTagLine?: 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.
skipTagLine bool If true skip the tag line validation. <br> If false, checks that the tag line format is valid and contains knows tags. <br><br>Default is true.
tags
  • Required: ❌
  • Type: string []

List of accepted commit tags.

Examples
{
    "types": [
        { "name": "feat", "description": "A new feature", "skipTagLine": false },
        { "name": "fix", "description": "A bug fix", "skipTagLine": false },
        { "name": "docs", "description": "Documentation changes", "skipTagLine": false },
        { "name": "test", "description": "Adding missing tests or correcting existing tests", "skipTagLine": false },
        { "name": "style", "description": "Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)", "skipTagLine": false },
        { "name": "refactor", "description": "A code change that neither fixes a bug nor adds a feature", "skipTagLine": 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 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. 
.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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.0.0 99 12/2/2024
2.2.0 94 11/23/2024
2.1.1 90 11/23/2024
2.1.0 93 11/22/2024
2.0.0 97 11/14/2024
1.2.0 90 11/4/2024
1.1.1 119 9/8/2024
1.1.0 112 8/27/2024
1.0.0 510 6/17/2024
0.1.0 119 6/13/2024

## 1.2.0

### 🚀 Features

- Add `Body` to `CommitMessage` ([eea6c0a](https://github.com/easybuild-org/EasyBuild.CommitParser/commit/eea6c0a2f69fe8655b6afc26810e86eeff12f49d))
- Improve error message if tag is missing and we have a list of tags in the config file ([98ffdf6](https://github.com/easybuild-org/EasyBuild.CommitParser/commit/98ffdf66afa113be7a7396d1f770061be74de63c))
- Re-add `FsToolkit.ErrorHandling` to make the code easier to read (this also bump minimal version of FSharp.Core) ([1f5b8de](https://github.com/easybuild-org/EasyBuild.CommitParser/commit/1f5b8deb7d10dcab100162c8719b39ce7462cf08))