//---------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//
// @owner Microsoft
// @backupOwner Microsoft
//---------------------------------------------------------------------
using System;
using System.Collections.Generic;
using System.Data.Common;
using System.Diagnostics;
using System.Reflection;
namespace System.Data.Metadata.Edm
{
///
/// Class representing a metadata attribute for an item
///
public sealed class MetadataProperty : MetadataItem
{
#region Constructors
///
/// The constructor for MetadataProperty taking in a name, a TypeUsage object, and a value for the attribute
///
/// The name of this MetadataProperty
/// The TypeUsage describing the type of this MetadataProperty
/// The value for this attribute
/// Thrown if typeUsage argument is null
internal MetadataProperty(string name, TypeUsage typeUsage, object value)
{
EntityUtil.GenericCheckArgumentNull(typeUsage, "typeUsage");
_name = name;
_value = value;
_typeUsage = typeUsage;
_propertyKind = PropertyKind.Extended;
}
///
/// The constructor for MetadataProperty taking in all the ingredients for creating TypeUsage and the actual value
///
/// The name of the attribute
/// The edm type of the attribute
/// Whether the collection type of the given edm type should be used
/// The value of the attribute
internal MetadataProperty(string name, EdmType edmType, bool isCollectionType, object value)
{
EntityUtil.CheckArgumentNull(edmType, "edmType");
_name = name;
_value = value;
if (isCollectionType)
{
_typeUsage = TypeUsage.Create(edmType.GetCollectionType());
}
else
{
_typeUsage = TypeUsage.Create(edmType);
}
_propertyKind = PropertyKind.System;
}
#endregion
#region Fields
private string _name;
private PropertyKind _propertyKind;
private object _value;
private TypeUsage _typeUsage;
#endregion
#region Properties
///
/// Returns the kind of the type
///
public override BuiltInTypeKind BuiltInTypeKind { get { return BuiltInTypeKind.MetadataProperty; } }
///
/// Gets the identity of this item
///
internal override string Identity
{
get
{
return Name;
}
}
///
/// Gets/Sets the name of this MetadataProperty
///
[MetadataProperty(PrimitiveTypeKind.String, false)]
public string Name
{
get
{
// The name is immutable, so it should be safe to always get it from the field
return _name;
}
}
///
/// Gets/Sets the value of this MetadataProperty
///
/// Thrown if the MetadataProperty instance is in readonly state
[MetadataProperty(typeof(Object), false)]
public object Value
{
get
{
// Check if we're redirecting to an MetadataItem system property
MetadataPropertyValue redirectValue = _value as MetadataPropertyValue;
if (null != redirectValue)
{
return redirectValue.GetValue();
}
// If not, return the actual stored value
return _value;
}
}
///
/// Gets/Sets the TypeUsage object describing the type of this attribute
///
/// Thrown if value passed into setter is null
/// Thrown if the MetadataProperty instance is in readonly state
[MetadataProperty(BuiltInTypeKind.TypeUsage, false)]
public TypeUsage TypeUsage
{
get
{
return _typeUsage;
}
}
#endregion
#region Methods
///
/// Sets this item to be readonly, once this is set, the item will never be writable again.
///
internal override void SetReadOnly()
{
if (!IsReadOnly)
{
base.SetReadOnly();
// TypeUsage is always readonly, no need to set _typeUsage
}
}
///
/// Returns the kind of the attribute
///
public PropertyKind PropertyKind
{
get
{
return _propertyKind;
}
}
#endregion
}
}