1 | // Copyright (c) 2010-2013 AlphaSierraPapa for the SharpDevelop Team |
---|
2 | // |
---|
3 | // Permission is hereby granted, free of charge, to any person obtaining a copy of this |
---|
4 | // software and associated documentation files (the "Software"), to deal in the Software |
---|
5 | // without restriction, including without limitation the rights to use, copy, modify, merge, |
---|
6 | // publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons |
---|
7 | // to whom the Software is furnished to do so, subject to the following conditions: |
---|
8 | // |
---|
9 | // The above copyright notice and this permission notice shall be included in all copies or |
---|
10 | // substantial portions of the Software. |
---|
11 | // |
---|
12 | // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, |
---|
13 | // INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR |
---|
14 | // PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE |
---|
15 | // FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR |
---|
16 | // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER |
---|
17 | // DEALINGS IN THE SOFTWARE. |
---|
18 | |
---|
19 | using System; |
---|
20 | using System.Collections.Generic; |
---|
21 | using ICSharpCode.NRefactory.Semantics; |
---|
22 | using ICSharpCode.NRefactory.TypeSystem; |
---|
23 | |
---|
24 | namespace ICSharpCode.NRefactory.CSharp.Resolver |
---|
25 | { |
---|
26 | /// <summary> |
---|
27 | /// Represents an anonymous method or lambda expression. |
---|
28 | /// Note: the lambda has no type. |
---|
29 | /// To retrieve the delegate type, look at the anonymous function conversion. |
---|
30 | /// </summary> |
---|
31 | public abstract class LambdaResolveResult : ResolveResult |
---|
32 | { |
---|
33 | protected LambdaResolveResult() : base(SpecialType.UnknownType) |
---|
34 | { |
---|
35 | } |
---|
36 | |
---|
37 | /// <summary> |
---|
38 | /// Gets whether there is a parameter list. |
---|
39 | /// This property always returns true for C# 3.0-lambdas, but may return false |
---|
40 | /// for C# 2.0 anonymous methods. |
---|
41 | /// </summary> |
---|
42 | public abstract bool HasParameterList { get; } |
---|
43 | |
---|
44 | /// <summary> |
---|
45 | /// Gets whether this lambda is using the C# 2.0 anonymous method syntax. |
---|
46 | /// </summary> |
---|
47 | public abstract bool IsAnonymousMethod { get; } |
---|
48 | |
---|
49 | /// <summary> |
---|
50 | /// Gets whether the lambda parameters are implicitly typed. |
---|
51 | /// </summary> |
---|
52 | /// <remarks>This property returns false for anonymous methods without parameter list.</remarks> |
---|
53 | public abstract bool IsImplicitlyTyped { get; } |
---|
54 | |
---|
55 | /// <summary> |
---|
56 | /// Gets whether the lambda is async. |
---|
57 | /// </summary> |
---|
58 | public abstract bool IsAsync { get; } |
---|
59 | |
---|
60 | /// <summary> |
---|
61 | /// Gets the return type inferred when the parameter types are inferred to be <paramref name="parameterTypes"/> |
---|
62 | /// </summary> |
---|
63 | /// <remarks> |
---|
64 | /// This method determines the return type inferred from the lambda body, which is used as part of C# type inference. |
---|
65 | /// Use the <see cref="ReturnType"/> property to retrieve the actual return type as determined by the target delegate type. |
---|
66 | /// </remarks> |
---|
67 | public abstract IType GetInferredReturnType(IType[] parameterTypes); |
---|
68 | |
---|
69 | /// <summary> |
---|
70 | /// Gets the list of parameters. |
---|
71 | /// </summary> |
---|
72 | public abstract IList<IParameter> Parameters { get; } |
---|
73 | |
---|
74 | /// <summary> |
---|
75 | /// Gets the return type of the lambda. |
---|
76 | /// |
---|
77 | /// If the lambda is async, the return type includes <code>Task<T></code> |
---|
78 | /// </summary> |
---|
79 | public abstract IType ReturnType { get; } |
---|
80 | |
---|
81 | /// <summary> |
---|
82 | /// Gets whether the lambda body is valid for the given parameter types and return type. |
---|
83 | /// </summary> |
---|
84 | /// <returns> |
---|
85 | /// Produces a conversion with <see cref="Conversion.IsAnonymousFunctionConversion"/>=<c>true</c> if the lambda is valid; |
---|
86 | /// otherwise returns <see cref="Conversion.None"/>. |
---|
87 | /// </returns> |
---|
88 | public abstract Conversion IsValid(IType[] parameterTypes, IType returnType, CSharpConversions conversions); |
---|
89 | |
---|
90 | /// <summary> |
---|
91 | /// Gets the resolve result for the lambda body. |
---|
92 | /// Returns a resolve result for 'void' for statement lambdas. |
---|
93 | /// </summary> |
---|
94 | public abstract ResolveResult Body { get; } |
---|
95 | |
---|
96 | public override IEnumerable<ResolveResult> GetChildResults() |
---|
97 | { |
---|
98 | return new [] { this.Body }; |
---|
99 | } |
---|
100 | } |
---|
101 | } |
---|