MetalamaAPI documentationPost­Sharp API migrationPost­Sharp.​AspectsILocation­Binding
Open sandboxFocus

ILocationBinding Interface

In PostSharp, a binding was a run-time object that allowed the run-time code of the aspect to call the target code. In Metalama, aspects no longer have run-time code. Instead, they have templates that are expanded at compile time and generate run-time code. Templates can generate run-time code that accesses target code using dynamic code or invokers. For fields and properties, use meta.Target.FieldOrProperty.Value.

Namespace: PostSharp.Aspects
Assembly: Metalama.Migration.dll
public interface ILocationBinding


Name Description

There is no equivalent in Metalama.


In Metalama, use meta.Target.FieldOrProperty. If you need a run-time object, use IFieldOrProperty.ToFieldOrPropertyInfo().


In Metalama, use meta.Target.FieldOrProperty.Type>. If you need a run-time object, use IType.ToType().


Name Description
Execute<TPayload>(ILocationBindingAction<TPayload>, ref TPayload)

There is no equivalent in Metalama.

GetValue(ref Object, Arguments)

In Metalama, get meta.Target.FieldOrProperty.Value.

SetValue(ref Object, Arguments, Object)

In Metalama, set meta.Target.FieldOrProperty.Value.

Extension Methods

LocationBindingExtensions.GetValue(ILocationBinding, Object, Arguments)
LocationBindingExtensions.GetValue(ILocationBinding, Object)
LocationBindingExtensions.SetValue(ILocationBinding, Object, Arguments, Object)
LocationBindingExtensions.SetValue(ILocationBinding, Object, Object)