FluentBuilder 0.4.4

There is a newer version of this package available.
See the version list below for details.
dotnet add package FluentBuilder --version 0.4.4
NuGet\Install-Package FluentBuilder -Version 0.4.4
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="FluentBuilder" Version="0.4.4">
  <PrivateAssets>all</PrivateAssets>
  <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets>
</PackageReference>
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add FluentBuilder --version 0.4.4
#r "nuget: FluentBuilder, 0.4.4"
#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 FluentBuilder as a Cake Addin
#addin nuget:?package=FluentBuilder&version=0.4.4

// Install FluentBuilder as a Cake Tool
#tool nuget:?package=FluentBuilder&version=0.4.4

Usage

1️⃣ Annotate a class

Annotate a class with [AutoGenerateBuilder] to indicate that a FluentBuilder should be generated for this class:

[AutoGenerateBuilder]
public class User
{
    public string FirstName { get; set; }

    public string LastName { get; set; }

    public DateTime? Date { get; set; }
}

2️⃣ Define a class which needs to act as a builder

This scenario is very usefull when you cannot modify the class to annotate it.

Create a public and partial builder class

And annotate this class with [AutoGenerateBuilder(typeof(XXX))] where XXX is the type for which you want to generate a FluentBuilder.

[AutoGenerateBuilder(typeof(UserDto))]
public partial class MyUserDtoBuilder
{
}

Use FluentBuilder

using System;

namespace Test
{
    class Program
    {
        static void Main(string[] args)
        {
            var user = new UserBuilder()
                .WithFirstName("Test")
                .WithLastName("User")
                .Build();

            Console.WriteLine($"{user.FirstName} {user.LastName}");
        }
    }
}
There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

  • .NETStandard 2.0

    • No dependencies.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on FluentBuilder:

Repository Stars
WireMock-Net/WireMock.Net
WireMock.Net is a flexible product for stubbing and mocking web HTTP responses using advanced request matching and response templating. Based on the functionality from http://WireMock.org, but extended with more functionality.
StefH/FluentBuilder
A project which uses Source Generation to create a FluentBuilder for a specified model or DTO
Version Downloads Last updated
0.7.1 89 3/14/2023
0.7.1-preview-02 52 3/2/2023
0.7.1-preview-01 51 2/25/2023
0.7.0 3,396 9/20/2022
0.7.0-preview-01 74 9/16/2022
0.6.0 309 8/20/2022
0.5.1 1,455 7/28/2022
0.5.0 343 7/13/2022
0.4.9 3,840 6/25/2022
0.4.8 301 6/21/2022
0.4.7 293 6/4/2022
0.4.6 353 5/20/2022
0.4.5 305 5/16/2022
0.4.4 912 4/27/2022
0.4.2 339 4/3/2022
0.4.1 816 2/18/2022
0.4.0 291 2/18/2022
0.3.3 303 2/16/2022
0.3.2 299 2/16/2022
0.3.1 295 2/14/2022
0.3.0 291 2/12/2022
0.2.5 297 2/8/2022
0.2.4 315 2/6/2022
0.2.3 301 2/1/2022
0.2.2 309 1/31/2022
0.2.1 313 1/30/2022
0.2.0 338 1/30/2022
0.1.2 307 1/20/2022
0.1.1 299 1/15/2022
0.1.0 303 1/13/2022
0.0.11 1,301 8/10/2021
0.0.11-preview-01 167 8/10/2021
0.0.10 213 8/8/2021
0.0.10-preview-03 141 8/8/2021
0.0.10-preview-02 163 8/7/2021
0.0.10-preview-01 163 8/7/2021
0.0.9 314 8/7/2021
0.0.8 222 8/6/2021
0.0.7 357 8/5/2021
0.0.6 223 8/5/2021
0.0.5 273 8/5/2021
0.0.4 8,212 7/21/2021
0.0.3 235 7/19/2021
0.0.2 228 7/19/2021
0.0.1 248 7/18/2021

# 0.4.4 (27 April 2022)
- #26 Replace Array.Empty by new T[0] (supporting .NET45) [bug]

The full release notes can be found here: https://github.com/StefH/FluentBuilder/blob/main/ReleaseNotes.md