Aspect that, when applied to a method, defines an exception handler around the whole method and calls a custom method in this exception handler.
Implements
Namespace: PostSharp.Aspects
Assembly: PostSharp.dll
Syntax
[AttributeUsage(AttributeTargets.Assembly|AttributeTargets.Class|AttributeTargets.Struct|AttributeTargets.Constructor|AttributeTargets.Method|AttributeTargets.Property|AttributeTargets.Event|AttributeTargets.Interface, AllowMultiple = true, Inherited = false)]
[MulticastAttributeUsage(MulticastTargets.Method|MulticastTargets.InstanceConstructor|MulticastTargets.StaticConstructor, TargetMemberAttributes = MulticastAttributes.AnyVisibility|MulticastAttributes.AnyScope|MulticastAttributes.NonAbstract|MulticastAttributes.Managed, AllowMultiple = true)]
[HasInheritedAttribute]
[AspectConfigurationAttributeType(typeof(OnExceptionAspectConfigurationAttribute))]
[Serializer(null)]
public abstract class OnExceptionAspect : MethodLevelAspect, IMethodLevelAspectBuildSemantics, IAspectBuildSemantics, IValidableAnnotation, IOnExceptionAspect, IMethodLevelAspect, IAspect
Remarks
The OnExceptionAspect aspect adds an exception handler to the method to which it is applied. It allows you to easily encapsulate exception handling policies as a custom attribute.
The most important method is OnException(MethodExecutionArgs). It is the exception handler in itself.
The current exception is available from the Exception property of the MethodExecutionArgs object. This property is read-only. If you need to replace the current exception by another one, you should throw a new exception from the handler. If you need to ignore the exception, set the FlowBehavior property to Continue.
An object of type MethodExecutionArgs is passed to every advice of this aspect. This object allows you to:
-
Get or set arguments.
Input and output arguments are available on the property
Arguments. You can change output (
out
) and by-reference (ref
) arguments, but not input arguments. If you need to modify arguments passed by value, consider using a MethodInterceptionAspect (see property Arguments). - Get the current exception. The current exception is available in the property Exception (only from the OnException(MethodExecutionArgs) advice). You can also replace the exception (see Exception for details).
- Get or set the return value. The return value is available in the ReturnValue property. You can also modify it.
- Change the method control flow. You can change the value of the FlowBehavior property to specify whether the target method should continue to execute after the execution of the current advice. This may be useful to implement a caching aspect or an exception handler.
- Share state between advices. You can use the MethodExecutionTag property to store state between the execution of different advices related to the same execution of a method. For instance, you can store a cache key in OnEntry(MethodExecutionArgs) and find it back in OnSuccess(MethodExecutionArgs). Using MethodExecutionTag is the only way to share state that is both thread-safe and reentrant.
note
All classes implementing IAspect should typically be marked as serializable using the SerializableAttribute or PSerializableAttribute custom attribute . Fields that are only used at runtime (and unknown at compile-time) should be carefully marked with the NonSerializedAttribute or PNonSerializedAttribute custom attribute. When PostSharp is used on a platform that does not support aspect serialization (such as .NET Compact Framework, Silverlight, or Windows Phone), or when another aspect serializer is used, it is not necessary to mark the aspect class as serializable. For more information, see Understanding Aspect Serialization .
Constructors
Name | Description |
---|---|
OnExceptionAspect() |
Properties
Name | Description |
---|---|
SemanticallyAdvisedMethodKinds | Determines which target methods will be advised semantically. This affects the behavior of the aspect when it's applied to iterator or async methods, which are compiled into state machines. |
UnsupportedTargetAction | Specifies the action to take when the aspect is applied to an unsupported target method. |
Methods
Name | Description |
---|---|
CreateAspectConfiguration() | Method invoked at build time to create a concrete AspectConfiguration instance specifically for the current Aspect type. |
GetExceptionType(MethodBase) | Gets the type of exception handled by this aspect. |
OnException(MethodExecutionArgs) | Method executed after the body of methods to which this aspect is applied,
in case that the method failed with an exception (i.e., in a |
SetAspectConfiguration(AspectConfiguration, MethodBase) | Method invoked at build time to set up an AspectConfiguration object according to the current Aspect instance and a specified target element of the current aspect. |