SourceKit.Generators.Builder 1.2.40

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package SourceKit.Generators.Builder --version 1.2.40                
NuGet\Install-Package SourceKit.Generators.Builder -Version 1.2.40                
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.40" />                
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.40                
#r "nuget: SourceKit.Generators.Builder, 1.2.40"                
#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.40

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

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.45 125 12/15/2024
1.2.44 74 12/15/2024
1.2.43 71 12/15/2024
1.2.42 69 12/15/2024
1.2.41 75 12/15/2024
1.2.40 71 12/15/2024
1.2.37 76 12/14/2024
1.2.36 431 11/18/2024
1.2.35 150 10/11/2024
1.2.34 221 5/4/2024
1.2.33 100 5/1/2024
1.2.31 127 4/27/2024
1.2.30 183 4/6/2024
1.1.29 164 4/3/2024
1.1.27 123 4/3/2024
1.1.26 143 4/3/2024
1.1.24 3,274 12/19/2023
1.1.23 230 12/6/2023
1.1.22 377 11/22/2023
1.1.21 640 11/11/2023
1.1.20 106 11/11/2023
1.1.19 177 11/11/2023
1.1.18 135 11/11/2023
1.1.16 114 11/11/2023
1.1.15 126 11/11/2023
1.1.14 141 11/11/2023
1.1.13 167 11/11/2023
1.1.11 128 11/11/2023
1.1.10 222 9/16/2023
1.1.4 265 9/10/2023
1.0.4 1,287 6/11/2023
1.0.3 185 6/10/2023
1.0.2 147 6/10/2023
1.0.1 379 5/14/2023
1.0.0 196 5/13/2023

Added default values support