SourceKit.Generators.Builder 1.2.36

Prefix Reserved
dotnet add package SourceKit.Generators.Builder --version 1.2.36                
NuGet\Install-Package SourceKit.Generators.Builder -Version 1.2.36                
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="SourceKit.Generators.Builder" Version="1.2.36" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add SourceKit.Generators.Builder --version 1.2.36                
#r "nuget: SourceKit.Generators.Builder, 1.2.36"                
#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 SourceKit.Generators.Builder as a Cake Addin
#addin nuget:?package=SourceKit.Generators.Builder&version=1.2.36

// Install SourceKit.Generators.Builder as a Cake Tool
#tool nuget:?package=SourceKit.Generators.Builder&version=1.2.36                

SourceKit.Generators.Builder

Use [GenerateBuilder] attribute to generate builder.

  • Only record or record struct types are supported
  • Builder is a nested class Builder
  • For collection properties field of type List<> will be generated
  • For collection properties, methods With{PropName} and With{PropName}s will be generated
  • If collection element type is IComparable or IComparable<TSelf> the .Distinct LINQ method would be called on .Build method
  • If collection property is List<> or HashSet<> then it will be converted to this collection respectively, otherwise, ToArray method will be called

You can use SomeType.Build() static method to shorthand create type instance using generated builder

[GenerateBuilder]
public partial record SomeQuery(IReadOnlyCollection<Guid> Ids, int Count = 10);

...

var query = SomeQuery.Build(x => x.WithCount(2).WithId(Guid.NewGuid());

Default values for record properties are supported

Required properties

You can annotate property with [RequiredValue] attribute to force compile time error when it is not initialized withing Build method of model.

[GenerateBuilder]
public partial record SomeQuery(long[] Ids, [RequiredValue] int PageSize);

The following code will produce an error.

var query = SomeQuery.Build(x => x.WithId(1));
There are no supported framework assets in this package.

Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on SourceKit.Generators.Builder:

Package Downloads
Itmo.Dev.Platform.BackgroundTasks

Package Description

Itmo.Dev.Platform.MessagePersistence

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.2.36 96 11/18/2024
1.2.35 122 10/11/2024
1.2.34 210 5/4/2024
1.2.33 95 5/1/2024
1.2.31 122 4/27/2024
1.2.30 169 4/6/2024
1.1.29 161 4/3/2024
1.1.27 120 4/3/2024
1.1.26 138 4/3/2024
1.1.24 3,107 12/19/2023
1.1.23 225 12/6/2023
1.1.22 362 11/22/2023
1.1.21 631 11/11/2023
1.1.20 103 11/11/2023
1.1.19 174 11/11/2023
1.1.18 130 11/11/2023
1.1.16 111 11/11/2023
1.1.15 123 11/11/2023
1.1.14 136 11/11/2023
1.1.13 164 11/11/2023
1.1.11 125 11/11/2023
1.1.10 219 9/16/2023
1.1.4 260 9/10/2023
1.0.4 1,284 6/11/2023
1.0.3 182 6/10/2023
1.0.2 144 6/10/2023
1.0.1 376 5/14/2023
1.0.0 173 5/13/2023

Added default values support