File: System\ComponentModel\LicenseProviderAttribute.cs
Web Access
Project: src\src\libraries\System.ComponentModel.TypeConverter\src\System.ComponentModel.TypeConverter.csproj (System.ComponentModel.TypeConverter)
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
 
using System.Diagnostics.CodeAnalysis;
 
namespace System.ComponentModel
{
    /// <summary>
    /// Specifies the <see cref='System.ComponentModel.LicenseProvider'/>
    /// to use with a class.
    /// </summary>
    [AttributeUsage(AttributeTargets.Class, AllowMultiple = false, Inherited = false)]
    public sealed class LicenseProviderAttribute : Attribute
    {
        /// <summary>
        /// Specifies the default value, which is no provider. This <see langword='static '/>field is read-only.
        /// </summary>
        public static readonly LicenseProviderAttribute Default = new LicenseProviderAttribute();
 
        [DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.PublicParameterlessConstructor)]
        private Type? _licenseProviderType;
        [DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.PublicParameterlessConstructor)]
        private readonly string? _licenseProviderName;
 
        /// <summary>
        /// Initializes a new instance of the <see cref='System.ComponentModel.LicenseProviderAttribute'/> class without a license
        /// provider.
        /// </summary>
        public LicenseProviderAttribute() : this((string?)null)
        {
        }
 
        /// <summary>
        /// Initializes a new instance of the <see cref='System.ComponentModel.LicenseProviderAttribute'/> class with
        /// the specified type.
        /// </summary>
        public LicenseProviderAttribute([DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.PublicParameterlessConstructor)] string? typeName)
        {
            _licenseProviderName = typeName;
        }
 
        /// <summary>
        /// Initializes a new instance of the <see cref='System.ComponentModel.LicenseProviderAttribute'/> class with
        /// the specified type of license provider.
        /// </summary>
        public LicenseProviderAttribute([DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.PublicParameterlessConstructor)] Type type)
        {
            _licenseProviderType = type;
        }
 
        /// <summary>
        /// Gets the license provider to use with the associated class.
        /// </summary>
        [DynamicallyAccessedMembers(DynamicallyAccessedMemberTypes.PublicParameterlessConstructor)]
        public Type? LicenseProvider
        {
            get
            {
                if (_licenseProviderType == null && _licenseProviderName != null)
                {
                    _licenseProviderType = Type.GetType(_licenseProviderName);
                }
                return _licenseProviderType;
            }
        }
 
        /// <summary>
        /// This defines a unique ID for this attribute type. It is used
        /// by filtering algorithms to identify two attributes that are
        /// the same type. For most attributes, this just returns the
        /// Type instance for the attribute. LicenseProviderAttribute overrides this to include the type name and the
        /// provider type name.
        /// </summary>
        public override object TypeId
        {
            get
            {
                string? typeName = _licenseProviderName;
 
                if (typeName == null && _licenseProviderType != null)
                {
                    typeName = _licenseProviderType.FullName;
                }
                return GetType().FullName + typeName;
            }
        }
 
        public override bool Equals([NotNullWhen(true)] object? value)
        {
            if (value is LicenseProviderAttribute && value != null)
            {
                Type? type = ((LicenseProviderAttribute)value).LicenseProvider;
                if (type == LicenseProvider)
                {
                    return true;
                }
                else
                {
                    if (type != null && type.Equals(LicenseProvider))
                    {
                        return true;
                    }
                }
            }
 
            return false;
        }
 
        /// <summary>
        /// Returns the hashcode for this object.
        /// </summary>
        public override int GetHashCode() => base.GetHashCode();
    }
}