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

« back to all changes in this revision

Viewing changes to external/mono-addins/Mono.Addins/Mono.Addins/ExtensionNodeChildAttribute.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
// ExtensionNodeChildAttribute.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 allowed children of an extension node type.
 
36
        /// </summary>
 
37
        /// <remarks>
 
38
        /// This attribute allows declaring the type of children that an extension node can have.
 
39
        /// </remarks>
 
40
        [AttributeUsage (AttributeTargets.Class, AllowMultiple=true)]
 
41
        public class ExtensionNodeChildAttribute: Attribute
 
42
        {
 
43
                string nodeName;
 
44
                Type extensionNodeType;
 
45
                string extensionNodeTypeName;
 
46
                
 
47
                /// <summary>
 
48
                /// Initializes a new instance
 
49
                /// </summary>
 
50
                /// <param name="nodeName">
 
51
                /// Name of the allowed child extension node.
 
52
                /// </param>
 
53
                public ExtensionNodeChildAttribute (string nodeName)
 
54
                        : this (typeof(TypeExtensionNode), nodeName)
 
55
                {
 
56
                }
 
57
                
 
58
                /// <summary>
 
59
                /// Initializes a new instance
 
60
                /// </summary>
 
61
                /// <param name="extensionNodeType">
 
62
                /// Type of the allowed child extension node.
 
63
                /// </param>
 
64
                public ExtensionNodeChildAttribute (Type extensionNodeType)
 
65
                        : this (extensionNodeType, null)
 
66
                {
 
67
                }
 
68
                
 
69
                /// <summary>
 
70
                /// Initializes a new instance
 
71
                /// </summary>
 
72
                /// <param name="extensionNodeType">
 
73
                /// Type of the allowed child extension node.
 
74
                /// </param>
 
75
                /// <param name="nodeName">
 
76
                /// Name of the allowed child extension node.
 
77
                /// </param>
 
78
                public ExtensionNodeChildAttribute (Type extensionNodeType, string nodeName)
 
79
                {
 
80
                        ExtensionNodeType = extensionNodeType;
 
81
                        this.nodeName = nodeName;
 
82
                }
 
83
                
 
84
                /// <summary>
 
85
                /// Name of the allowed child extension node.
 
86
                /// </summary>
 
87
                public string NodeName {
 
88
                        get { return nodeName != null ? nodeName : string.Empty; }
 
89
                        set { nodeName = value; }
 
90
                }
 
91
                
 
92
                /// <summary>
 
93
                /// Type of the allowed child extension node.
 
94
                /// </summary>
 
95
                public Type ExtensionNodeType {
 
96
                        get { return extensionNodeType; }
 
97
                        set { extensionNodeType = value; extensionNodeTypeName = value.FullName; }
 
98
                }
 
99
                
 
100
                internal string ExtensionNodeTypeName {
 
101
                        get { return extensionNodeTypeName; }
 
102
                        set { extensionNodeTypeName = value; extensionNodeType = null; }
 
103
                }
 
104
        }
 
105
}