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

« back to all changes in this revision

Viewing changes to external/mono-addins/Mono.Addins/Mono.Addins/ExtensionNodeAttribute.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
// ExtensionNodeAttribute.cs
 
3
//
 
4
// Author:
 
5
//   Lluis Sanchez Gual
 
6
//
 
7
// Copyright (C) 2007 Novell, Inc (http://www.novell.com)
 
8
//
 
9
// Permission is hereby granted, free of charge, to any person obtaining
 
10
// a copy of this software and associated documentation files (the
 
11
// "Software"), to deal in the Software without restriction, including
 
12
// without limitation the rights to use, copy, modify, merge, publish,
 
13
// distribute, sublicense, and/or sell copies of the Software, and to
 
14
// permit persons to whom the Software is furnished to do so, subject to
 
15
// the following conditions:
 
16
// 
 
17
// The above copyright notice and this permission notice shall be
 
18
// included in all copies or substantial portions of the Software.
 
19
// 
 
20
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 
21
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 
22
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 
23
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
 
24
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 
25
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 
26
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 
27
//
 
28
 
 
29
 
 
30
using System;
 
31
 
 
32
namespace Mono.Addins
 
33
{
 
34
        /// <summary>
 
35
        /// This attribute can be applied to an ExtensionNode subclass to specify the default name and description.
 
36
        /// </summary>
 
37
        /// <remarks>
 
38
        /// This information will be used when an extension point does not define a name or description for a node type.
 
39
        /// </remarks>
 
40
        [AttributeUsage (AttributeTargets.Class)]
 
41
        public class ExtensionNodeAttribute: Attribute
 
42
        {
 
43
                string nodeName;
 
44
                string description;
 
45
                string customAttributeTypeName;
 
46
                Type customAttributeType;
 
47
                
 
48
                /// <summary>
 
49
                /// Initializes the attribute
 
50
                /// </summary>
 
51
                public ExtensionNodeAttribute ()
 
52
                {
 
53
                }
 
54
                
 
55
                /// <summary>
 
56
                /// Initializes the attribute
 
57
                /// </summary>
 
58
                /// <param name="nodeName">
 
59
                /// Name of the node
 
60
                /// </param>
 
61
                public ExtensionNodeAttribute (string nodeName)
 
62
                {
 
63
                        this.nodeName = nodeName;
 
64
                }
 
65
                
 
66
                /// <summary>
 
67
                /// Initializes the attribute
 
68
                /// </summary>
 
69
                /// <param name="nodeName">
 
70
                /// Name of the node
 
71
                /// </param>
 
72
                /// <param name="description">
 
73
                /// Description of the node
 
74
                /// </param>
 
75
                public ExtensionNodeAttribute (string nodeName, string description)
 
76
                {
 
77
                        this.nodeName = nodeName;
 
78
                        this.description = description;
 
79
                }
 
80
                
 
81
                /// <summary>
 
82
                /// Default name of the extension node
 
83
                /// </summary>
 
84
                public string NodeName {
 
85
                        get { return nodeName != null ? nodeName : string.Empty; }
 
86
                        set { nodeName = value; }
 
87
                }
 
88
                
 
89
                /// <summary>
 
90
                /// Default description of the extension node type
 
91
                /// </summary>
 
92
                public string Description {
 
93
                        get { return description != null ? description : string.Empty; }
 
94
                        set { description = value; }
 
95
                }
 
96
                
 
97
                /// <summary>
 
98
                /// Type of a custom attribute which can be used to specify metadata for this extension node type
 
99
                /// </summary>
 
100
                public Type ExtensionAttributeType {
 
101
                        get { return customAttributeType; }
 
102
                        set { customAttributeType = value; customAttributeTypeName = value.FullName; }
 
103
                }
 
104
                
 
105
                internal string ExtensionAttributeTypeName {
 
106
                        get { return customAttributeTypeName ?? string.Empty; }
 
107
                        set { customAttributeTypeName = value; }
 
108
                }
 
109
        }
 
110
}