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

« back to all changes in this revision

Viewing changes to external/nrefactory/ICSharpCode.NRefactory/TypeSystem/Implementation/ExplicitInterfaceImplementationMemberReference.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 System.Linq;
 
22
 
 
23
namespace ICSharpCode.NRefactory.TypeSystem.Implementation
 
24
{
 
25
        /// <summary>
 
26
        /// References a member that is an explicit interface implementation.
 
27
        /// </summary>
 
28
        /// <remarks>
 
29
        /// Resolving an ExplicitInterfaceImplementationMemberReference requires a context
 
30
        /// that provides enough information for resolving the declaring type reference
 
31
        /// and the interface member reference.
 
32
        /// Note that the interface member reference is resolved in '<c>context.WithCurrentTypeDefinition(declaringType.GetDefinition())</c>'
 
33
        /// - this is done to ensure that open generics in the interface member reference resolve to the type parameters of the
 
34
        /// declaring type.
 
35
        /// </remarks>
 
36
        [Serializable]
 
37
        public sealed class ExplicitInterfaceImplementationMemberReference : IMemberReference
 
38
        {
 
39
                ITypeReference typeReference;
 
40
                IMemberReference interfaceMemberReference;
 
41
                
 
42
                public ExplicitInterfaceImplementationMemberReference(ITypeReference typeReference, IMemberReference interfaceMemberReference)
 
43
                {
 
44
                        if (typeReference == null)
 
45
                                throw new ArgumentNullException("typeReference");
 
46
                        if (interfaceMemberReference == null)
 
47
                                throw new ArgumentNullException("interfaceMemberReference");
 
48
                        this.typeReference = typeReference;
 
49
                        this.interfaceMemberReference = interfaceMemberReference;
 
50
                }
 
51
                
 
52
                public ITypeReference DeclaringTypeReference {
 
53
                        get { return typeReference; }
 
54
                }
 
55
                
 
56
                public IMember Resolve(ITypeResolveContext context)
 
57
                {
 
58
                        IType declaringType = typeReference.Resolve(context);
 
59
                        IMember interfaceMember = interfaceMemberReference.Resolve(context.WithCurrentTypeDefinition(declaringType.GetDefinition()));
 
60
                        if (interfaceMember == null)
 
61
                                return null;
 
62
                        IEnumerable<IMember> members;
 
63
                        if (interfaceMember.EntityType == EntityType.Accessor) {
 
64
                                members = declaringType.GetAccessors(
 
65
                                        m => m.IsExplicitInterfaceImplementation,
 
66
                                        GetMemberOptions.IgnoreInheritedMembers);
 
67
                        } else {
 
68
                                members = declaringType.GetMembers(
 
69
                                        m => m.EntityType == interfaceMember.EntityType && m.IsExplicitInterfaceImplementation,
 
70
                                        GetMemberOptions.IgnoreInheritedMembers);
 
71
                        }
 
72
                        return members.FirstOrDefault(m => m.ImplementedInterfaceMembers.Count == 1 && interfaceMember.Equals(m.ImplementedInterfaceMembers[0]));
 
73
                }
 
74
        }
 
75
}