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
<PackageReference Include="pauldeen79.ClassFramework.Domain" Version="0.19.2" />
paket add pauldeen79.ClassFramework.Domain --version 0.19.2
#r "nuget: pauldeen79.ClassFramework.Domain, 0.19.2"
// 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 | Versions 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. |
-
.NETStandard 2.0
- pauldeen79.CrossCutting.Common (>= 3.13.0)
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 |