DTOMaker.MessagePack
0.70.2
See the version list below for details.
dotnet add package DTOMaker.MessagePack --version 0.70.2
NuGet\Install-Package DTOMaker.MessagePack -Version 0.70.2
<PackageReference Include="DTOMaker.MessagePack" Version="0.70.2" />
<PackageVersion Include="DTOMaker.MessagePack" Version="0.70.2" />
<PackageReference Include="DTOMaker.MessagePack" />
paket add DTOMaker.MessagePack --version 0.70.2
#r "nuget: DTOMaker.MessagePack, 0.70.2"
#:package DTOMaker.MessagePack@0.70.2
#addin nuget:?package=DTOMaker.MessagePack&version=0.70.2
#tool nuget:?package=DTOMaker.MessagePack&version=0.70.2
DTOMaker
Warning: This is pre-release software under active development. Breaking changes may occur.
A collection of model-driven compile-time source generators for quickly creating DTOs (Data Transport Objects) supporting the following serialization schemes:
- JSON (NewtonSoft)
- MessagePack
- MemBlocks
and related types.
Workflow
---
title: Workflow
---
flowchart LR
def(Define models e.g. IMyDTO.cs)
ref1(Reference DTOMaker.Models.*)
ref2(Reference DTOMaker.Runtime.*)
ref3(Reference one or more source generators e.g. DTOMaker.MessagePack)
bld(VS/Code/MSBuild)
pkg(Assembly)
ref1-->def
def-->ref2
def-->ref3
ref2-->bld
ref3-->bld
bld-->pkg
Models are defined as C# interfaces with additional attributes. Here's a trivial example:
[Entity][Id(1)]
public interface IMyFirstDTO
{
[Member(1)] string Name { get; set; }
}
If using the MessagePack source generator, the following implmentation will be generated (simplified):
[MessagePackObject]
public sealed class MyFirstDTO : EntityBase, IMyFirstDTO, IEquatable<MyFirstDTO>
{
[Key(1)] string Name { get; set; }
}
Included Packages
This repo includes the following packages:
DTOMaker.Models
Attributes for defining simple data models as interfaces in C#.
DTOMaker.JsonNewtonSoft
A source generator that creates DTOs (Data Transport Objects) that are serializable to JSON using the Newtonsoft.Json package.
DTOMaker.MessagePack
A source generator that creates MessagePack DTOs (Data Transport Objects). See https://github.com/MessagePack-CSharp/MessagePack-CSharp.
DTOMaker.Models.MessagePack
Additional attributes used by the DTOMaker.MessagePack source generator, to manage MessagePack entity and member keys.
DTOMaker.MemBlocks
Generates DTOs whose internal data is a single memory block (Memory<byte>). Property getters and setters decode and encode values directly to the block with little-endian (default) or big-endian byte ordering.
DTOMaker.Models.MemBlocks
Additional attributes used by the DTOMaker.MemBlocks source generator, to manage entity and member memory layout.
DTOMaker.CSPoco
Generates basic POCOs (Plain Old C# Objects) that implement the model interfaces.
DTOMaker.Runtime
Common types used at runtime by DTOMaker generated entities.
Model features
- Member value types: Boolean, S/Byte, U/Int16/32/64/128, Double, Single, Half, Char, Guid, Decimal
- String member types
- Binary member types (Octets)
- polymorphic types
- generic types
- entity members
- Built-in freezability (mutable until frozen) support
- [Obsolete] members
- Fixed length arrays of above value types.
- IEquatable<T> support
- Templates as testable code, template-to-generator processing.
MemBlocks features
- auto-embedded string, binary and entity members when encoded < 63 bytes.
- fixed-length string and binary member types.
!Limitations
Single compilation unit
All models and generated DTOs are contained within a single assembly. Models cannot reference types in other projects or packages (other than native or built-in types). Generated classes are partial, which can help you mitigate the single assembly constraint.
Development
In progress
- custom struct members (to avoid primitive obsession)
Coming soon
- Json (System.Text) generator
- upgrade source generators to IIncrementalGenerator
- global interface equality comparer
- reservation (hidden members)
- Orleans generator
- ProtobufNet 3.0 generator
- MessagePack 3.x generator
- NetStrux generator
- MemBlocks compact layout method
- Enum data types. Workaround - enums can be implemented with an underlying integer property and a cast.
- MemBlocks nullable types. Workaround - T? can be implemented with a pair of members (Boolean, T).
Coming later
- Google Protobuf .proto generation
- model.json generation
- command-line alternative
- variable length arrays
- logical value equality
- Rune member types
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- Microsoft.Bcl.HashCode (>= 6.0.0)
- Microsoft.CodeAnalysis (>= 4.12.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last Updated |
---|---|---|
0.71.7 | 270 | 9/19/2025 |
0.71.6 | 281 | 9/17/2025 |
0.71.5 | 278 | 9/16/2025 |
0.71.4 | 218 | 9/15/2025 |
0.71.3 | 216 | 9/15/2025 |
0.71.1 | 214 | 9/15/2025 |
0.70.3 | 139 | 9/9/2025 |
0.70.2 | 146 | 9/2/2025 |
0.70.1-dev | 187 | 8/27/2025 |
0.69.10 | 121 | 8/17/2025 |
0.69.9 | 77 | 8/16/2025 |
0.69.8 | 145 | 8/13/2025 |
0.69.7-dev | 148 | 8/13/2025 |
0.69.6-dev | 140 | 8/12/2025 |
0.69.4-dev | 114 | 8/9/2025 |
0.69.3-dev | 81 | 7/19/2025 |
0.69.2-dev | 72 | 7/19/2025 |
0.68.6 | 82 | 7/19/2025 |
0.68.5-dev | 75 | 7/19/2025 |
0.68.2-dev | 156 | 7/17/2025 |
0.68.1-dev | 143 | 7/17/2025 |
0.67.7 | 150 | 7/17/2025 |
0.67.6-dev | 154 | 7/9/2025 |
0.67.5-dev | 153 | 7/9/2025 |
0.67.3-dev | 158 | 7/7/2025 |
0.67.1-dev | 298 | 6/10/2025 |
0.66.18 | 257 | 6/9/2025 |
0.66.17-dev | 224 | 6/9/2025 |
0.66.16-dev | 129 | 6/8/2025 |
0.66.14-dev | 85 | 6/7/2025 |
0.66.13-dev | 149 | 6/5/2025 |
0.66.10-dev | 155 | 6/5/2025 |
0.66.9-dev | 151 | 6/5/2025 |
0.66.8-dev | 153 | 6/5/2025 |
0.66.7-dev | 146 | 6/4/2025 |
0.66.2-dev | 83 | 5/31/2025 |
0.65.20-generics-g24a665d336 | 82 | 5/31/2025 |
0.65.13-generics-ge74b19332f | 171 | 4/23/2025 |
0.65.10-generics-g6f262eb134 | 194 | 4/17/2025 |
0.65.1-generics | 83 | 5/31/2025 |
0.64.27 | 157 | 5/27/2025 |
0.64.26 | 219 | 5/16/2025 |
0.64.24 | 161 | 5/8/2025 |
0.64.22 | 182 | 4/23/2025 |
0.64.20 | 181 | 4/10/2025 |
0.64.18 | 185 | 4/10/2025 |
0.64.17 | 175 | 4/10/2025 |
0.64.16 | 179 | 4/9/2025 |
0.64.10 | 178 | 4/7/2025 |
0.64.9 | 136 | 4/4/2025 |
0.64.8-dev | 168 | 4/1/2025 |
0.64.7-dev-g53a80ba3be | 172 | 4/1/2025 |
0.64.5-dev-g449e36f771 | 482 | 3/25/2025 |
0.64.5-dev-g2fcf9bff64 | 154 | 4/1/2025 |
0.64.4-dev | 167 | 4/1/2025 |
0.64.3-dev | 158 | 3/31/2025 |
0.64.2-dev | 490 | 3/25/2025 |
0.64.1-dev | 482 | 3/25/2025 |
0.63.60-gee4d301e03 | 484 | 3/25/2025 |
0.63.19 | 120 | 3/21/2025 |
0.63.19-g2e909c64aa | 113 | 3/21/2025 |
0.63.17 | 133 | 3/14/2025 |
0.63.16 | 137 | 3/14/2025 |
0.63.15 | 164 | 3/13/2025 |
0.63.13 | 173 | 3/11/2025 |
0.63.12 | 175 | 3/11/2025 |
0.63.11-dev | 172 | 3/11/2025 |
0.63.9-dev | 171 | 3/11/2025 |
0.63.8-dev | 177 | 3/10/2025 |
0.63.7-dev | 167 | 3/10/2025 |
0.63.6-dev | 176 | 3/10/2025 |
0.63.3-dev | 171 | 3/10/2025 |
0.62.10 | 229 | 3/8/2025 |
0.62.9 | 236 | 3/8/2025 |
0.62.7 | 227 | 3/7/2025 |
0.62.6-dev | 214 | 3/7/2025 |
0.62.5-dev | 213 | 3/7/2025 |
0.61.14 | 237 | 3/6/2025 |
0.61.13-dev | 213 | 3/6/2025 |
0.61.12-dev | 206 | 3/6/2025 |
0.61.10-dev | 222 | 3/6/2025 |
0.61.9-dev | 224 | 3/5/2025 |
0.61.8-dev | 212 | 3/5/2025 |
0.61.5-dev | 206 | 3/4/2025 |
0.61.3-dev | 208 | 3/4/2025 |
0.61.2-dev | 146 | 3/3/2025 |
0.60.8 | 140 | 2/27/2025 |
0.60.7 | 119 | 2/27/2025 |
0.60.6-dev | 109 | 2/27/2025 |
0.60.3-dev | 96 | 2/25/2025 |
0.59.10 | 119 | 2/19/2025 |
0.59.8-dev | 111 | 2/19/2025 |
0.59.5-dev | 106 | 2/17/2025 |
0.59.4-dev | 115 | 2/15/2025 |
0.58.9 | 141 | 2/4/2025 |
0.58.8-dev | 117 | 2/4/2025 |
0.57.6 | 132 | 2/1/2025 |
0.57.4 | 127 | 2/1/2025 |
0.57.2-dev | 115 | 2/1/2025 |
0.57.1-dev | 108 | 2/1/2025 |
0.56.13 | 147 | 1/31/2025 |
0.56.12-dev | 113 | 1/31/2025 |
0.56.11-dev | 106 | 1/30/2025 |
0.56.10-dev | 98 | 1/30/2025 |
0.56.9-dev | 115 | 1/30/2025 |
0.56.6-dev | 95 | 1/24/2025 |
0.56.5-dev | 100 | 1/24/2025 |
0.56.4-dev | 100 | 1/24/2025 |
0.56.3-dev | 101 | 1/24/2025 |
0.55.38 | 125 | 1/23/2025 |
0.55.37-dev | 108 | 1/23/2025 |
0.55.36-dev | 104 | 1/22/2025 |
0.55.34-dev | 113 | 1/22/2025 |
0.55.32-dev | 99 | 1/22/2025 |
0.55.31-dev | 101 | 1/21/2025 |
0.55.30-dev | 95 | 1/21/2025 |
0.55.29-dev | 103 | 1/20/2025 |
0.55.27-dev | 103 | 1/20/2025 |
0.55.25-dev | 101 | 1/20/2025 |
0.55.24-dev | 92 | 1/20/2025 |
0.55.23-dev | 95 | 1/19/2025 |
0.55.20-dev | 94 | 1/19/2025 |
0.55.17-dev | 91 | 1/19/2025 |
0.55.14-dev | 95 | 1/19/2025 |
0.54.1 | 130 | 1/3/2025 |
0.53.5 | 144 | 1/1/2025 |
0.53.4 | 136 | 1/1/2025 |
0.53.3 | 145 | 12/31/2024 |
0.53.2-dev | 113 | 12/31/2024 |
0.53.1-dev | 95 | 12/31/2024 |
0.52.2 | 121 | 12/31/2024 |
0.52.1 | 118 | 12/31/2024 |
0.51.1 | 104 | 12/31/2024 |
0.50.2 | 122 | 12/31/2024 |
0.50.1-dev | 104 | 12/31/2024 |
0.49.3 | 124 | 12/29/2024 |
0.49.2-dev | 108 | 12/29/2024 |
0.49.1-dev | 107 | 12/29/2024 |
0.48.5 | 117 | 12/29/2024 |
0.48.4-dev | 106 | 12/29/2024 |
0.48.3-dev | 110 | 12/28/2024 |
0.48.2-dev | 103 | 12/28/2024 |
0.48.1-dev | 107 | 12/28/2024 |
0.47.2 | 114 | 12/28/2024 |
0.47.1 | 126 | 12/27/2024 |
0.46.9 | 117 | 12/27/2024 |
0.46.8 | 127 | 12/27/2024 |
0.46.7 | 116 | 12/27/2024 |
0.46.6 | 118 | 12/23/2024 |
0.46.5 | 125 | 12/23/2024 |
0.46.4 | 118 | 12/23/2024 |
0.46.3 | 127 | 12/22/2024 |
0.46.2-dev | 109 | 12/22/2024 |
0.46.1-dev | 98 | 12/22/2024 |
0.45.3 | 120 | 12/22/2024 |
0.45.2-dev | 110 | 12/21/2024 |
0.45.1-dev | 108 | 12/20/2024 |
0.44.4 | 117 | 12/19/2024 |
0.44.3 | 114 | 12/19/2024 |
0.44.2 | 119 | 12/19/2024 |
0.44.1 | 108 | 12/19/2024 |
0.43.3 | 110 | 12/19/2024 |
0.43.2-dev | 106 | 12/19/2024 |
0.43.1-dev | 104 | 12/19/2024 |
0.42.2 | 117 | 12/18/2024 |
0.42.1-dev | 100 | 12/18/2024 |
0.41.2 | 117 | 12/18/2024 |
0.41.1-dev | 104 | 12/18/2024 |
0.40.4 | 133 | 12/16/2024 |
0.40.3-dev | 87 | 12/16/2024 |
0.39.2 | 114 | 12/3/2024 |
0.39.1-dev | 102 | 12/3/2024 |
0.38.2-dev | 97 | 11/25/2024 |
0.38.1-dev | 110 | 11/25/2024 |
0.37.2 | 108 | 11/24/2024 |
0.37.1 | 129 | 11/23/2024 |
0.36.6 | 114 | 11/23/2024 |
0.36.5 | 123 | 11/22/2024 |
0.36.4 | 120 | 11/22/2024 |
0.34.1 | 122 | 11/17/2024 |
0.33.1 | 113 | 11/17/2024 |
0.32.1 | 122 | 11/16/2024 |
0.31.1 | 111 | 11/16/2024 |
0.29.5 | 125 | 11/13/2024 |
0.29.4 | 120 | 11/13/2024 |
0.29.3 | 124 | 11/13/2024 |
0.29.2 | 118 | 11/12/2024 |
0.29.1 | 124 | 11/12/2024 |
0.28.2 | 120 | 11/12/2024 |
0.28.1 | 125 | 11/11/2024 |
0.27.3 | 125 | 11/11/2024 |
0.27.2 | 135 | 11/11/2024 |
0.26.4 | 126 | 11/9/2024 |
0.26.2-dev | 105 | 11/7/2024 |
0.26.1-dev | 106 | 11/5/2024 |
0.25.2 | 152 | 10/20/2024 |
0.24.2 | 170 | 10/19/2024 |
0.23.1 | 168 | 10/18/2024 |
0.22.6 | 177 | 10/18/2024 |
0.21.3 | 130 | 10/11/2024 |
0.21.2-beta | 106 | 10/10/2024 |
0.20.2 | 112 | 10/8/2024 |
0.20.1 | 126 | 10/8/2024 |
0.19.2 | 141 | 10/7/2024 |
0.19.1 | 112 | 10/6/2024 |
0.18.1 | 131 | 10/6/2024 |
0.17.1 | 133 | 10/5/2024 |
0.16.2 | 127 | 10/5/2024 |
0.16.1 | 120 | 10/5/2024 |
0.15.1 | 134 | 10/5/2024 |
0.14.1 | 126 | 10/5/2024 |
0.13.1 | 122 | 10/4/2024 |
0.12.1 | 127 | 10/4/2024 |
0.11.2 | 134 | 10/4/2024 |
0.10.1 | 130 | 10/2/2024 |
0.9.3 | 124 | 10/2/2024 |
0.3.2-beta | 113 | 10/1/2024 |
0.3.1-beta | 125 | 9/30/2024 |
0.2.1-beta | 108 | 9/28/2024 |
0.1.36-alpha | 109 | 9/28/2024 |
0.1.35-alpha | 106 | 9/28/2024 |
0.1.33-alpha | 98 | 9/26/2024 |
0.1.32-alpha | 104 | 9/25/2024 |
0.1.31-alpha | 108 | 9/25/2024 |
0.1.30-alpha | 97 | 9/25/2024 |