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

« back to all changes in this revision

Viewing changes to external/nrefactory/ICSharpCode.NRefactory/TypeSystem/Implementation/NestedTypeReference.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
 
 
21
namespace ICSharpCode.NRefactory.TypeSystem.Implementation
 
22
{
 
23
        /// <summary>
 
24
        /// Type reference used to reference nested types.
 
25
        /// </summary>
 
26
        [Serializable]
 
27
        public sealed class NestedTypeReference : ITypeReference, ISupportsInterning
 
28
        {
 
29
                readonly ITypeReference declaringTypeRef;
 
30
                readonly string name;
 
31
                readonly int additionalTypeParameterCount;
 
32
                
 
33
                /// <summary>
 
34
                /// Creates a new NestedTypeReference.
 
35
                /// </summary>
 
36
                /// <param name="declaringTypeRef">Reference to the declaring type.</param>
 
37
                /// <param name="name">Name of the nested class</param>
 
38
                /// <param name="additionalTypeParameterCount">Number of type parameters on the inner class (without type parameters on baseTypeRef)</param>
 
39
                /// <remarks>
 
40
                /// <paramref name="declaringTypeRef"/> must be exactly the (unbound) declaring type, not a derived type, not a parameterized type.
 
41
                /// NestedTypeReference thus always resolves to a type definition, never to (partially) parameterized types.
 
42
                /// </remarks>
 
43
                public NestedTypeReference(ITypeReference declaringTypeRef, string name, int additionalTypeParameterCount)
 
44
                {
 
45
                        if (declaringTypeRef == null)
 
46
                                throw new ArgumentNullException("declaringTypeRef");
 
47
                        if (name == null)
 
48
                                throw new ArgumentNullException("name");
 
49
                        this.declaringTypeRef = declaringTypeRef;
 
50
                        this.name = name;
 
51
                        this.additionalTypeParameterCount = additionalTypeParameterCount;
 
52
                }
 
53
                
 
54
                public ITypeReference DeclaringTypeReference {
 
55
                        get { return declaringTypeRef; }
 
56
                }
 
57
                
 
58
                public string Name {
 
59
                        get { return name; }
 
60
                }
 
61
                
 
62
                public int AdditionalTypeParameterCount {
 
63
                        get { return additionalTypeParameterCount; }
 
64
                }
 
65
                
 
66
                public IType Resolve(ITypeResolveContext context)
 
67
                {
 
68
                        ITypeDefinition declaringType = declaringTypeRef.Resolve(context) as ITypeDefinition;
 
69
                        if (declaringType != null) {
 
70
                                int tpc = declaringType.TypeParameterCount;
 
71
                                foreach (IType type in declaringType.NestedTypes) {
 
72
                                        if (type.Name == name && type.TypeParameterCount == tpc + additionalTypeParameterCount)
 
73
                                                return type;
 
74
                                }
 
75
                        }
 
76
                        return new UnknownType(null, name, additionalTypeParameterCount);
 
77
                }
 
78
                
 
79
                public override string ToString()
 
80
                {
 
81
                        if (additionalTypeParameterCount == 0)
 
82
                                return declaringTypeRef + "+" + name;
 
83
                        else
 
84
                                return declaringTypeRef + "+" + name + "`" + additionalTypeParameterCount;
 
85
                }
 
86
                
 
87
                int ISupportsInterning.GetHashCodeForInterning()
 
88
                {
 
89
                        return declaringTypeRef.GetHashCode() ^ name.GetHashCode() ^ additionalTypeParameterCount;
 
90
                }
 
91
                
 
92
                bool ISupportsInterning.EqualsForInterning(ISupportsInterning other)
 
93
                {
 
94
                        NestedTypeReference o = other as NestedTypeReference;
 
95
                        return o != null && declaringTypeRef == o.declaringTypeRef && name == o.name && additionalTypeParameterCount == o.additionalTypeParameterCount;
 
96
                }
 
97
        }
 
98
}