~ubuntu-branches/ubuntu/trusty/monodevelop/trusty-proposed

« back to all changes in this revision

Viewing changes to external/nrefactory/ICSharpCode.NRefactory.CSharp/Resolver/LambdaResolveResult.cs

  • Committer: Package Import Robot
  • Author(s): Jo Shields
  • Date: 2013-05-12 09:46:03 UTC
  • mto: This revision was merged to the branch mainline in revision 29.
  • Revision ID: package-import@ubuntu.com-20130512094603-mad323bzcxvmcam0
Tags: upstream-4.0.5+dfsg
Import upstream version 4.0.5+dfsg

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
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
                public abstract IType GetInferredReturnType(IType[] parameterTypes);
 
64
                
 
65
                /// <summary>
 
66
                /// Gets the list of parameters.
 
67
                /// </summary>
 
68
                public abstract IList<IParameter> Parameters { get; }
 
69
                
 
70
                /// <summary>
 
71
                /// Gets whether the lambda body is valid for the given parameter types and return type.
 
72
                /// </summary>
 
73
                /// <returns>
 
74
                /// Produces a conversion with <see cref="Conversion.IsAnonymousFunctionConversion"/>=<c>true</c> if the lambda is valid;
 
75
                /// otherwise returns <see cref="Conversion.None"/>.
 
76
                /// </returns>
 
77
                public abstract Conversion IsValid(IType[] parameterTypes, IType returnType, CSharpConversions conversions);
 
78
                
 
79
                /// <summary>
 
80
                /// Gets the resolve result for the lambda body.
 
81
                /// Returns a resolve result for 'void' for statement lambdas.
 
82
                /// </summary>
 
83
                public abstract ResolveResult Body { get; }
 
84
                
 
85
                public override IEnumerable<ResolveResult> GetChildResults()
 
86
                {
 
87
                        return new [] { this.Body };
 
88
                }
 
89
        }
 
90
}