Jo Shields 3c1f479b9d Imported Upstream version 4.0.0~alpha1
Former-commit-id: 806294f5ded97629b74c85c09952f2a74fe182d9
2015-04-07 09:35:12 +01:00

86 lines
2.5 KiB
C#

//------------------------------------------------------------------------------
// <copyright file="ControlBuilderAttribute.cs" company="Microsoft">
// Copyright (c) Microsoft Corporation. All rights reserved.
// </copyright>
//------------------------------------------------------------------------------
/*
*/
namespace System.Web.UI {
using System;
using System.Diagnostics.CodeAnalysis;
/// <devdoc>
/// <para>Allows a control to specify a custom <see cref='System.Web.UI.ControlBuilder'/> object
/// for building that control within the ASP.NET parser.</para>
/// </devdoc>
[AttributeUsage(AttributeTargets.Class)]
public sealed class ControlBuilderAttribute : Attribute {
/// <internalonly/>
/// <devdoc>
/// <para>The default <see cref='System.Web.UI.ControlBuilderAttribute'/> object is a
/// <see langword='null'/> builder. This field is read-only.</para>
/// </devdoc>
public static readonly ControlBuilderAttribute Default = new ControlBuilderAttribute(null);
private Type builderType = null;
/// <devdoc>
/// </devdoc>
public ControlBuilderAttribute(Type builderType) {
this.builderType = builderType;
}
/// <devdoc>
/// <para> Indicates XXX. This property is read-only.</para>
/// </devdoc>
public Type BuilderType {
get {
return builderType;
}
}
/// <internalonly/>
/// <devdoc>
/// <para>[To be supplied.]</para>
/// </devdoc>
[SuppressMessage("Microsoft.Usage", "CA2303:FlagTypeGetHashCode", Justification = "The type is a ControlBuilder which is never going to be an interop class.")]
public override int GetHashCode()
{
return ((BuilderType != null) ? BuilderType.GetHashCode() : 0);
}
/// <internalonly/>
/// <devdoc>
/// </devdoc>
public override bool Equals(object obj) {
if (obj == this) {
return true;
}
if ((obj != null) && (obj is ControlBuilderAttribute)) {
return((ControlBuilderAttribute)obj).BuilderType == builderType;
}
return false;
}
/// <devdoc>
/// </devdoc>
/// <internalonly/>
public override bool IsDefaultAttribute() {
return this.Equals(Default);
}
}
}