New test.
[mono.git] / mcs / class / System / System.ComponentModel / EditorAttribute.cs
index d8b675a5639c1b8dfa1119bce015889e24b380a6..6961f7e8c0c6eca47265345dc6553345c07f3959 100644 (file)
@@ -2,9 +2,32 @@
 // System.ComponentModel.EditorAttribute.cs
 //
 // Author:
-//   Alejandro Sánchez Acosta (raciel@es.gnu.org)
+//   Alejandro Sánchez Acosta (raciel@es.gnu.org)
+//   Andreas Nahr (ClassDevelopment@A-SoftTech.com)
 //
-// (C) Alejandro Sánchez Acosta
+// (C) Alejandro Sánchez Acosta
+// (C) 2003 Andreas Nahr
+//
+
+//
+// Permission is hereby granted, free of charge, to any person obtaining
+// a copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to
+// permit persons to whom the Software is furnished to do so, subject to
+// the following conditions:
+// 
+// The above copyright notice and this permission notice shall be
+// included in all copies or substantial portions of the Software.
+// 
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 //
 
 namespace System.ComponentModel {
@@ -12,75 +35,63 @@ namespace System.ComponentModel {
        /// <summary>
        ///   Editor Attribute for classes. 
        /// </summary>
-
-       [AttributeUsage(AttributeTargets.All)]
+       [AttributeUsage (AttributeTargets.All, AllowMultiple = true, Inherited = true)]
        public sealed class EditorAttribute : Attribute {
                
-               string name;    
+               string name;
                string basename;
-               Type base;
-               Type nametype;
 
-               public EditorAttribute()
+               public EditorAttribute ()
                {
-                       this.name = "";
+                       this.name = string.Empty;
                }
 
-               public EditorAttribute(string typeName, string baseTypeName)
+               public EditorAttribute (string typeName, string baseTypeName)
                {
                        name = typeName;
                        basename = baseTypeName;
                }
 
-               public EditorAttribute(string typeName, Type baseType)
+               public EditorAttribute (string typeName, Type baseType)
+                       : this (typeName, baseType.AssemblyQualifiedName)
                {
-                       name = typeName;
-                       base = baseType;        
                }
 
-               public EditorAttribute(Type type, Type baseType)
+               public EditorAttribute (Type type, Type baseType)
+                       : this (type.AssemblyQualifiedName, baseType.AssemblyQualifiedName)
                {
-                       nametype = type;
-                       base = baseType;
                }
 
                public string EditorBaseTypeName {
-                       get
-                       {
+                       get {
                                return basename;
                        }
                }
                
                public string EditorTypeName {
-                       get
-                       {
+                       get {
                                return name;
                        }
                }
 
                public override object TypeId {
-                       get
-                       {
-                               return this.GetType();
+                       get {
+                               return this.GetType ();
                        }
                }
                
-               public override bool Equals(object obj)
+               public override bool Equals (object obj)
                {
-                       if (!(o is EditorAttribute))
+                       if (!(obj is EditorAttribute))
                                return false;
-                       return (((EditorAttribute) o).name == name) &&
-                               (((EditorAttribute) o).basename == basename) &&
-                               (((EditorAttribute) o).base == base) &&
-                               (((EditorAttribute) o).nametype == nametype);
+
+                       return ((EditorAttribute) obj).EditorBaseTypeName.Equals (basename) &&
+                               ((EditorAttribute) obj).EditorTypeName.Equals (name);
                }
                
-               public override int GetHashCode()
+               public override int GetHashCode ()
                {
-                        if (AttributeName == null)
-                               return 0;
-                        return name.GetHashCode ();
+                       return string.Concat(name, basename).GetHashCode ();
                }
        }
 }
-