Merge pull request #439 from mono-soc-2012/garyb/iconfix
[mono.git] / mcs / class / dlr / Runtime / Microsoft.Scripting.Core / Actions / IDynamicMetaObjectProvider.cs
1 /* ****************************************************************************
2  *
3  * Copyright (c) Microsoft Corporation. 
4  *
5  * This source code is subject to terms and conditions of the Apache License, Version 2.0. A 
6  * copy of the license can be found in the License.html file at the root of this distribution. If 
7  * you cannot locate the  Apache License, Version 2.0, please send an email to 
8  * dlr@microsoft.com. By using this source code in any fashion, you are agreeing to be bound 
9  * by the terms of the Apache License, Version 2.0.
10  *
11  * You must not remove this notice, or any other, from this software.
12  *
13  *
14  * ***************************************************************************/
15
16 #if FEATURE_CORE_DLR
17 using System.Linq.Expressions;
18 #else
19 using Microsoft.Scripting.Ast;
20 #endif
21
22 namespace System.Dynamic {
23     /// <summary>
24     /// Represents a dynamic object, that can have its operations bound at runtime.
25     /// </summary>
26     /// <remarks>
27     /// Objects that want to participate in the binding process should implement an IDynamicMetaObjectProvider interface,
28     /// and implement <see cref="IDynamicMetaObjectProvider.GetMetaObject" /> to return a <see cref="DynamicMetaObject" />.
29     /// </remarks>
30     public interface IDynamicMetaObjectProvider {
31         /// <summary>
32         /// Returns the <see cref="DynamicMetaObject" /> responsible for binding operations performed on this object.
33         /// </summary>
34         /// <param name="parameter">The expression tree representation of the runtime value.</param>
35         /// <returns>The <see cref="DynamicMetaObject" /> to bind this object.</returns>
36         DynamicMetaObject GetMetaObject(Expression parameter);
37     }
38 }