Riok.Mapperly 4.2.0-next.0

Prefix Reserved
This is a prerelease version of Riok.Mapperly.
dotnet add package Riok.Mapperly --version 4.2.0-next.0                
NuGet\Install-Package Riok.Mapperly -Version 4.2.0-next.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Riok.Mapperly" Version="4.2.0-next.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Riok.Mapperly --version 4.2.0-next.0                
#r "nuget: Riok.Mapperly, 4.2.0-next.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Riok.Mapperly as a Cake Addin
#addin nuget:?package=Riok.Mapperly&version=4.2.0-next.0&prerelease

// Install Riok.Mapperly as a Cake Tool
#tool nuget:?package=Riok.Mapperly&version=4.2.0-next.0&prerelease                

Mapperly

Nuget Nuget Preview License Downloads GitHub Sponsors GitHub

Mapperly is a .NET source generator for generating object mappings.

Because Mapperly creates the mapping code at build time, there is minimal overhead at runtime. Even better, the generated code is perfectly readable, allowing you to verify the generated mapping code easily.

Documentation

The documentation is available here.

Quickstart

Installation

Add the NuGet Package to your project:

dotnet add package Riok.Mapperly

Create your first mapper

Create a mapper declaration as a partial class and apply the Riok.Mapperly.Abstractions.MapperAttribute attribute. Mapperly generates mapping method implementations for the defined mapping methods in the mapper.

// Mapper declaration
[Mapper]
public partial class CarMapper
{
    public partial CarDto CarToCarDto(Car car);
}

// Mapper usage
var mapper = new CarMapper();
var car = new Car { NumberOfSeats = 10, ... };
var dto = mapper.CarToCarDto(car);
dto.NumberOfSeats.Should().Be(10);

Read the docs for any further information.

Upgrading

Find a list of breaking changes for each major version and upgrade guides here.

How To Contribute

We would love for you to contribute to Mapperly and help make it even better than it is today! Find information on how to contribute in the docs.

License

Mapperly is Apache 2.0 licensed.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .NETStandard 2.0

    • No dependencies.

NuGet packages (16)

Showing the top 5 NuGet packages that depend on Riok.Mapperly:

Package Downloads
Rocket.Surgery.LaunchPad.Mapping

Package Description

Indice.Hive.Core

Package Description

Fanzoo.Kernel

An opinionated framework for building scalable web applications.

AssemblyAI

The AssemblyAI C# .NET SDK provides an easy-to-use interface for interacting with the AssemblyAI API, which supports async and real-time transcription, audio intelligence models, as well as the latest LeMUR models.

Eternet.AspNetCore.DocumentDb.Crud

AspNet Core DocumentDb CRUD framework using Marten for Document DB and Events Store

GitHub repositories (17)

Showing the top 5 popular GitHub repositories that depend on Riok.Mapperly:

