eQuantic.Mapper.Generator
1.4.0
dotnet add package eQuantic.Mapper.Generator --version 1.4.0
NuGet\Install-Package eQuantic.Mapper.Generator -Version 1.4.0
<PackageReference Include="eQuantic.Mapper.Generator" Version="1.4.0" />
paket add eQuantic.Mapper.Generator --version 1.4.0
#r "nuget: eQuantic.Mapper.Generator, 1.4.0"
// Install eQuantic.Mapper.Generator as a Cake Addin #addin nuget:?package=eQuantic.Mapper.Generator&version=1.4.0 // Install eQuantic.Mapper.Generator as a Cake Tool #tool nuget:?package=eQuantic.Mapper.Generator&version=1.4.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 override Before
or/and After
methods:
[Mapper(typeof(ExampleA), typeof(ExampleB))]
public partial class ExampleMapper : IMapper
{
partial void AfterMap(ExampleA source, ExampleB destination)
{
if(source.Name == "Test")
{
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.4.0 | 763 | 9/18/2024 |
1.3.6 | 323 | 7/23/2024 |
1.3.5 | 113 | 7/22/2024 |
1.3.4 | 100 | 7/22/2024 |
1.3.3 | 105 | 7/22/2024 |
1.3.2 | 140 | 7/20/2024 |
1.3.1 | 111 | 7/15/2024 |
1.3.0 | 149 | 7/1/2024 |
1.2.8 | 139 | 6/28/2024 |
1.2.7 | 128 | 6/28/2024 |
1.2.6 | 112 | 6/28/2024 |
1.2.5 | 120 | 6/28/2024 |
1.2.4 | 369 | 5/5/2024 |
1.2.3 | 132 | 5/4/2024 |
1.2.2 | 116 | 5/4/2024 |
1.2.1 | 130 | 5/3/2024 |
1.2.0 | 89 | 5/3/2024 |
1.1.9 | 155 | 4/23/2024 |
1.1.8 | 123 | 4/23/2024 |
1.1.7 | 118 | 4/23/2024 |
1.1.6 | 125 | 4/23/2024 |
1.1.5 | 505 | 11/18/2023 |
1.1.4 | 440 | 8/2/2023 |
1.1.3 | 212 | 7/15/2023 |
1.1.2 | 189 | 7/15/2023 |
1.1.1 | 179 | 7/15/2023 |
1.1.0 | 305 | 5/18/2023 |
1.0.0 | 212 | 1/8/2023 |
DTOs mapping without reflection