pauldeen79.ClassFramework.Domain 0.19.2

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

// Install pauldeen79.ClassFramework.Domain as a Cake Tool
#tool nuget:?package=pauldeen79.ClassFramework.Domain&version=0.19.2                

ClassFramework

Class modeling framework for C#

If you want to create a C# class structure based on a model, this framework is for you!

We are using the following dependencies:

  • CsharpExpressionDumper, to generate c# code for values
  • CrossCutting.ProcessingPipeline, for extendable pipelines for transformation of classes and interfaces
  • CrossCutting.Utilities.Parsers, for parsing named format strings like {$property.Name}Builder
  • TemplateFramework, to translate the domain model to actual c# code files

The Domain and Pipelines packages target .NET Standard 2.0, so you can use it anywhere. Because of the dependency to TemplateFramework, we target some projects to .NET 8.0.

Background

Imagine you want to create some domain model for a new project.

First, you need to create a console project named [YourProjectName].CodeGeneration.

In this project, there are a number of components:

  • The Program.cs class, which runs the code generation
  • The Models folder, which contains interfaces for all your domain entities
  • The CodeGenerationProviders folder, which contains all types of code generators, like entities, builders and maybe abstractions

Philosophy

The entity and builder generators use the following characteristics:

  • The entity can be either a POCO or a DDD-style object, which takes all input in the constructor and then validates the state
  • You can use either immutable or mutable entities, and you can choose to make the setters private or public
  • You can use observable properties on entities, if you need to
  • For immutable entities, you can also generate builders. These are mutable, and you can easily convert between the two types (unless you want the entities in a separate project, without a reference to the builders)
  • Validation is supported using the IValidatableObject interface (standard .NET validation), and can be shared between the entities and the builders
  • Default values on the model properties can automatically be set in the constructor of the builders, if you want to
  • You can either create entities without interfaces, or interface-based entities (possibly in a different namespace, e.g. MyProject.Core and MyProject.Abstractions)

Dog fooding

I have decided that the models for ClassFramework need to be generated using ClassFramework. To make this possible, I have first generated everything with another framework (called ModelFramework) as a Bootstrap action. After this, I re-generated everything using ClassFramework.

But since version 0.9.1, I stored the generated code, so I could add breaking changes. This means the code generation in the build pipelines has been removed.

Known issues

If you have types with nested or multiple generic arguments, the nullability of those types will not get determined correctly... Try to fix this by creating types for this. E.g. System.Func<System.Object, System.Int32, System.Object?> Just create a delegate for this, and add this to the type mapping.

If you still get errors, you could use the CsharpTypeNameAttribute to decorate your property/field/parameter.

Upgrading to version 0.19

Most methods in the CsharpClassGeneratorPipelineCodeGenerationProviderBase class have wrapped their result in a Result<T> type. So, for example, IEnumerable<TypeBase> becomes Result<IEnumerable<TypeBase>>.

For example, this code:

Task<IEnumerable<TypeBase>> GetModel()

has changed to:

Task<Result<IEnumerable<TypeBase>>>

This way, you can return errors and halt program flow with Result.Error instead of throwing exceptions.

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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  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 (2)

Showing the top 2 NuGet packages that depend on pauldeen79.ClassFramework.Domain:

Package Downloads
pauldeen79.ClassFramework.Pipelines

Package Description

pauldeen79.ClassFramework.CsharpExpressionCreator

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.19.2 225 12/28/2024
0.19.1 163 12/27/2024
0.19.0 154 12/26/2024
0.18.4 123 12/18/2024
0.18.3 109 12/18/2024
0.18.2 110 12/18/2024
0.18.1 111 12/18/2024
0.18.0 116 12/17/2024
0.17.0 226 11/17/2024
0.16.2 197 11/10/2024
0.16.1 165 11/6/2024
0.16.0 126 11/6/2024
0.15.5 146 10/31/2024
0.15.4 147 10/30/2024
0.15.3 176 10/18/2024
0.15.2 155 10/17/2024
0.15.1 140 9/22/2024
0.15.0 179 9/21/2024
0.14.2 173 9/11/2024
0.14.1 280 8/20/2024
0.14.0 168 8/19/2024
0.13.9 149 8/3/2024
0.13.8 110 7/28/2024
0.13.7 194 7/6/2024
0.13.6 222 6/9/2024
0.13.5 147 6/9/2024
0.13.4 143 6/9/2024
0.13.3 185 5/25/2024
0.13.2 188 5/20/2024
0.13.1 205 5/18/2024
0.13.0 167 5/17/2024
0.12.7 180 5/9/2024
0.12.6 134 5/9/2024
0.12.5 193 5/8/2024
0.12.4 179 5/7/2024
0.12.3 170 5/7/2024
0.12.2 119 5/3/2024
0.12.1 152 5/2/2024
0.12.0 139 5/1/2024
0.11.0 233 4/19/2024
0.10.0 195 4/16/2024
0.9.3 223 4/12/2024
0.9.2 177 4/9/2024
0.9.1 174 4/7/2024
0.9.0 191 4/6/2024
0.8.9 175 4/5/2024
0.8.8 154 4/5/2024
0.8.7 166 4/5/2024
0.8.6 162 4/4/2024
0.8.5 159 4/3/2024
0.8.4 178 4/3/2024
0.8.3 165 4/3/2024
0.8.1 179 4/2/2024
0.8.0 215 3/23/2024
0.7.2 188 3/22/2024
0.7.1 172 3/22/2024
0.7.0 191 3/20/2024
0.6.0 178 3/17/2024
0.5.6 205 3/15/2024
0.5.5 195 3/15/2024
0.5.4 189 3/14/2024
0.5.3 189 3/14/2024
0.5.2 183 3/14/2024
0.5.1 182 3/13/2024
0.4.2 240 3/8/2024
0.4.1 199 3/8/2024
0.4.0 196 3/8/2024
0.3.1 206 3/5/2024
0.3.0 199 3/5/2024
0.2.0 222 3/4/2024
0.1.0 201 2/25/2024