eQuantic.Mapper.Generator
1.1.4
See the version list below for details.
dotnet add package eQuantic.Mapper.Generator --version 1.1.4
NuGet\Install-Package eQuantic.Mapper.Generator -Version 1.1.4
<PackageReference Include="eQuantic.Mapper.Generator" Version="1.1.4"> <PrivateAssets>all</PrivateAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets> </PackageReference>
paket add eQuantic.Mapper.Generator --version 1.1.4
#r "nuget: eQuantic.Mapper.Generator, 1.1.4"
// Install eQuantic.Mapper.Generator as a Cake Addin #addin nuget:?package=eQuantic.Mapper.Generator&version=1.1.4 // Install eQuantic.Mapper.Generator as a Cake Tool #tool nuget:?package=eQuantic.Mapper.Generator&version=1.1.4
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
{
}
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.
This package has 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 | 596 | 9/18/2024 |
1.3.6 | 320 | 7/23/2024 |
1.3.5 | 108 | 7/22/2024 |
1.3.4 | 97 | 7/22/2024 |
1.3.3 | 102 | 7/22/2024 |
1.3.2 | 134 | 7/20/2024 |
1.3.1 | 106 | 7/15/2024 |
1.3.0 | 144 | 7/1/2024 |
1.2.8 | 135 | 6/28/2024 |
1.2.7 | 123 | 6/28/2024 |
1.2.6 | 108 | 6/28/2024 |
1.2.5 | 116 | 6/28/2024 |
1.2.4 | 366 | 5/5/2024 |
1.2.3 | 129 | 5/4/2024 |
1.2.2 | 113 | 5/4/2024 |
1.2.1 | 127 | 5/3/2024 |
1.2.0 | 86 | 5/3/2024 |
1.1.9 | 154 | 4/23/2024 |
1.1.8 | 120 | 4/23/2024 |
1.1.7 | 117 | 4/23/2024 |
1.1.6 | 124 | 4/23/2024 |
1.1.5 | 504 | 11/18/2023 |
1.1.4 | 439 | 8/2/2023 |
1.1.3 | 211 | 7/15/2023 |
1.1.2 | 188 | 7/15/2023 |
1.1.1 | 178 | 7/15/2023 |
1.1.0 | 302 | 5/18/2023 |
1.0.0 | 210 | 1/8/2023 |
DTOs mapping without reflection