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

« back to all changes in this revision

Viewing changes to contrib/ICSharpCode.NRefactory.CSharp/Refactoring/CodeIssues/InconsistentNamingIssue/WordParser.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
 
// WordParser.cs
3
 
//  
4
 
// Author:
5
 
//       Michael Hutchinson <mhutch@xamarin.com>
6
 
// 
7
 
// Copyright (c) 2012 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.
26
 
using System;
27
 
using System.Collections.Generic;
28
 
 
29
 
namespace ICSharpCode.NRefactory.CSharp
30
 
{
31
 
        public static class WordParser
32
 
        {
33
 
                public static List<string> BreakWords (string identifier)
34
 
                {
35
 
                        var words = new List<string> ();
36
 
                        int wordStart = 0;
37
 
                        bool lastWasLower = false, lastWasUpper = false;
38
 
                        for (int i = 0; i < identifier.Length; i++) {
39
 
                                char c = identifier[i];
40
 
                                if (c == '_') {
41
 
                                        if ((i - wordStart) > 0) {
42
 
                                                words.Add (identifier.Substring (wordStart, i - wordStart));
43
 
                                        }
44
 
                                        wordStart = i + 1;
45
 
                                        lastWasLower = lastWasUpper = false;
46
 
                                } else if (Char.IsLower (c)) {
47
 
                                        if (lastWasUpper && (i - wordStart) > 2) {
48
 
                                                words.Add (identifier.Substring (wordStart, i - wordStart - 1));
49
 
                                                wordStart = i - 1;
50
 
                                        }
51
 
                                        lastWasLower = true;
52
 
                                        lastWasUpper = false;
53
 
                                } else if (Char.IsUpper (c)) {
54
 
                                        if (lastWasLower) {
55
 
                                                words.Add (identifier.Substring (wordStart, i - wordStart));
56
 
                                                wordStart = i;
57
 
                                        }
58
 
                                        lastWasLower = false;
59
 
                                        lastWasUpper = true;
60
 
                                }
61
 
                        }
62
 
                        if (wordStart < identifier.Length)
63
 
                                words.Add (identifier.Substring (wordStart));
64
 
                        return words;
65
 
                }
66
 
        }
67
 
}
68