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

« back to all changes in this revision

Viewing changes to contrib/ICSharpCode.NRefactory.CSharp/Refactoring/CodeActions/CreatePropertyAction.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
 
// 
2
 
// CreateProperty.cs
3
 
//  
4
 
// Author:
5
 
//       Mike Krüger <mkrueger@novell.com>
6
 
// 
7
 
// Copyright (c) 2011 Novell, Inc (http://www.novell.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.
26
 
using System;
27
 
using System.Collections.Generic;
28
 
using ICSharpCode.NRefactory.Semantics;
29
 
using ICSharpCode.NRefactory.TypeSystem;
30
 
 
31
 
namespace ICSharpCode.NRefactory.CSharp.Refactoring
32
 
{
33
 
        [ContextAction("Create property", Description = "Creates a property for a undefined variable.")]
34
 
        public class CreatePropertyAction : ICodeActionProvider
35
 
        {
36
 
                public IEnumerable<CodeAction> GetActions(RefactoringContext context)
37
 
                {
38
 
                        var identifier = context.GetNode(n => n is IdentifierExpression || n is MemberReferenceExpression) as Expression;
39
 
                        if (identifier == null)
40
 
                                yield break;
41
 
                        if (CreateFieldAction.IsInvocationTarget(identifier))
42
 
                                yield break;
43
 
 
44
 
                        var propertyName = GetPropertyName(identifier);
45
 
                        if (propertyName == null)
46
 
                                yield break;
47
 
 
48
 
                        var statement = context.GetNode<Statement>();
49
 
                        if (statement == null)
50
 
                                yield break;
51
 
 
52
 
                        if (!(context.Resolve(identifier).IsError))
53
 
                                yield break;
54
 
 
55
 
                        var guessedType = CreateFieldAction.GuessAstType(context, identifier);
56
 
                        if (guessedType == null)
57
 
                                yield break;
58
 
                        var state = context.GetResolverStateBefore(identifier);
59
 
                        if (state.CurrentTypeDefinition == null)
60
 
                                yield break;
61
 
                        
62
 
                        bool createInOtherType = false;
63
 
                        ResolveResult targetResolveResult = null;
64
 
                        if (identifier is MemberReferenceExpression) {
65
 
                                targetResolveResult = context.Resolve(((MemberReferenceExpression)identifier).Target);
66
 
                                createInOtherType = !state.CurrentTypeDefinition.Equals(targetResolveResult.Type.GetDefinition());
67
 
                        }
68
 
 
69
 
                        bool isStatic = targetResolveResult is TypeResolveResult;
70
 
                        if (createInOtherType) {
71
 
                                if (isStatic && targetResolveResult.Type.Kind == TypeKind.Interface || targetResolveResult.Type.Kind == TypeKind.Enum)
72
 
                                        yield break;
73
 
                        } else {
74
 
                                if (state.CurrentMember == null)
75
 
                                        yield break;
76
 
                                isStatic |= state.CurrentMember.IsStatic || state.CurrentTypeDefinition.IsStatic;
77
 
                        }
78
 
 
79
 
//                      var service = (NamingConventionService)context.GetService(typeof(NamingConventionService));
80
 
//                      if (service != null && !service.IsValidName(propertyName, AffectedEntity.Property, Modifiers.Private, isStatic)) { 
81
 
//                              yield break;
82
 
//                      }
83
 
 
84
 
                        yield return new CodeAction(context.TranslateString("Create property"), script => {
85
 
                                var decl = new PropertyDeclaration() {
86
 
                                        ReturnType = guessedType,
87
 
                                        Name = propertyName,
88
 
                                        Getter = new Accessor(),
89
 
                                        Setter = new Accessor()
90
 
                                };
91
 
                                if (isStatic)
92
 
                                        decl.Modifiers |= Modifiers.Static;
93
 
                                
94
 
                                if (createInOtherType) {
95
 
                                        if (targetResolveResult.Type.Kind == TypeKind.Interface) {
96
 
                                                decl.Modifiers = Modifiers.None;
97
 
                                        } else {
98
 
                                                decl.Modifiers |= Modifiers.Public;
99
 
                                        }
100
 
                                        script.InsertWithCursor(
101
 
                                                context.TranslateString("Create property"),
102
 
                                                targetResolveResult.Type.GetDefinition(),
103
 
                                                decl);
104
 
 
105
 
                                        return;
106
 
                                }
107
 
 
108
 
                                script.InsertWithCursor(context.TranslateString("Create property"), Script.InsertPosition.Before, decl);
109
 
 
110
 
                        });
111
 
                }
112
 
 
113
 
                static string GetPropertyName(Expression expr)
114
 
                {
115
 
                        if (expr is IdentifierExpression) 
116
 
                                return ((IdentifierExpression)expr).Identifier;
117
 
                        if (expr is MemberReferenceExpression) 
118
 
                                return ((MemberReferenceExpression)expr).MemberName;
119
 
 
120
 
                        return null;
121
 
                }
122
 
        }
123
 
}
124