MrAdvice 2.14.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package MrAdvice --version 2.14.0                
NuGet\Install-Package MrAdvice -Version 2.14.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="MrAdvice" Version="2.14.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add MrAdvice --version 2.14.0                
#r "nuget: MrAdvice, 2.14.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 MrAdvice as a Cake Addin
#addin nuget:?package=MrAdvice&version=2.14.0

// Install MrAdvice as a Cake Tool
#tool nuget:?package=MrAdvice&version=2.14.0                

Mr. Advice

Summary

Mr. Advice is an open source (and free of charge) alternative to PostSharp (which is still far more advanced, see https://www.postsharp.net).
It intends to inject aspects at build-time. Advices are written in the form of attributes, and marking methods with them makes the pointcut, resulting in a nice and easy aspect injection.
More information about what is an aspect at Wikipedia.

Mr. Advice can weave assemblies for:

  • .NET framework ≥4.6.1 / Mono
  • .NET ≥5
  • .NET Standard 2.0

Mr. Advice allows you to:

  • Advise methods or parameters, at assembly, type, method or parameter level
  • Advice types (at assembly startup)
  • Introduce fields
  • Advise Mr. Advice (and this is BIG) at weaving-time (during build step), so you can rename methods as they are advised, add properties, etc.

How it works

It is available as a NuGet Status package. There is also an automatic build with tests at appveyor. The current status is Build status

Philosophy

Currently, MrAdvice won't bring you any aspect out-of-the-box. This means you'll have to write your own aspects (however you can see below other packages using Mr. Advice).
So it brings us to the next chapter, which is...

How to implement your own aspects

In a nutshell

Here is the minimal sample:

public class MyProudAdvice : Attribute, IMethodAdvice
{
    public void Advise(MethodAdviceContext context)
    {
        // do things you want here
        context.Proceed(); // this calls the original method
        // do other things here
    }
}

You then just need to mark the method(s) with the attribute and that's it, your aspect is injected!

[MyProudAdvice]
public void MyProudMethod()
{
}

More details

Your aspects can be injected at assembly, type or method level, simply by setting the attribute:

  • When an aspect is injected at asembly level, all methods of all types are weaved.
  • When the aspect is injected at type level, all of its methods are weaved.
  • And of course, if the aspect is injected on a method, only the method is weaved.

Other projects using Mr. Advice

NuGet packages:

Miscellaneous projects:

Project owner is picrap, feel free to drop a mail ✉️.
Project company is Arx One, a french company editor of backup software solutions.

Product Compatible and additional computed target framework versions.
.NET net5.0 is compatible.  net5.0-windows was computed.  net6.0 is compatible.  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.

This package has no dependencies.

NuGet packages (24)

Showing the top 5 NuGet packages that depend on MrAdvice:

Package Downloads
MrAdvice.Fody

Obsolete! Use https://www.nuget.org/packages/MrAdvice/ instead! MrAdvice allows to weave aspects at build-time (just like PostSharp, but free as in free beer). Write your own aspects in the form of attributes and apply them to target methods or properties.

ZLSoft.QWPlatform.SystemLibraryCore

公共类库组件

MrAdvice.MVVM

MrAdvice.MVVM is a lightweight MVVM library. It implements NotifyPropertyChanged, DependencyProperty (dependency and attached), A command binder and some threading management.

SD.AOP.Core

SD.AOP 面向方面编程基础

ArxOne.Persistence

A simple persistence library. Simply mark properties with attributes and they are persisted in registry.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.19.1 140 10 days ago
2.19.0 120 13 days ago
2.17.0 3,112 3 months ago
2.16.0 14,472 6 months ago
2.15.0 25,939 2/1/2024
2.14.0 1,650 1/8/2024
2.13.0 1,085 11/17/2023
2.12.2 4,121 5/12/2023
2.12.2-t1 618 5/12/2023
2.12.1 4,530 3/28/2023
2.12.0 10,609 3/11/2023
2.11.3 1,005 3/5/2023
2.11.2 712 3/5/2023
2.11.1 740 3/5/2023
2.11.0 692 3/5/2023
2.10.1 17,613 12/20/2022
2.10.0 821 12/19/2022
2.9.9 2,244 11/5/2022
2.9.8 5,644 9/21/2022
2.9.7 127,559 2/18/2022
2.9.6 1,337 1/28/2022
2.9.6-testing3 640 1/25/2022
2.9.6-testing2 616 1/24/2022
2.9.6-testing1 568 1/6/2022
2.9.5 6,218 12/18/2021
2.9.4 2,098 12/1/2021
2.9.3 847 11/27/2021
2.9.2 9,458 9/17/2021
2.9.1 2,286 8/1/2021
2.9.0 11,877 4/26/2021
2.9.0-test1 714 4/25/2021
2.8.12 59,002 12/24/2020
2.8.11 9,971 7/19/2020
2.8.10 11,184 2/16/2020
2.8.9-embed1 2,570 1/9/2020
2.8.8 30,725 10/5/2019
2.8.7 1,239 10/5/2019
2.8.6 8,355 9/6/2019
2.8.5 17,026 3/29/2019
2.8.4 2,608 3/27/2019
2.8.3 3,079 3/18/2019
2.8.2 39,794 11/29/2018
2.8.1 3,014 11/29/2018
2.8.0 2,709 11/28/2018
2.7.2 4,309 10/23/2018
2.7.1 2,689 10/23/2018
2.7.0 3,240 10/8/2018
2.6.0 10,463 9/24/2018
2.5.30 2,744 9/23/2018
2.5.29 2,691 9/21/2018
2.5.28 2,720 9/20/2018
2.5.27 2,710 9/20/2018
2.5.25 12,184 8/12/2018
2.5.24 26,309 2/13/2018
2.5.23 3,006 2/8/2018
2.5.22 3,021 2/8/2018
2.5.21 2,923 2/7/2018
2.5.20 2,993 2/2/2018
2.5.19 7,016 12/17/2017
2.5.18 3,016 12/17/2017
2.5.18-pre2 2,597 11/11/2017
2.5.18-pre 2,613 11/8/2017
2.5.18-exp4 2,790 12/17/2017
2.5.18-exp3 2,818 12/15/2017
2.5.17 21,157 11/1/2017
2.5.16 6,742 8/14/2017
2.5.15 3,274 8/12/2017
2.5.14 2,796 8/11/2017
2.5.13 2,895 8/10/2017
2.5.12 2,770 8/9/2017
2.5.11 2,889 8/7/2017
2.5.10 2,967 8/7/2017
2.5.9 2,891 8/6/2017
2.5.8 2,953 8/6/2017
2.5.7 2,796 8/6/2017
2.5.6 2,838 8/5/2017
2.5.5 2,869 8/5/2017
2.5.4 19,194 6/26/2017
2.5.3 2,963 6/25/2017
2.5.2 2,936 6/14/2017
2.5.1 2,980 5/24/2017
2.5.0 3,266 4/16/2017
2.4.8 5,680 3/15/2017
2.4.7 3,162 3/10/2017
2.4.6 2,889 3/10/2017
2.4.5 14,549 12/28/2016
2.4.4 2,982 12/27/2016
2.4.3 3,827 12/7/2016
2.4.2 2,944 12/3/2016
2.4.1 2,872 12/3/2016
2.4.1-test1 2,681 12/2/2016
2.4.0 2,977 11/25/2016
2.4.0-test5 2,686 11/24/2016
2.4.0-test4 2,730 11/23/2016
2.3.5 2,992 11/10/2016
2.3.5-pre1 3,089 11/8/2016
2.3.5-name1 2,765 11/10/2016
2.3.4 3,121 11/8/2016
2.3.2 3,043 11/7/2016
2.3.1 3,227 11/6/2016
2.2.0 3,293 11/5/2016
2.1.3 3,203 11/2/2016
2.1.2 2,982 10/24/2016
2.1.1 2,872 10/24/2016
2.1.0 3,114 10/22/2016
2.1.0-pre3 2,598 10/21/2016
2.1.0-pre2 2,681 10/20/2016
2.1.0-pre1 2,693 10/19/2016
2.0.22 2,998 10/19/2016
2.0.21 2,967 10/19/2016
2.0.20 2,922 10/18/2016
2.0.19 2,865 10/18/2016
2.0.18 2,962 10/18/2016
2.0.17 2,875 10/18/2016
2.0.16 2,842 10/17/2016
2.0.15 2,899 10/17/2016
2.0.14 2,915 10/17/2016
2.0.13 2,975 10/16/2016
2.0.12 2,973 10/16/2016
2.0.10 2,885 10/15/2016
2.0.9 2,931 10/14/2016
2.0.8 2,864 10/13/2016
2.0.7 2,919 10/13/2016
2.0.6 2,822 10/12/2016
2.0.5 2,778 10/8/2016
2.0.4 2,904 10/8/2016
2.0.3 2,852 10/8/2016
2.0.2 2,867 10/8/2016
2.0.1 2,879 10/8/2016
2.0.0 4,292 10/2/2016
2.0.0-alpha4 2,677 10/2/2016