Free cookie consent management tool by TermsFeed Policy Generator

source: branches/2994-AutoDiffForIntervals/HeuristicLab.ExtLibs/HeuristicLab.NRefactory/5.5.0/NRefactory.CSharp-5.5.0/Completion/ICompletionDataFactory.cs

Last change on this file was 11700, checked in by jkarder, 10 years ago

#2077: created branch and added first version

File size: 3.9 KB
Line 
1//
2// ICompletionDataFactory.cs
3// 
4// Author:
5//       Mike Krüger <mkrueger@xamarin.com>
6//
7// Copyright (c) 2011 Xamarin Inc. (http://xamarin.com)
8//
9// Permission is hereby granted, free of charge, to any person obtaining a copy
10// of this software and associated documentation files (the "Software"), to deal
11// in the Software without restriction, including without limitation the rights
12// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
13// copies of the Software, and to permit persons to whom the Software is
14// furnished to do so, subject to the following conditions:
15//
16// The above copyright notice and this permission notice shall be included in
17// all copies or substantial portions of the Software.
18//
19// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
22// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
24// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
25// THE SOFTWARE.
26using System;
27using System.Collections.Generic;
28using ICSharpCode.NRefactory.TypeSystem;
29using ICSharpCode.NRefactory.Completion;
30
31namespace ICSharpCode.NRefactory.CSharp.Completion
32{
33  public interface ICompletionDataFactory
34  {
35    ICompletionData CreateEntityCompletionData (IEntity entity);
36    ICompletionData CreateEntityCompletionData (IEntity entity, string text);
37   
38    ICompletionData CreateTypeCompletionData (IType type, bool showFullName, bool isInAttributeContext, bool addForTypeCreation);
39
40    /// <summary>
41    /// Creates the member completion data.
42    /// Form: Type.Member
43    /// Used for generating enum members Foo.A, Foo.B where the enum 'Foo' is valid.
44    /// </summary>
45    ICompletionData CreateMemberCompletionData(IType type, IEntity member);
46
47    /// <summary>
48    /// Creates a generic completion data.
49    /// </summary>
50    /// <param name='title'>
51    /// The title of the completion data
52    /// </param>
53    /// <param name='description'>
54    /// The description of the literal.
55    /// </param>
56    /// <param name='insertText'>
57    /// The insert text. If null, title is taken.
58    /// </param>
59    ICompletionData CreateLiteralCompletionData (string title, string description = null, string insertText = null);
60   
61    ICompletionData CreateNamespaceCompletionData (INamespace name);
62   
63    ICompletionData CreateVariableCompletionData (IVariable variable);
64
65    ICompletionData CreateVariableCompletionData (ITypeParameter parameter);
66   
67    ICompletionData CreateEventCreationCompletionData (string delegateMethodName, IType delegateType, IEvent evt, string parameterDefinition, IUnresolvedMember currentMember, IUnresolvedTypeDefinition currentType);
68
69    ICompletionData CreateNewOverrideCompletionData (int declarationBegin, IUnresolvedTypeDefinition type, IMember m);
70    ICompletionData CreateNewPartialCompletionData (int declarationBegin, IUnresolvedTypeDefinition type, IUnresolvedMember m);
71   
72    IEnumerable<ICompletionData> CreateCodeTemplateCompletionData ();
73   
74    IEnumerable<ICompletionData> CreatePreProcessorDefinesCompletionData ();
75
76    /// <summary>
77    /// Creates a completion data that adds the required using for the created type.
78    /// </summary>
79    /// <param name="type">The type to import</param>
80    /// <param name="useFullName">If set to true the full name of the type needs to be used.</param>
81    /// <param name="addForTypeCreation">If true the completion data is used in 'new' context.</param>
82    ICompletionData CreateImportCompletionData(IType type, bool useFullName, bool addForTypeCreation);
83
84    ICompletionData CreateFormatItemCompletionData(string format, string description, object example);
85
86    ICompletionData CreateXmlDocCompletionData (string tag, string description = null, string tagInsertionText = null);
87
88  }
89}
Note: See TracBrowser for help on using the repository browser.