linux-packaging-mono/mcs/class/referencesource/System.Web/UI/FileLevelControlBuilderAttribute.cs
Xamarin Public Jenkins (auto-signing) e79aa3c0ed Imported Upstream version 4.6.0.125
Former-commit-id: a2155e9bd80020e49e72e86c44da02a8ac0e57a4
2016-08-03 10:59:49 +00:00

97 lines
2.7 KiB
C#

//------------------------------------------------------------------------------
// <copyright file="FileLevelControlBuilderAttribute.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 TemplateControl (e.g. Page or UserControl) derived class to specify
// the control builder used at the top level ofthe builder tree when parsing the file.
/// for building that control within the ASP.NET parser.</para>
/// </devdoc>
[AttributeUsage(AttributeTargets.Class)]
public sealed class FileLevelControlBuilderAttribute : Attribute
{
/// <internalonly/>
/// <devdoc>
/// <para>The default <see cref='System.Web.UI.FileLevelControlBuilderAttribute'/> object is a
/// <see langword='null'/> builder. This field is read-only.</para>
/// </devdoc>
public static readonly FileLevelControlBuilderAttribute Default = new FileLevelControlBuilderAttribute(null);
private Type builderType = null;
/// <devdoc>
/// </devdoc>
public FileLevelControlBuilderAttribute(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.GetHashCode();
}
/// <internalonly/>
/// <devdoc>
/// </devdoc>
public override bool Equals(object obj)
{
if (obj == this)
{
return true;
}
if ((obj != null) && (obj is FileLevelControlBuilderAttribute))
{
return ((FileLevelControlBuilderAttribute)obj).BuilderType == builderType;
}
return false;
}
/// <devdoc>
/// </devdoc>
/// <internalonly/>
public override bool IsDefaultAttribute()
{
return this.Equals(Default);
}
}
}