mirror of https://github.com/icsharpcode/ILSpy.git
				
				
			
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							131 lines
						
					
					
						
							5.0 KiB
						
					
					
				
			
		
		
	
	
							131 lines
						
					
					
						
							5.0 KiB
						
					
					
				// Copyright (c) 2010-2013 AlphaSierraPapa for the SharpDevelop Team | 
						|
//  | 
						|
// Permission is hereby granted, free of charge, to any person obtaining a copy of this | 
						|
// software and associated documentation files (the "Software"), to deal in the Software | 
						|
// without restriction, including without limitation the rights to use, copy, modify, merge, | 
						|
// publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons | 
						|
// to whom the Software is furnished to do so, subject to the following conditions: | 
						|
//  | 
						|
// The above copyright notice and this permission notice shall be included in all copies or | 
						|
// substantial portions of the Software. | 
						|
//  | 
						|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, | 
						|
// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR | 
						|
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE | 
						|
// FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR | 
						|
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER | 
						|
// DEALINGS IN THE SOFTWARE. | 
						|
 | 
						|
#nullable enable | 
						|
 | 
						|
using System.Collections.Generic; | 
						|
 | 
						|
namespace ICSharpCode.Decompiler.TypeSystem | 
						|
{ | 
						|
	public interface IMemberReference | 
						|
	{ | 
						|
		/// <summary> | 
						|
		/// Gets the declaring type reference for the member. | 
						|
		/// </summary> | 
						|
		ITypeReference DeclaringTypeReference { get; } | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Resolves the member. | 
						|
		/// </summary> | 
						|
		/// <param name="context"> | 
						|
		/// Context to use for resolving this member reference. | 
						|
		/// Which kind of context is required depends on the which kind of member reference this is; | 
						|
		/// please consult the documentation of the method that was used to create this member reference, | 
						|
		/// or that of the class implementing this method. | 
						|
		/// </param> | 
						|
		/// <returns> | 
						|
		/// Returns the resolved member, or <c>null</c> if the member could not be found. | 
						|
		/// </returns> | 
						|
		IMember? Resolve(ITypeResolveContext context); | 
						|
	} | 
						|
 | 
						|
	/// <summary> | 
						|
	/// Method/field/property/event. | 
						|
	/// </summary> | 
						|
	public interface IMember : IEntity | 
						|
	{ | 
						|
		/// <summary> | 
						|
		/// Gets the original member definition for this member. | 
						|
		/// Returns <c>this</c> if this is not a specialized member. | 
						|
		/// Specialized members are the result of overload resolution with type substitution. | 
						|
		/// </summary> | 
						|
		IMember MemberDefinition { get; } | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Gets the return type of this member. | 
						|
		/// This property never returns <c>null</c>. | 
						|
		/// </summary> | 
						|
		IType ReturnType { get; } | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Gets/Sets the declaring type (incl. type arguments, if any). | 
						|
		/// If this is not a specialized member, the value returned is equal to <see cref="IEntity.DeclaringTypeDefinition"/>. | 
						|
		/// </summary> | 
						|
		new IType DeclaringType { get; } | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Gets the interface members explicitly implemented by this member. | 
						|
		/// </summary> | 
						|
		/// <remarks> | 
						|
		/// For methods, equivalent to ( | 
						|
		///		from impl in DeclaringTypeDefinition.GetExplicitInterfaceImplementations() | 
						|
		///		where impl.Implementation == this | 
						|
		///		select impl.InterfaceMethod | 
						|
		/// ), | 
						|
		/// but may be more efficient than searching the whole list. | 
						|
		///  | 
						|
		/// Note that it is possible for a class to implement an interface using members in a | 
						|
		/// base class unrelated to that interface: | 
						|
		///   class BaseClass { public void Dispose() {} } | 
						|
		///   class C : BaseClass, IDisposable { } | 
						|
		/// In this case, the interface member will not show up in (BaseClass.Dispose).ImplementedInterfaceMembers, | 
						|
		/// so use (C).GetInterfaceImplementations() instead to handle this case. | 
						|
		/// </remarks> | 
						|
		IEnumerable<IMember> ExplicitlyImplementedInterfaceMembers { get; } | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Gets whether this member is explicitly implementing an interface. | 
						|
		/// </summary> | 
						|
		bool IsExplicitInterfaceImplementation { get; } | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Gets if the member is virtual. Is true only if the "virtual" modifier was used, but non-virtual | 
						|
		/// members can be overridden, too; if they are abstract or overriding a method. | 
						|
		/// </summary> | 
						|
		bool IsVirtual { get; } | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Gets whether this member is overriding another member. | 
						|
		/// </summary> | 
						|
		bool IsOverride { get; } | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Gets if the member can be overridden. Returns true when the member is "abstract", "virtual" or "override" but not "sealed". | 
						|
		/// </summary> | 
						|
		bool IsOverridable { get; } | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Gets the substitution belonging to this specialized member. | 
						|
		/// Returns TypeParameterSubstitution.Identity for not specialized members. | 
						|
		/// </summary> | 
						|
		TypeParameterSubstitution Substitution { | 
						|
			get; | 
						|
		} | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Specializes this member with the given substitution. | 
						|
		/// If this member is already specialized, the new substitution is composed with the existing substition. | 
						|
		/// </summary> | 
						|
		IMember Specialize(TypeParameterSubstitution substitution); | 
						|
 | 
						|
		/// <summary> | 
						|
		/// Gets whether the members are considered equal when applying the specified type normalization. | 
						|
		/// </summary> | 
						|
		bool Equals(IMember? obj, TypeVisitor typeNormalization); | 
						|
	} | 
						|
}
 | 
						|
 |