Riok.Mapperly 4.3.1

Prefix Reserved
There is a newer prerelease version of this package available.
See the version list below for details.
dotnet add package Riok.Mapperly --version 4.3.1
                    
NuGet\Install-Package Riok.Mapperly -Version 4.3.1
                    
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.3.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Riok.Mapperly" Version="4.3.1" />
                    
Directory.Packages.props
<PackageReference Include="Riok.Mapperly" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Riok.Mapperly --version 4.3.1
                    
#r "nuget: Riok.Mapperly, 4.3.1"
                    
#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.
#:package Riok.Mapperly@4.3.1
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Riok.Mapperly&version=4.3.1
                    
Install as a Cake Addin
#tool nuget:?package=Riok.Mapperly&version=4.3.1
                    
Install as a Cake Tool

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.ShouldBe(10);

Read the docs for any further information.

Release Channels

Mapperly is distributed through two release channels:

  • Stable Channel: Production-ready releases with full support for the latest release. Install the latest stable version for production use. Subject to semantic versioning (breaking changes only in major version bumps).
  • Next Channel: Preview releases with upcoming features and improvements. These versions may contain breaking changes and are not subject to semantic versioning. Use for testing and early access to new features.

Support Policy

Only the latest version released on the stable channel is fully supported. We strive to support all .NET versions that are currently supported by Microsoft.

Upgrading

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

Support

Need assistance with Mapperly or looking for consulting services? The riok team is available to help with:

  • Enterprise support and training
  • Architecture consultation
  • Custom feature development and integration support
  • Performance optimization and code reviews

Reach out through GitHub Discussions for questions, or contact the riok team directly for professional consulting services at hello@riok.ch. You can also support the project and get priority support through GitHub Sponsors.

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.  net10.0 was computed.  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. 
.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 (40)

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

Package Downloads
Volo.Abp.Mapperly

Package Description

Indice.Hive.Core

Package Description

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.

Rocket.Surgery.LaunchPad.Mapping

Package Description

Fanzoo.Kernel

An opinionated framework for building scalable web applications.

GitHub repositories (21)

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

