Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / ndp / fx / src / DataEntity / System / Data / EntityModel / SchemaObjectModel / RelationshipEndCollection.cs / 1 / RelationshipEndCollection.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backupOwner [....] //--------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.Collections.Specialized; using System.Diagnostics; using System.Data; using System.Data.Metadata.Edm; namespace System.Data.EntityModel.SchemaObjectModel { ////// A collection of RelationshipEnds /// internal sealed class RelationshipEndCollection : IList{ private Dictionary _endLookup = null; private List _keysInDefOrder = null; /// /// construct a RelationshipEndCollection /// public RelationshipEndCollection() { } ////// How many RelationshipEnds are in the collection /// public int Count { get { return KeysInDefOrder.Count; } } ////// Add a relationship end /// /// the end to add public void Add(IRelationshipEnd end) { Debug.Assert(end != null, "end parameter is null"); SchemaElement endElement = end as SchemaElement; Debug.Assert(endElement != null, "end is not a SchemaElement"); // this should have been caught before this, just ignore it if ( !IsEndValid(end) ) return; if ( !ValidateUniqueName(endElement, end.Name)) return; EndLookup.Add(end.Name,end); KeysInDefOrder.Add(end.Name); } ////// See if an end can be added to the collection /// /// the end to add ///true if the end is valid, false otherwise private static bool IsEndValid(IRelationshipEnd end) { return !string.IsNullOrEmpty(end.Name); } ////// /// /// /// ///private bool ValidateUniqueName(SchemaElement end, string name) { if ( EndLookup.ContainsKey(name) ) { end.AddError( ErrorCode.AlreadyDefined, EdmSchemaErrorSeverity.Error, System.Data.Entity.Strings.EndNameAlreadyDefinedDuplicate(name)); return false; } return true; } /// /// Remove a relationship end /// /// the end to remove ///true if item was in list public bool Remove(IRelationshipEnd end) { Debug.Assert(end != null, "end parameter is null"); if ( !IsEndValid(end) ) return false; KeysInDefOrder.Remove(end.Name); bool wasInList = EndLookup.Remove(end.Name); return wasInList; } ////// See if a relationship end is in the collection /// /// the name of the end ///true if the end name is in the collection public bool Contains(string name) { return EndLookup.ContainsKey(name); } ////// See if a relationship end is in the collection /// /// the name of the end ///true if the end is in the collection public bool Contains(IRelationshipEnd end) { Debug.Assert(end != null, "end parameter is null"); return Contains(end.Name); } public IRelationshipEnd this[int index] { get { return EndLookup[KeysInDefOrder[index]]; } set { throw EntityUtil.NotSupported(); } } ////// get a typed enumerator for the collection /// ///the enumerator public IEnumeratorGetEnumerator() { return new Enumerator(EndLookup,KeysInDefOrder); } public bool TryGetEnd( string name, out IRelationshipEnd end ) { return EndLookup.TryGetValue( name, out end ); } /// /// get an un-typed enumerator for the collection /// ///the enumerator IEnumerator System.Collections.IEnumerable.GetEnumerator() { return new Enumerator(EndLookup,KeysInDefOrder); } ////// The data for the collection /// private DictionaryEndLookup { get { if ( _endLookup == null ) _endLookup = new Dictionary (StringComparer.Ordinal); return _endLookup; } } /// /// the definition order collection /// private ListKeysInDefOrder { get { if ( _keysInDefOrder == null ) _keysInDefOrder = new List (); return _keysInDefOrder; } } /// /// remove all elements from the collection /// public void Clear() { EndLookup.Clear(); KeysInDefOrder.Clear(); } ////// can the collection be modified /// public bool IsReadOnly { get { return false; } } ////// Not supported /// /// the end ///nothing int IList.IndexOf(IRelationshipEnd end) { throw EntityUtil.NotSupported(); } /// /// Not supported /// /// the index /// the end void IList.Insert(int index, IRelationshipEnd end) { throw EntityUtil.NotSupported(); } /// /// Not supported /// /// the index void IList.RemoveAt(int index) { throw EntityUtil.NotSupported(); } /// /// copy all elements to an array /// /// array to copy to /// The zero-based index in array at which copying begins. public void CopyTo(IRelationshipEnd[] ends, int index ) { Debug.Assert(ends.Length-index >= Count); foreach ( IRelationshipEnd end in this ) ends[index++] = end; } ////// enumerator for the RelationshipEnd collection /// the ends as traversed in the order in which they were added /// private sealed class Enumerator : IEnumerator{ private List .Enumerator _Enumerator; private Dictionary _Data = null; /// /// construct the enumerator /// /// the real data /// the keys to the real data in inserted order public Enumerator(Dictionarydata, List keysInDefOrder) { Debug.Assert(data != null); Debug.Assert(keysInDefOrder != null); _Enumerator = keysInDefOrder.GetEnumerator(); _Data = data; } /// /// reset the enumerator /// public void Reset() { // reset is implemented explicitly ((IEnumerator)_Enumerator).Reset(); } ////// get current relationship end from the enumerator /// public IRelationshipEnd Current { get { return _Data[_Enumerator.Current]; } } ////// get current relationship end from the enumerator /// object System.Collections.IEnumerator.Current { get { return _Data[_Enumerator.Current]; } } ////// move to the next element in the collection /// ///true if there is a next, false if not public bool MoveNext() { return _Enumerator.MoveNext(); } ////// dispose of the enumerator /// public void Dispose() { } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backupOwner [....] //--------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.Collections.Specialized; using System.Diagnostics; using System.Data; using System.Data.Metadata.Edm; namespace System.Data.EntityModel.SchemaObjectModel { ////// A collection of RelationshipEnds /// internal sealed class RelationshipEndCollection : IList{ private Dictionary _endLookup = null; private List _keysInDefOrder = null; /// /// construct a RelationshipEndCollection /// public RelationshipEndCollection() { } ////// How many RelationshipEnds are in the collection /// public int Count { get { return KeysInDefOrder.Count; } } ////// Add a relationship end /// /// the end to add public void Add(IRelationshipEnd end) { Debug.Assert(end != null, "end parameter is null"); SchemaElement endElement = end as SchemaElement; Debug.Assert(endElement != null, "end is not a SchemaElement"); // this should have been caught before this, just ignore it if ( !IsEndValid(end) ) return; if ( !ValidateUniqueName(endElement, end.Name)) return; EndLookup.Add(end.Name,end); KeysInDefOrder.Add(end.Name); } ////// See if an end can be added to the collection /// /// the end to add ///true if the end is valid, false otherwise private static bool IsEndValid(IRelationshipEnd end) { return !string.IsNullOrEmpty(end.Name); } ////// /// /// /// ///private bool ValidateUniqueName(SchemaElement end, string name) { if ( EndLookup.ContainsKey(name) ) { end.AddError( ErrorCode.AlreadyDefined, EdmSchemaErrorSeverity.Error, System.Data.Entity.Strings.EndNameAlreadyDefinedDuplicate(name)); return false; } return true; } /// /// Remove a relationship end /// /// the end to remove ///true if item was in list public bool Remove(IRelationshipEnd end) { Debug.Assert(end != null, "end parameter is null"); if ( !IsEndValid(end) ) return false; KeysInDefOrder.Remove(end.Name); bool wasInList = EndLookup.Remove(end.Name); return wasInList; } ////// See if a relationship end is in the collection /// /// the name of the end ///true if the end name is in the collection public bool Contains(string name) { return EndLookup.ContainsKey(name); } ////// See if a relationship end is in the collection /// /// the name of the end ///true if the end is in the collection public bool Contains(IRelationshipEnd end) { Debug.Assert(end != null, "end parameter is null"); return Contains(end.Name); } public IRelationshipEnd this[int index] { get { return EndLookup[KeysInDefOrder[index]]; } set { throw EntityUtil.NotSupported(); } } ////// get a typed enumerator for the collection /// ///the enumerator public IEnumeratorGetEnumerator() { return new Enumerator(EndLookup,KeysInDefOrder); } public bool TryGetEnd( string name, out IRelationshipEnd end ) { return EndLookup.TryGetValue( name, out end ); } /// /// get an un-typed enumerator for the collection /// ///the enumerator IEnumerator System.Collections.IEnumerable.GetEnumerator() { return new Enumerator(EndLookup,KeysInDefOrder); } ////// The data for the collection /// private DictionaryEndLookup { get { if ( _endLookup == null ) _endLookup = new Dictionary (StringComparer.Ordinal); return _endLookup; } } /// /// the definition order collection /// private ListKeysInDefOrder { get { if ( _keysInDefOrder == null ) _keysInDefOrder = new List (); return _keysInDefOrder; } } /// /// remove all elements from the collection /// public void Clear() { EndLookup.Clear(); KeysInDefOrder.Clear(); } ////// can the collection be modified /// public bool IsReadOnly { get { return false; } } ////// Not supported /// /// the end ///nothing int IList.IndexOf(IRelationshipEnd end) { throw EntityUtil.NotSupported(); } /// /// Not supported /// /// the index /// the end void IList.Insert(int index, IRelationshipEnd end) { throw EntityUtil.NotSupported(); } /// /// Not supported /// /// the index void IList.RemoveAt(int index) { throw EntityUtil.NotSupported(); } /// /// copy all elements to an array /// /// array to copy to /// The zero-based index in array at which copying begins. public void CopyTo(IRelationshipEnd[] ends, int index ) { Debug.Assert(ends.Length-index >= Count); foreach ( IRelationshipEnd end in this ) ends[index++] = end; } ////// enumerator for the RelationshipEnd collection /// the ends as traversed in the order in which they were added /// private sealed class Enumerator : IEnumerator{ private List .Enumerator _Enumerator; private Dictionary _Data = null; /// /// construct the enumerator /// /// the real data /// the keys to the real data in inserted order public Enumerator(Dictionarydata, List keysInDefOrder) { Debug.Assert(data != null); Debug.Assert(keysInDefOrder != null); _Enumerator = keysInDefOrder.GetEnumerator(); _Data = data; } /// /// reset the enumerator /// public void Reset() { // reset is implemented explicitly ((IEnumerator)_Enumerator).Reset(); } ////// get current relationship end from the enumerator /// public IRelationshipEnd Current { get { return _Data[_Enumerator.Current]; } } ////// get current relationship end from the enumerator /// object System.Collections.IEnumerator.Current { get { return _Data[_Enumerator.Current]; } } ////// move to the next element in the collection /// ///true if there is a next, false if not public bool MoveNext() { return _Enumerator.MoveNext(); } ////// dispose of the enumerator /// public void Dispose() { } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- Transform.cs
- WebPartZoneBase.cs
- LayoutEngine.cs
- Evidence.cs
- MarkedHighlightComponent.cs
- XmlSchemaSubstitutionGroup.cs
- CurrencyWrapper.cs
- PartialTrustHelpers.cs
- FixedSOMElement.cs
- SoapElementAttribute.cs
- Mappings.cs
- Int32Animation.cs
- BamlBinaryReader.cs
- TextBoxView.cs
- Table.cs
- EventRoute.cs
- PropertyCollection.cs
- FullTrustAssemblyCollection.cs
- ExceptionRoutedEventArgs.cs
- SelfIssuedAuthRSAPKCS1SignatureFormatter.cs
- TemplateField.cs
- RuntimeConfig.cs
- ResourceIDHelper.cs
- HttpConfigurationSystem.cs
- BackoffTimeoutHelper.cs
- DataColumnMappingCollection.cs
- ReadOnlyActivityGlyph.cs
- TraceUtils.cs
- ConditionedDesigner.cs
- StorageInfo.cs
- SqlConnectionString.cs
- OutputCacheSection.cs
- TableCell.cs
- TextServicesHost.cs
- EntityTypeBase.cs
- FixedFlowMap.cs
- ForAllOperator.cs
- MobileControlsSection.cs
- RichTextBoxContextMenu.cs
- ResolvedKeyFrameEntry.cs
- ResourceDefaultValueAttribute.cs
- InputMethodStateTypeInfo.cs
- HttpModulesSection.cs
- Bold.cs
- DriveNotFoundException.cs
- SqlCrossApplyToCrossJoin.cs
- ListItemCollection.cs
- NumericUpDownAcceleration.cs
- NavigatorInput.cs
- NamespaceInfo.cs
- ModelChangedEventArgsImpl.cs
- InvokePattern.cs
- CustomLineCap.cs
- HashStream.cs
- VarInfo.cs
- CategoryAttribute.cs
- ReaderWriterLock.cs
- IIS7WorkerRequest.cs
- LocatorPart.cs
- TdsParserStaticMethods.cs
- datacache.cs
- MimeTypeMapper.cs
- DataGrid.cs
- WsiProfilesElement.cs
- PageWrapper.cs
- HiddenField.cs
- GeometryGroup.cs
- coordinatorfactory.cs
- ModelMemberCollection.cs
- SelectionItemProviderWrapper.cs
- DbConnectionOptions.cs
- NameTable.cs
- Int32CollectionConverter.cs
- CfgParser.cs
- TextChange.cs
- ClickablePoint.cs
- WebHttpBindingCollectionElement.cs
- documentsequencetextpointer.cs
- Propagator.cs
- AssertSection.cs
- Int32RectConverter.cs
- Speller.cs
- CompoundFileReference.cs
- TemplateDefinition.cs
- TextSegment.cs
- TreeView.cs
- DateTimeConverter2.cs
- ColumnBinding.cs
- QueryHandler.cs
- SapiAttributeParser.cs
- DataGridTextBox.cs
- Constant.cs
- DecoratedNameAttribute.cs
- DataRowChangeEvent.cs
- OleDbParameter.cs
- HyperLinkField.cs
- XmlSerializerSection.cs
- RTLAwareMessageBox.cs
- EventBuilder.cs
- HMACSHA384.cs