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

« back to all changes in this revision

Viewing changes to external/mono-addins/Mono.Addins/Mono.Addins/ExtensionPointAttribute.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
// ExtensionPointAttribute.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
        /// Declares an extension point.
 
36
        /// </summary>
 
37
        [AttributeUsage (AttributeTargets.Assembly, AllowMultiple=true)]
 
38
        public class ExtensionPointAttribute: Attribute
 
39
        {
 
40
                string path;
 
41
                Type nodeType;
 
42
                string nodeName;
 
43
                string desc;
 
44
                string name;
 
45
                Type objectType;
 
46
                string nodeTypeName;
 
47
                string objectTypeName;
 
48
                Type customAttributeType;
 
49
                string customAttributeTypeName;
 
50
                
 
51
                /// <summary>
 
52
                /// Initializes a new instance
 
53
                /// </summary>
 
54
                public ExtensionPointAttribute ()
 
55
                {
 
56
                }
 
57
                
 
58
                /// <summary>
 
59
                /// Initializes a new instance
 
60
                /// </summary>
 
61
                /// <param name="path">
 
62
                /// Extension path that identifies the extension point
 
63
                /// </param>
 
64
                public ExtensionPointAttribute (string path)
 
65
                {
 
66
                        this.path = path;
 
67
                }
 
68
                
 
69
                /// <summary>
 
70
                /// Initializes a new instance
 
71
                /// </summary>
 
72
                /// <param name="path">
 
73
                /// Extension path that identifies the extension point
 
74
                /// </param>
 
75
                /// <param name="nodeType">
 
76
                /// Type of the extension node to be created for extensions
 
77
                /// </param>
 
78
                public ExtensionPointAttribute (string path, Type nodeType)
 
79
                {
 
80
                        this.path = path;
 
81
                        this.nodeType = nodeType;
 
82
                }
 
83
                
 
84
                /// <summary>
 
85
                /// Initializes a new instance
 
86
                /// </summary>
 
87
                /// <param name="path">
 
88
                /// Extension path that identifies the extension point
 
89
                /// </param>
 
90
                /// <param name="nodeName">
 
91
                /// Element name to be used when defining an extension in an XML manifest.
 
92
                /// </param>
 
93
                /// <param name="nodeType">
 
94
                /// Type of the extension node to be created for extensions
 
95
                /// </param>
 
96
                public ExtensionPointAttribute (string path, string nodeName, Type nodeType)
 
97
                {
 
98
                        this.path = path;
 
99
                        this.nodeType = nodeType;
 
100
                        this.nodeName = nodeName;
 
101
                }
 
102
                
 
103
                /// <summary>
 
104
                /// Extension path that identifies the extension point
 
105
                /// </summary>
 
106
                public string Path {
 
107
                        get { return path != null ? path : string.Empty; }
 
108
                        set { path = value; }
 
109
                }
 
110
                
 
111
                /// <summary>
 
112
                /// Long description of the extension point.
 
113
                /// </summary>
 
114
                public string Description {
 
115
                        get { return desc != null ? desc : string.Empty; }
 
116
                        set { desc = value; }
 
117
                }
 
118
                
 
119
                /// <summary>
 
120
                /// Type of the extension node to be created for extensions
 
121
                /// </summary>
 
122
                public Type NodeType {
 
123
                        get { return nodeType != null ? nodeType : typeof(TypeExtensionNode); }
 
124
                        set { nodeType = value; nodeTypeName = value.FullName; }
 
125
                }
 
126
                
 
127
                /// <summary>
 
128
                /// Expected extension object type (when nodes are of type TypeExtensionNode)
 
129
                /// </summary>
 
130
                public Type ObjectType {
 
131
                        get { return objectType; }
 
132
                        set { objectType = value; objectTypeName = value.FullName; }
 
133
                }
 
134
                
 
135
                internal string NodeTypeName {
 
136
                        get { return nodeTypeName != null ? nodeTypeName : typeof(TypeExtensionNode).FullName; }
 
137
                        set { nodeTypeName = value; }
 
138
                }
 
139
                
 
140
                internal string ObjectTypeName {
 
141
                        get { return objectTypeName; }
 
142
                        set { objectTypeName = value; }
 
143
                }
 
144
                
 
145
                /// <summary>
 
146
                /// Element name to be used when defining an extension in an XML manifest. The default name is "Type".
 
147
                /// </summary>
 
148
                public string NodeName {
 
149
                        get { return nodeName != null && nodeName.Length > 0 ? nodeName : string.Empty; }
 
150
                        set { nodeName = value; }
 
151
                }
 
152
                
 
153
                /// <summary>
 
154
                /// Display name of the extension point.
 
155
                /// </summary>
 
156
                public string Name {
 
157
                        get { return name != null ? name : string.Empty; }
 
158
                        set { name = value; }
 
159
                }
 
160
                
 
161
                /// <summary>
 
162
                /// Type of the custom attribute to be used to specify metadata for the extension point
 
163
                /// </summary>
 
164
                public Type ExtensionAttributeType {
 
165
                        get { return this.customAttributeType; }
 
166
                        set { this.customAttributeType = value; customAttributeTypeName = value.FullName; }
 
167
                }
 
168
 
 
169
                internal string ExtensionAttributeTypeName {
 
170
                        get { return this.customAttributeTypeName; }
 
171
                        set { this.customAttributeTypeName = value; }
 
172
                }
 
173
        }
 
174
}