//-----------------------------------------------------------------------
//
//  Microsoft Windows Client Platform
//  Copyright (C) Microsoft Corporation, 2005
//
//  File:      ValueSerializerAttribute.cs
//
//  Contents:  An attribute that allows associating a ValueSerializer 
//             implementation with either a type or a property (or
//             an attached property by setting it on the static accessor
//             for the attachable property).
//
//  Created:   04/28/2005 Microsoft
//
//------------------------------------------------------------------------
using System;
using System.Runtime.CompilerServices;
namespace System.Windows.Markup
{
    /// 
    /// Attribute to associate a ValueSerializer class with a value type or to override
    /// which value serializer to use for a property. A value serializer can be associated
    /// with an attached property by placing the attribute on the static accessor for the
    /// attached property.
    /// 
    [AttributeUsage(AttributeTargets.Class | AttributeTargets.Interface | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Property | AttributeTargets.Method, AllowMultiple = false, Inherited = true)]
#if !MOBILE
    [TypeForwardedFrom("WindowsBase, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35")]
#endif
    public sealed class ValueSerializerAttribute : Attribute
    {
        /// 
        /// Constructor for the ValueSerializerAttribute
        /// 
        /// Type of the value serializer being associated with a type or property
        public ValueSerializerAttribute(Type valueSerializerType)
        {
            _valueSerializerType = valueSerializerType;
        }
        /// 
        /// Constructor for the ValueSerializerAttribute
        /// 
        /// Fully qualified type name of the value serializer being associated with a type or property
        public ValueSerializerAttribute(string valueSerializerTypeName)
        {
            _valueSerializerTypeName = valueSerializerTypeName;
        }
        /// 
        /// The type of the value serializer to create for this type or property.
        /// 
        public Type ValueSerializerType
        {
            get
            {
                if (_valueSerializerType == null && _valueSerializerTypeName != null)
                    _valueSerializerType = Type.GetType(_valueSerializerTypeName);
                return _valueSerializerType;
            }
        }
        /// 
        /// The assembly qualified name of the value serializer type for this type or property.
        /// 
        public string ValueSerializerTypeName
        {
            get
            {
                if (_valueSerializerType != null)
                    return _valueSerializerType.AssemblyQualifiedName;
                else
                    return _valueSerializerTypeName;
            }
        }
        private Type _valueSerializerType;
        private string _valueSerializerTypeName;
    }
}