eQuantic.Mapper.Generator
1.7.0
dotnet add package eQuantic.Mapper.Generator --version 1.7.0
NuGet\Install-Package eQuantic.Mapper.Generator -Version 1.7.0
<PackageReference Include="eQuantic.Mapper.Generator" Version="1.7.0" />
<PackageVersion Include="eQuantic.Mapper.Generator" Version="1.7.0" />
<PackageReference Include="eQuantic.Mapper.Generator" />
paket add eQuantic.Mapper.Generator --version 1.7.0
#r "nuget: eQuantic.Mapper.Generator, 1.7.0"
#addin nuget:?package=eQuantic.Mapper.Generator&version=1.7.0
#tool nuget:?package=eQuantic.Mapper.Generator&version=1.7.0
eQuantic.Mapper Library
The eQuantic Mapper provides all the implementation needed to use the Mapper Pattern
To install eQuantic.Mapper, run the following command in the Package Manager Console
Install-Package eQuantic.Mapper
If you choose to use generated mappers, install the Generator package below
Install-Package eQuantic.Mapper.Generator
Example of implementation
The models
public class ExampleA
{
public string Id { get; set; } = string.Empty;
public string Name { get; set; } = string.Empty;
public string Date { get; set; } = string.Empty;
}
public class ExampleB
{
public int Id { get; set; }
public string Name { get; set; } = string.Empty;
public DateTime Date { get; set; }
[MapFrom(typeof(ExampleA), nameof(ExampleA.Id))]
public string Code { get; set; } = string.Empty;
}
The mapper
public class ExampleMapper : IMapper<ExampleA, ExampleB>
{
public ExampleB? Map(ExampleA? source)
{
return Map(source, new ExampleB());
}
public ExampleB? Map(ExampleA? source, ExampleB? destination)
{
if (source == null)
{
return null;
}
if (destination == null)
{
return Map(source);
}
destination.Id = source.Id;
destination.Name = source.Name;
destination.Date = source.Date;
return destination;
}
}
The mapper with context
public class ExampleContext
{
public string Code { get; set; }
}
public class ExampleMapper : IMapper<ExampleA, ExampleB, ExampleContext>
{
public ExampleContext Context { get; set; }
public ExampleB? Map(ExampleA? source)
{
return Map(source, new ExampleB());
}
public ExampleB? Map(ExampleA? source, ExampleB? destination)
{
if (source == null)
{
return null;
}
if (destination == null)
{
return Map(source);
}
destination.Id = source.Id;
destination.Name = source.Name;
destination.Date = source.Date;
if(!string.IsNullOrEmpty(Context.Code))
{
destination.Code = Context.Code;
}
return destination;
}
}
Auto-Generated Code
If you want that the mapper to be auto-generated, you need to use the MapperAttribute
and partial
definition into the class mapper
[Mapper(typeof(ExampleA), typeof(ExampleB))]
public partial class ExampleMapper : IMapper
{
}
or
[Mapper(typeof(ExampleA), typeof(ExampleB))]
public partial class AsyncExampleMapper : IAsyncMapper
{
}
The application
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddMappers();
var app = builder.Build();
app.MapGet("/", (IMapperFactory mapperFactory) =>
{
var mapper = mapperFactory.GetMapper<ExampleA, ExampleB>()!;
var exampleA = new ExampleA
{
Id = "1",
Name = "Test",
Date = "2023-01-01"
};
var exampleB = mapper.Map(exampleA);
return exampleB;
});
app.Run();
Manual customization
If you need customize the auto-generated mapper, just create delegations for OnBeforeMap
or/and OnAfterMap
events:
[Mapper(typeof(ExampleA), typeof(ExampleB))]
public partial class ExampleMapper : IMapper
{
partial void AfterConstructor()
{
OnAfterMap += (s, e) =>
{
if(e.Source.Name == "Test")
{
e.Destination.Name = "Empty";
}
};
}
}
If you need to modify the generated constructor, just set OmitConstructor
on attribute and create the new one:
[Mapper(typeof(ExampleA), typeof(ExampleB), OmitConstructor = true)]
public partial class ExampleMapper : IMapper
{
public ExampleMapper(IMapperFactory mapperFactory)
{
MapperFactory = mapperFactory;
OnAfterMap += (s, e) =>
{
if(e.Source.Name == "Test")
{
e.Destination.Name = "Empty";
}
};
}
}
Debugging
Inside MapperGenerator
on Initialize
method use:
#if DEBUG
SpinWait.SpinUntil(() => Debugger.IsAttached);
#endif
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- No dependencies.
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 |
---|---|---|
1.7.0 | 206 | 5/29/2025 |
1.6.3 | 156 | 5/27/2025 |
1.6.2 | 142 | 5/26/2025 |
1.6.1 | 137 | 5/10/2025 |
1.6.0 | 181 | 2/23/2025 |
1.5.1 | 250 | 1/20/2025 |
1.5.0 | 102 | 1/20/2025 |
1.4.0 | 954 | 9/18/2024 |
1.3.6 | 359 | 7/23/2024 |
1.3.5 | 134 | 7/22/2024 |
1.3.4 | 124 | 7/22/2024 |
1.3.3 | 129 | 7/22/2024 |
1.3.2 | 160 | 7/20/2024 |
1.3.1 | 131 | 7/15/2024 |
1.3.0 | 169 | 7/1/2024 |
1.2.8 | 159 | 6/28/2024 |
1.2.7 | 147 | 6/28/2024 |
1.2.6 | 133 | 6/28/2024 |
1.2.5 | 142 | 6/28/2024 |
1.2.4 | 391 | 5/5/2024 |
1.2.3 | 152 | 5/4/2024 |
1.2.2 | 139 | 5/4/2024 |
1.2.1 | 156 | 5/3/2024 |
1.2.0 | 111 | 5/3/2024 |
1.1.9 | 177 | 4/23/2024 |
1.1.8 | 154 | 4/23/2024 |
1.1.7 | 136 | 4/23/2024 |
1.1.6 | 145 | 4/23/2024 |
1.1.5 | 520 | 11/18/2023 |
1.1.4 | 461 | 8/2/2023 |
1.1.3 | 231 | 7/15/2023 |
1.1.2 | 211 | 7/15/2023 |
1.1.1 | 200 | 7/15/2023 |
1.1.0 | 335 | 5/18/2023 |
1.0.0 | 242 | 1/8/2023 |
DTOs mapping without reflection