Repository Stars
abpframework/abp
Open-source web application framework for ASP.NET Core! Offers an opinionated architecture to build enterprise software solutions with best practices on top of the .NET. Provides the fundamental infrastructure, cross-cutting-concern implementations, startup templates, application modules, UI themes, tooling and documentation.
martinothamar/Mediator
A high performance implementation of Mediator pattern in .NET using source generators.
velopack/velopack
Installer and automatic update framework for cross-platform desktop applications
bitfoundation/bitplatform
Build all of your apps using what you already know and love ❤️
lookup-foundation/RevitLookup
Interactive Revit RFA and RVT project database exploration tool to view and navigate BIM element parameters, properties and relationships.
Tim-Maes/Facet
Source generator that eliminates DTO boilerplate by auto-generating DTOs, mappings, and EF Core projections at compile time.
ThingsGateway/ThingsGateway
ThingsGateway is a cross-platform, high-performance gateway for edge data acquisition and IoT connectivity. Developed with .NET 8, it offers a suite of powerful tools, including advanced PLC communication libraries and debugging software.
mehdihadeli/food-delivery-microservices
🍔 A practical and cloud-native food delivery microservices, built with .Net Aspire, .Net 9, MassTransit, Domain-Driven Design, CQRS, Vertical Slice Architecture, Event-Driven Architecture, and the latest technologies.
yanpitangui/dotnet-api-boilerplate
A Dotnet 9.0 WebApi template project. MediatR, Swagger, Mapper, Serilog and more implemented.
nkdAgility/azure-devops-migration-tools
Azure DevOps Migration Tools allow you to migrate Teams, Backlogs, Work Items, Tasks, Test Cases, and Plans & Suits from one Project to another in Azure DevOps / TFS both within the same Organisation, and between Organisations.
josephnhtam/live-streaming-server-net
A .NET implementation of RTMP live streaming server, supporting HTTP-FLV, WebSocket-FLV, HLS, Kubernetes, cloud storage services integration and more.
mehdihadeli/vertical-slice-api-template
🍰 An asp.net core template based on .Net 9, Vertical Slice Architecture, CQRS, Minimal APIs, OpenTelemetry, API Versioning and OpenAPI.
svrooij/WinTuner
Package any app from Winget to Intune - WinTuner
higty/higlabo
HigLabo library provide 1.AI client library(OpenAI, Anthoripic, Groq) 2.Object Mapper(fastest in the world) 3.DbSharp(DAL generator) 4.Other.(Mail, Ftp, Utility...etc)
Azure/iotedge-lorawan-starterkit
Sample implementation of LoRaWAN components to connect LoRaWAN antenna gateway running IoT Edge directly with Azure IoT.
westonwalker/BlazorMinimalAPI
harrison314/BouncyHsm
Bouncy Hsm is a software simulator of HSM and smartcard simulator with HTML UI, REST API and PKCS#11 interface.
asesidaa/EXVS2-POC
Euterpe-org/Euterpe
Muse Dash Mod Manager
SapiensAnatis/Dawnshard
Server emulator for Dragalia Lost
Version Downloads Last Updated
5.0.0-next.0 1,152 12/24/2025
4.3.1 154,840 12/22/2025
4.3.1-next.0 1,540 12/4/2025
4.3.0 733,913 10/21/2025
4.3.0-next.6 2,788 10/15/2025
4.3.0-next.5 4,467 10/7/2025
4.3.0-next.4 3,220 9/18/2025
4.3.0-next.3 11,485 7/29/2025
4.3.0-next.2 16,155 6/16/2025
4.3.0-next.1 529 6/13/2025
4.3.0-next.0 2,132 5/27/2025
4.2.1 2,783,295 4/23/2025
4.2.1-next.2 251 4/21/2025
4.2.1-next.1 305 4/20/2025
4.2.1-next.0 1,164 4/8/2025
4.2.0 567,782 3/26/2025
4.2.0-next.2 1,984 3/18/2025
4.2.0-next.1 3,784 2/17/2025
4.2.0-next.0 84,367 1/20/2025
4.1.1 3,341,870 11/20/2024
4.1.1-next.0 30,170 11/5/2024
4.1.0 824,748 10/31/2024
4.1.0-next.3 278 10/29/2024
4.1.0-next.2 1,053 10/25/2024
4.1.0-next.1 1,339 10/14/2024
4.1.0-next.0 8,231 10/11/2024
4.0.0 353,883 10/11/2024
4.0.0-next.4 3,596 9/29/2024
4.0.0-next.3 33,086 8/13/2024
4.0.0-next.2 574 8/6/2024
4.0.0-next.1 15,818 6/30/2024
3.6.0 2,074,620 6/18/2024
3.6.0-next.2 4,616 6/3/2024
3.6.0-next.1 8,145 5/3/2024
3.5.1 661,999 4/23/2024
3.5.1-next.2 5,225 4/15/2024
3.5.1-next.1 321 4/9/2024
3.5.0 498,442 4/5/2024
3.5.0-next.4 1,648 3/27/2024
3.5.0-next.3 9,979 3/18/2024
3.5.0-next.2 49,580 3/11/2024
3.5.0-next.1 1,029 3/9/2024
3.4.0 533,921 2/23/2024
3.4.0-next.5 2,269 2/20/2024
3.4.0-next.4 973 2/16/2024
3.4.0-next.3 6,120 2/5/2024
3.4.0-next.2 25,573 1/10/2024
3.4.0-next.1 419 1/6/2024
3.3.1-next.1 3,050 12/18/2023
3.3.0 751,763 12/12/2023
3.3.0-next.6 1,105 12/6/2023
3.3.0-next.5 1,469 11/28/2023
3.3.0-next.4 2,857 11/22/2023
3.3.0-next.3 9,762 11/19/2023
3.3.0-next.2 4,328 10/26/2023
3.3.0-next.1 4,149 10/11/2023
3.2.0 838,996 9/18/2023
3.2.0-next.4 1,505 9/12/2023
3.2.0-next.3 592 9/11/2023
3.2.0-next.2 444 9/5/2023
3.2.0-next.1 597 8/29/2023
3.1.0 173,444 8/18/2023
3.1.0-next.2 214 8/18/2023
3.1.0-next.1 4,835 8/8/2023
3.0.0 48,180 8/7/2023
3.0.0-next.1 545 8/2/2023
2.9.0-next.4 8,074 7/26/2023
2.9.0-next.3 1,108 7/16/2023
2.9.0-next.2 5,199 6/13/2023
2.9.0-next.1 5,757 5/11/2023
2.8.0 737,715 4/27/2023
2.8.0-next.2 657 4/20/2023
2.8.0-next.1 20,795 3/23/2023
2.7.1-next.1 800 3/17/2023
2.7.0 203,720 3/13/2023
2.7.0-next.2 987 1/26/2023
2.7.0-next.1 757 1/23/2023
2.6.0 121,628 1/12/2023
2.6.0-next.4 254 1/11/2023
2.6.0-next.3 303 1/9/2023
2.6.0-next.2 449 12/14/2022
2.6.0-next.1 728 12/12/2022
2.5.0 99,951 10/12/2022
2.5.0-next.2 480 9/28/2022
2.5.0-next.1 393 9/19/2022
2.4.1-next.1 360 9/16/2022
2.4.0 22,611 9/8/2022
2.3.3 3,688 8/10/2022
2.3.2 1,464 8/9/2022
2.3.1 62,275 5/31/2022
2.3.0 2,980 5/16/2022
2.2.1 4,101 4/6/2022
2.2.0 1,828 3/15/2022
2.1.0 1,652 2/28/2022
2.0.0 1,889 2/21/2022

🐛 Bug Fixes

fix: Stackoverflow on readonly self reference by @faddiv in #1991

fix: use global prefix for enum parse invocation by @latonz in #2021

fix: call extension block methods correctly in inlined expression mappings by @latonz in #2051

fix: prevent reporting derived type on mapping from source by @faddiv in #2025

fix: support external mappings when auto user mappings are disabled by @faddiv in #2063

Full Changelog: https://github.com/riok/mapperly/compare/v4.3.0...v4.3.1