~ubuntu-branches/ubuntu/oneiric/monodevelop/oneiric

« back to all changes in this revision

Viewing changes to src/core/MonoDevelop.Core/MonoDevelop.Projects.Extensions/ParserNode.cs

  • Committer: Bazaar Package Importer
  • Author(s): Jo Shields
  • Date: 2011-06-27 17:03:13 UTC
  • mto: (1.8.1 upstream)
  • mto: This revision was merged to the branch mainline in revision 54.
  • Revision ID: james.westby@ubuntu.com-20110627170313-6cvz3s19x6e9hqe9
ImportĀ upstreamĀ versionĀ 2.5.92+dfsg

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
// 
 
2
// ParserNode.cs
 
3
//  
 
4
// Author:
 
5
//       Michael Hutchinson <mhutchinson@novell.com>
 
6
// 
 
7
// Copyright (c) 2010 Novell, Inc.
 
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
 
 
27
using System;
 
28
using MonoDevelop.Projects.Dom.Parser;
 
29
using Mono.Addins;
 
30
using System.Collections;
 
31
using System.Linq;
 
32
 
 
33
namespace MonoDevelop.Projects.Extensions
 
34
{
 
35
        public class ParserNode: TypeExtensionNode
 
36
        {
 
37
                [NodeAttribute (Description="Comma separated list of file extensions to which this parser applies. It applies to all if none is specified.")]
 
38
                string[] fileExtensions;
 
39
                
 
40
                
 
41
//              [NodeAttribute (Description="Comma separated list of mime types to which this parser applies. It applies to all if none is specified.")]
 
42
//              string[] mimeTypes;
 
43
                
 
44
                public string[] FileExtensions {
 
45
                        get { return this.fileExtensions; }
 
46
                        set { this.fileExtensions = value; }
 
47
                }
 
48
                
 
49
//              public string[] MimeTypes {
 
50
//                      get { return this.mimeTypes; }
 
51
//                      set { this.mimeTypes = value; }
 
52
//              }
 
53
                
 
54
                IParser cachedInstance;
 
55
                public IParser Parser {
 
56
                        get {
 
57
                                return cachedInstance ?? (cachedInstance = (IParser)CreateInstance ());
 
58
                        }
 
59
                }
 
60
                
 
61
                public bool Supports (string fileName)
 
62
                {
 
63
                        if (fileExtensions != null && fileExtensions.Length > 0) {
 
64
                                string ext = System.IO.Path.GetExtension (fileName);
 
65
                                return fileExtensions.Any (fe => string.Compare (fe, ext, StringComparison.OrdinalIgnoreCase) == 0);
 
66
                        }
 
67
                        
 
68
//FIXME: DesktopService is not accessible from here
 
69
//                      if (mimeTypes != null && mimeTypes.Length > 0) {
 
70
//                              string mt = DesktopService.GetMimeTypeForUri (fileName);
 
71
//                              foreach (string t in mimeTypes) {
 
72
//                                      if (DesktopService.GetMimeTypeIsSubtype (mt, t))
 
73
//                                              return true;
 
74
//                              }
 
75
//                              return false;
 
76
//                      }
 
77
                        
 
78
                        // No constraints on the file
 
79
                        return true;
 
80
                }
 
81
        }
 
82
}
 
83