DTOMaker.CLI
1.9.4-dev
This is a prerelease version of DTOMaker.CLI.
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet tool install --global DTOMaker.CLI --version 1.9.4-dev
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest
dotnet tool install --local DTOMaker.CLI --version 1.9.4-dev
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=DTOMaker.CLI&version=1.9.4-dev&prerelease
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
nuke :add-package DTOMaker.CLI --version 1.9.4-dev
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
DTOMaker
Warning: This is pre-release software under active development. Breaking changes may occur.
Model-driven compile-time source generators for quickly creating polymorphic, freezable DTOs (Data Transport Objects) supporting various serialization protocols.
Features
- Models defined via C# interfaces with attributes.
- Source generators create implementations at compile time.
- Properties can be basic .NET types such as integers, floats, strings, Guid, etc.
- Raw byte arrays are supported using the built-in Octets type.
- Other common types such as DateTime, DateTimeOffset, TimeSpan are supported by built-in converters.
- User-defined value types can be supported via user-defined converters to built-in types.
- Nullable types.
- Polymorphic types.
- Freezable types: Instances are mutable until frozen.
- Serialization protocols:
- JSON via System.Text.Json
- JSON via Newtonsoft.Json
- MessagePack 2.x
- MemBlocks
- Collections. Collections based on balanced binary trees are supported.
Example
using DTOMaker.Models;
namespace MyModels;
[Entity(1)] public interface INode : IEntityBase
{
[Member(1)] String Key { get; set; }
}
[Entity(2)] public interface IStringNode : INode
{
[Member(1)] String Value { get; set; }
}
[Entity(3)] public interface INumberNode : INode
{
[Member(1)] Int64 Value { get; set; }
}
[Entity(4)] public interface ITree : IEntityBase
{
[Member(1)] ITree? Left { get; set; }
[Member(2)] ITree? Right { get; set; }
[Member(3)] INode? Node { get; set; }
}
Workflow
flowchart TB
def(Define models e.g. IMyDTO.cs)
ref1(Reference DTOMaker.Models)
ref2(Reference runtime e.g. DTOMaker.Runtime.JsonSystemText)
ref3(Reference source generator e.g. DTOMaker.SrcGen.JsonSystemText)
bld(Build/Run)
ref1-->def
def-->ref2
ref2-->ref3
ref3-->bld
Development
Coming soon
- more custom (ref and value) type converters
Coming later
- incremental serialization
- MessagePack 3.x serialization
- Orleans serialization
- Protobuf.Net serialization
- model.json generation
- command-line alternative
- variant native type support
- variable length arrays
- logical value equality
- common pattern extensions
How to sponsor
If you find these tools useful, please consider sponsoring my work on GitHub at https://github.com/sponsors/Psiman62 or buy me a coffee at https://www.buymeacoffee.com/psiman62
License
This project is licensed under the Apache-2.0 License - see the LICENSE file for details.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
This package has no dependencies.
| Version | Downloads | Last Updated |
|---|---|---|
| 2.0.19-dev | 0 | 3/5/2026 |
| 2.0.18-dev | 0 | 3/5/2026 |
| 2.0.17-dev | 72 | 3/3/2026 |
| 2.0.16-dev | 71 | 3/3/2026 |
| 2.0.15-dev | 79 | 3/1/2026 |
| 2.0.13-dev | 79 | 2/27/2026 |
| 2.0.9-dev | 80 | 2/27/2026 |
| 2.0.7-dev | 80 | 2/26/2026 |
| 1.11.8-dev | 83 | 2/20/2026 |
| 1.10.4 | 89 | 2/14/2026 |
| 1.9.5 | 109 | 2/7/2026 |
| 1.9.4-dev | 91 | 2/6/2026 |
| 1.9.2-dev | 89 | 2/1/2026 |
| 1.8.7 | 108 | 1/26/2026 |
| 1.8.6 | 102 | 1/23/2026 |
| 1.8.4 | 103 | 1/22/2026 |
| 1.8.1-dev | 100 | 1/22/2026 |
| 1.7.25 | 89 | 1/19/2026 |
| 1.7.22 | 87 | 1/18/2026 |
| 1.7.20-dev | 98 | 1/18/2026 |
Loading failed