PageRenderTime 708ms CodeModel.GetById 702ms app.highlight 3ms RepoModel.GetById 1ms app.codeStats 0ms

/NRefactory/ICSharpCode.NRefactory/TypeSystem/IEvent.cs

http://github.com/icsharpcode/ILSpy
C# | 58 lines | 25 code | 6 blank | 27 comment | 0 complexity | d9fc4bba5f1faacbe88174b96a840a7c MD5 | raw file
 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
19using System;
20using System.Diagnostics.Contracts;
21using ICSharpCode.NRefactory.TypeSystem;
22
23namespace ICSharpCode.NRefactory.TypeSystem
24{
25	public interface IUnresolvedEvent : IUnresolvedMember
26	{
27		bool CanAdd { get; }
28		bool CanRemove { get; }
29		bool CanInvoke { get; }
30		
31		IUnresolvedMethod AddAccessor { get; }
32		IUnresolvedMethod RemoveAccessor { get; }
33		IUnresolvedMethod InvokeAccessor { get; }
34		
35		/// <summary>
36		/// Resolves the member.
37		/// </summary>
38		/// <param name="context">
39		/// Context for looking up the member. The context must specify the current assembly.
40		/// A <see cref="SimpleTypeResolveContext"/> that specifies the current assembly is sufficient.
41		/// </param>
42		/// <returns>
43		/// Returns the resolved member, or <c>null</c> if the member could not be found.
44		/// </returns>
45		new IEvent Resolve(ITypeResolveContext context);
46	}
47	
48	public interface IEvent : IMember
49	{
50		bool CanAdd { get; }
51		bool CanRemove { get; }
52		bool CanInvoke { get; }
53		
54		IMethod AddAccessor { get; }
55		IMethod RemoveAccessor { get; }
56		IMethod InvokeAccessor { get; }
57	}
58}