-
Notifications
You must be signed in to change notification settings - Fork 45
ImplementingAdvices
Pascal Craponne edited this page Sep 27, 2015
·
8 revisions
#Implementing advices
##A very small theory on it
In our implementation:
- The advices are attribute implementations
- The pointcuts are attributes applied to method, property, type or assembly
##Let's get practical
###Method advices
Here is a first method advice:
public class ADummyMethodAdvice : Attribute, IMethodAdvice
{
// your only duty is to implement the method below...
public void Advise(MethodAdviceContext context)
{
// ... and optionnally call the original method (this is usually a good idea)
context.Proceed();
}
}
Some special method advices are propery advices:
public class ADummyPropertyAdvice : Attribute, IPropertyAdvice
{
public void Advise(PropertyAdviceContext context)
{
if(context.IsGetter)
{
context.Proceed();
// you can check the return value here, by using context.ReturnValue
}
else
{
// you can check the setter value here, by using context.Value
context.Proceed()
}
}
}
There is also a specialization for parameter advices (please note that parameter advices can be applied at method level, in which case they apply to all method parameters):
public class ADummyParameterAdvice : Attribute, IParameterAdvice
{
public void Advise(ParameterAdviceContext context)
{
if (context.IsIn)
{
// input or ref parameters can be checked here
}
context.Proceed();
if (context.IsOut)
{
// output or ref parameters and return value can be checked here
}
}
}
###Info advices
A method info advice
public class ADummyMethodInfoAdvice : Attribute, IMethodInfoAdvice
{
public void Advise(MethodInfoAdviceContext context)
{
// do what you want here
}
}
And a property info advice:
public class ADummyPropertyInfoAdvice : Attribute, IPropertyInfoAdvice
{
public void Advise(PropertyInfoAdviceContext context)
{
// do what you want here
}
}
###Weaving advices
public class MethodWeavingAdvice : Attribute, IMethodWeavingAdvice
{
public void Advise(MethodWeavingContext context)
{
// we add a property, named after the target method.
context.AddPublicAutoProperty(context.TargetMethodName + "_Friend", typeof(string));
// and we also renamed the target method. All calls are preserved.
context.TargetMethodName += "_Renamed";
// also, extra initializers can be added to target class
// those initializeds will be invoked at the end of constructors
context.AddInitializer(Initializer);
}
public static void Initializer(object instance)
{
// you can add extra initialization from here
}
}
###End of part one (their greatest hits)
Please note that a single class can implement multiple advice interfaces (info advice and method advice, for example).
You can now learn how to use those advices.
Mr. Advice is sponsored by Arx One and available as a NuGet package