Repository Stars
riok/mapperly
A .NET source generator for generating object mappings. No runtime reflection.
martinothamar/Mediator
A high performance implementation of Mediator pattern in .NET using source generators.
bitfoundation/bitplatform
Build all of your apps using what you already know and love ❤️
ldqk/Masuit.MyBlogs
基于C#/.NET8的 masuit.org个人博客站项目源码,https://masuit.org ,供参考、学习、引用、非商业性质的部署。
neozhu/CleanArchitectureWithBlazorServer
This is a repository for creating a Blazor Server dashboard application following the principles of Clean Architecture
Version Downloads Last updated
4.2.0-next.0 181 1/20/2025
4.1.1 229,056 11/20/2024
4.1.1-next.0 6,418 11/5/2024
4.1.0 184,512 10/31/2024
4.1.0-next.3 141 10/29/2024
4.1.0-next.2 968 10/25/2024
4.1.0-next.1 627 10/14/2024
4.1.0-next.0 1,643 10/11/2024
4.0.0 143,087 10/11/2024
4.0.0-next.4 1,962 9/29/2024
4.0.0-next.3 15,090 8/13/2024
4.0.0-next.2 487 8/6/2024
4.0.0-next.1 5,268 6/30/2024
3.6.0 1,052,124 6/18/2024
3.6.0-next.2 1,831 6/3/2024
3.6.0-next.1 5,610 5/3/2024
3.5.1 442,312 4/23/2024
3.5.1-next.2 1,862 4/15/2024
3.5.1-next.1 235 4/9/2024
3.5.0 271,233 4/5/2024
3.5.0-next.4 1,232 3/27/2024
3.5.0-next.3 9,615 3/18/2024
3.5.0-next.2 18,991 3/11/2024
3.5.0-next.1 654 3/9/2024
3.4.0 384,986 2/23/2024
3.4.0-next.5 1,662 2/20/2024
3.4.0-next.4 898 2/16/2024
3.4.0-next.3 4,405 2/5/2024
3.4.0-next.2 19,860 1/10/2024
3.4.0-next.1 335 1/6/2024
3.3.1-next.1 2,938 12/18/2023
3.3.0 576,806 12/12/2023
3.3.0-next.6 1,025 12/6/2023
3.3.0-next.5 1,387 11/28/2023
3.3.0-next.4 2,584 11/22/2023
3.3.0-next.3 7,854 11/19/2023
3.3.0-next.2 3,483 10/26/2023
3.3.0-next.1 3,738 10/11/2023
3.2.0 667,816 9/18/2023
3.2.0-next.4 1,404 9/12/2023
3.2.0-next.3 467 9/11/2023
3.2.0-next.2 348 9/5/2023
3.2.0-next.1 488 8/29/2023
3.1.0 153,605 8/18/2023
3.1.0-next.2 116 8/18/2023
3.1.0-next.1 4,592 8/8/2023
3.0.0 41,567 8/7/2023
3.0.0-next.1 369 8/2/2023
2.9.0-next.4 6,887 7/26/2023
2.9.0-next.3 763 7/16/2023
2.9.0-next.2 5,071 6/13/2023
2.9.0-next.1 5,574 5/11/2023
2.8.0 563,382 4/27/2023
2.8.0-next.2 527 4/20/2023
2.8.0-next.1 17,562 3/23/2023
2.7.1-next.1 667 3/17/2023
2.7.0 173,530 3/13/2023
2.7.0-next.2 839 1/26/2023
2.7.0-next.1 618 1/23/2023
2.6.0 93,702 1/12/2023
2.6.0-next.4 121 1/11/2023
2.6.0-next.3 178 1/9/2023
2.6.0-next.2 299 12/14/2022
2.6.0-next.1 576 12/12/2022
2.5.0 86,415 10/12/2022
2.5.0-next.2 344 9/28/2022
2.5.0-next.1 245 9/19/2022
2.4.1-next.1 213 9/16/2022
2.4.0 20,128 9/8/2022
2.3.3 3,100 8/10/2022
2.3.2 924 8/9/2022
2.3.1 61,607 5/31/2022
2.3.0 2,425 5/16/2022
2.2.1 3,544 4/6/2022
2.2.0 1,269 3/15/2022
2.1.0 1,083 2/28/2022
2.0.0 1,170 2/21/2022

🚀 Features

Separate RequiredMappingStrategy configuration for enums by @jacob-buckaroo in #1591

Diagnostic for mapping null mismatch by @jorisBarkema in #1612, #1592

Add support for From and To method conversions (#1117) by @TonEnfer in #1616

🐛 Bug Fixes

missing global alias on method argument in inlined user-implemented method #1629 by @TonEnfer in #1630

initialize nullable members for nested containers by @clegoz in #1660

only diagnostic missing member mappings for required init members by @latonz in #1686

Full Changelog: https://github.com/riok/mapperly/compare/v4.1.1...v4.2.0-next.0