//---------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//
// @owner Microsoft
// @backupOwner Microsoft
//---------------------------------------------------------------------
using System;
using System.Collections;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Data.Common;
using System.Reflection;
using System.Text;
using System.Diagnostics;
namespace System.Data.Metadata.Edm
{
///
/// Class representing a collection of entity set objects
///
internal sealed class EntitySetBaseCollection : MetadataCollection
{
// This collection allows changes to be intercepted before and after they are passed to MetadataCollection. The interception
// is required to update the EntitySet's back-reference to the EntityContainer.
#region Constructors
///
/// Default constructor for constructing an empty collection
///
/// The entity container that has this entity set collection
/// Thrown if the argument entityContainer is null
internal EntitySetBaseCollection(EntityContainer entityContainer)
: this(entityContainer, null)
{
}
///
/// The constructor for constructing the collection with the given items
///
/// The entity container that has this entity set collection
/// The items to populate the collection
/// Thrown if the argument entityContainer is null
internal EntitySetBaseCollection(EntityContainer entityContainer, IEnumerable items)
: base(items)
{
EntityUtil.GenericCheckArgumentNull(entityContainer, "entityContainer");
_entityContainer = entityContainer;
}
#endregion
#region Fields
private readonly EntityContainer _entityContainer;
#endregion
#region Properties
///
/// Gets an item from the collection with the given index
///
/// The index to search for
/// An item from the collection
/// Thrown if the index is out of the range for the Collection
/// Always thrown on setter
public override EntitySetBase this[int index]
{
get
{
return base[index];
}
set
{
throw EntityUtil.OperationOnReadOnlyCollection();
}
}
///
/// Gets an item from the collection with the given identity
///
/// The identity of the item to search for
/// An item from the collection
/// Thrown if identity argument passed in is null
/// Thrown if the Collection does not have an EntitySet with the given identity
/// Always thrown on setter
public override EntitySetBase this[string identity]
{
get
{
return base[identity];
}
set
{
throw EntityUtil.OperationOnReadOnlyCollection();
}
}
#endregion
#region Methods
///
/// Adds an item to the collection
///
/// The item to add to the list
/// Thrown if item argument is null
/// Thrown if the item passed in or the collection itself instance is in ReadOnly state
/// Thrown if the EntitySetBase that is being added already belongs to another EntityContainer
/// Thrown if the EntitySetCollection already contains an EntitySet with the same identity
public override void Add(EntitySetBase item)
{
EntityUtil.GenericCheckArgumentNull(item, "item");
// Check to make sure the given entity set is not associated with another type
ThrowIfItHasEntityContainer(item, "item");
base.Add(item);
// Fix up the declaring type
item.ChangeEntityContainerWithoutCollectionFixup(_entityContainer);
}
///
/// Checks if the given entity set already has a entity container, if so, throw an exception
///
/// The entity set to check for
/// The name of the argument from the caller
private static void ThrowIfItHasEntityContainer(EntitySetBase entitySet, string argumentName)
{
EntityUtil.GenericCheckArgumentNull(entitySet, argumentName);
if (entitySet.EntityContainer != null)
{
throw EntityUtil.EntitySetInAnotherContainer(argumentName);
}
}
#endregion
}
}