pauldeen79.ClassFramework.TemplateFramework 0.19.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package pauldeen79.ClassFramework.TemplateFramework --version 0.19.0                
NuGet\Install-Package pauldeen79.ClassFramework.TemplateFramework -Version 0.19.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="pauldeen79.ClassFramework.TemplateFramework" Version="0.19.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add pauldeen79.ClassFramework.TemplateFramework --version 0.19.0                
#r "nuget: pauldeen79.ClassFramework.TemplateFramework, 0.19.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 pauldeen79.ClassFramework.TemplateFramework as a Cake Addin
#addin nuget:?package=pauldeen79.ClassFramework.TemplateFramework&version=0.19.0

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

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 net9.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on pauldeen79.ClassFramework.TemplateFramework:

Package Downloads
DatabaseFramework.CodeGeneration

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
0.19.2 444 12/28/2024
0.19.1 99 12/27/2024
0.19.0 130 12/26/2024
0.18.4 102 12/18/2024
0.18.3 89 12/18/2024
0.18.2 92 12/18/2024
0.18.1 90 12/18/2024
0.18.0 103 12/17/2024
0.17.0 189 11/17/2024
0.16.2 166 11/10/2024
0.16.1 118 11/6/2024
0.16.0 91 11/6/2024
0.15.5 115 10/31/2024
0.15.4 116 10/30/2024
0.15.3 149 10/18/2024
0.15.2 116 10/17/2024
0.15.1 113 9/22/2024
0.15.0 141 9/21/2024
0.14.2 166 9/11/2024
0.14.1 220 8/20/2024
0.14.0 129 8/19/2024
0.13.9 107 8/3/2024
0.13.8 100 7/28/2024
0.13.7 190 7/6/2024
0.13.6 183 6/9/2024
0.13.5 109 6/9/2024
0.13.4 123 6/9/2024
0.13.3 224 5/25/2024
0.13.2 258 5/20/2024
0.13.1 210 5/18/2024
0.13.0 167 5/17/2024
0.12.7 308 5/9/2024
0.12.6 86 5/9/2024
0.12.5 167 5/8/2024
0.12.4 165 5/7/2024
0.12.3 123 5/7/2024
0.12.2 71 5/3/2024
0.12.1 107 5/2/2024
0.12.0 92 5/1/2024
0.11.0 183 4/19/2024
0.10.0 149 4/16/2024
0.9.3 171 4/12/2024
0.9.2 132 4/9/2024
0.9.1 126 4/7/2024
0.9.0 162 4/6/2024
0.8.9 116 4/5/2024
0.8.8 120 4/5/2024
0.8.7 123 4/5/2024
0.8.6 134 4/4/2024
0.8.5 118 4/3/2024
0.8.4 134 4/3/2024
0.8.3 114 4/3/2024
0.8.1 123 4/2/2024
0.8.0 226 3/23/2024
0.7.2 150 3/22/2024
0.7.1 131 3/22/2024
0.7.0 158 3/20/2024
0.6.0 209 3/17/2024
0.5.6 194 3/15/2024
0.5.5 136 3/15/2024
0.5.4 141 3/14/2024
0.5.3 142 3/14/2024
0.5.2 119 3/14/2024
0.5.1 153 3/13/2024
0.4.2 262 3/8/2024
0.4.1 107 3/8/2024
0.4.0 121 3/8/2024
0.3.1 206 3/5/2024
0.3.0 102 3/5/2024
0.2.0 167 3/4/2024
0.1.0 322 2/25/2024