Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / ndp / fx / src / DataEntity / System / Data / Objects / ObjectViewEntityCollectionData.cs / 1 / ObjectViewEntityCollectionData.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner jhutson // @backupOwner [....] //--------------------------------------------------------------------- using System; using System.Collections.Generic; using System.ComponentModel; using System.Data.Objects.DataClasses; using System.Diagnostics; namespace System.Data.Objects { ////// Manages a binding list constructed from an EntityCollection. /// ////// Type of the elements in the binding list. /// ////// Type of element in the underlying EntityCollection. /// ////// The binding list is initialized from the EntityCollection, /// and is synchronized with changes made to the EntityCollection membership. /// This class always allows additions and removals from the binding list. /// internal sealed class ObjectViewEntityCollectionData: IObjectViewData where TItemElement : class, IEntityWithRelationships where TViewElement : TItemElement { private List _bindingList; private EntityCollection _entityCollection; private readonly bool _canEditItems; /// /// True if item that was added to binding list but not underlying entity collection /// is now being committed to the collection. /// Otherwise false. /// Used by CommitItemAt and OnCollectionChanged methods to coordinate addition /// of new item to underlying entity collection. /// private bool _itemCommitPending; ////// Construct a new instance of the ObjectViewEntityCollectionData class using the supplied entityCollection. /// /// /// EntityCollection used to populate the binding list. /// internal ObjectViewEntityCollectionData(EntityCollectionentityCollection) { _entityCollection = entityCollection; _canEditItems = typeof(IEntityWithChangeTracker).IsAssignableFrom(typeof(TViewElement)); _bindingList = new List (entityCollection.Count); foreach (TViewElement entity in entityCollection) { _bindingList.Add(entity); } } #region IObjectViewData Members public IList List { get { return _bindingList; } } public bool AllowNew { get { return !_entityCollection.IsReadOnly; } } public bool AllowEdit { get { return _canEditItems; } } public bool AllowRemove { get { return !_entityCollection.IsReadOnly; } } public bool FiresEventOnAdd { get { return true; } } public bool FiresEventOnRemove { get { return true; } } public bool FiresEventOnClear { get { return true; } } public void EnsureCanAddNew() { // nop } public int Add(TViewElement item, bool isAddNew) { if (isAddNew) { // Item is added to bindingList, but pending addition to entity collection. _bindingList.Add(item); } else { _entityCollection.Add(item); // OnCollectionChanged will be fired, where the binding list will be updated. } return _bindingList.Count - 1; } public void CommitItemAt(int index) { TViewElement item = _bindingList[index]; try { _itemCommitPending = true; _entityCollection.Add(item); // OnCollectionChanged will be fired, where the binding list will be updated. } finally { _itemCommitPending = false; } } public void Clear() { if (0 < _bindingList.Count) { List _deletionList = new List (); foreach (object item in _bindingList) { _deletionList.Add(item as IEntityWithRelationships); } _entityCollection.BulkDeleteAll(_deletionList); // EntityCollection will fire change event which this instance will use to clean up the binding list. } } public bool Remove(TViewElement item, bool isCancelNew) { bool removed; if (isCancelNew) { // Item was previously added to binding list, but not entity collection. removed = _bindingList.Remove(item); } else { removed = _entityCollection.Remove(item); // OnCollectionChanged will be fired, where the binding list will be updated. } return removed; } public ListChangedEventArgs OnCollectionChanged(object sender, CollectionChangeEventArgs e, ObjectViewListener listener) { ListChangedEventArgs changeArgs = null; switch (e.Action) { case CollectionChangeAction.Remove: // An Entity is being removed from entity collection, remove it from list. if (e.Element is TViewElement) { TViewElement removedItem = (TViewElement)e.Element; int oldIndex = _bindingList.IndexOf(removedItem); if (oldIndex != -1) { _bindingList.Remove(removedItem); // Unhook from events of removed entity. listener.UnregisterEntityEvents(removedItem); changeArgs = new ListChangedEventArgs(ListChangedType.ItemDeleted, oldIndex /* newIndex*/, -1 /* oldIndex*/); } } break; case CollectionChangeAction.Add: // Add the entity to our list. if (e.Element is TViewElement) { // Do not process Add events that fire as a result of committing an item to the entity collection. if (!_itemCommitPending) { TViewElement addedItem = (TViewElement)e.Element; _bindingList.Add(addedItem); // Register to its events. listener.RegisterEntityEvents(addedItem); changeArgs = new ListChangedEventArgs(ListChangedType.ItemAdded, _bindingList.Count - 1 /* newIndex*/, -1 /* oldIndex*/); } } break; case CollectionChangeAction.Refresh: foreach (TViewElement entity in _bindingList) { Debug.Assert(entity is IEntityWithChangeTracker, "entity must be type IEntityWithChangeTracker"); listener.UnregisterEntityEvents(entity); } _bindingList.Clear(); foreach (TViewElement entity in _entityCollection) { _bindingList.Add(entity); Debug.Assert(entity is IEntityWithChangeTracker, "entity must be type IEntityWithChangeTracker"); listener.RegisterEntityEvents(entity); } changeArgs = new ListChangedEventArgs(ListChangedType.Reset, -1 /*newIndex*/, -1/*oldIndex*/); break; } return changeArgs; } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- // // Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner jhutson // @backupOwner [....] //--------------------------------------------------------------------- using System; using System.Collections.Generic; using System.ComponentModel; using System.Data.Objects.DataClasses; using System.Diagnostics; namespace System.Data.Objects { ////// Manages a binding list constructed from an EntityCollection. /// ////// Type of the elements in the binding list. /// ////// Type of element in the underlying EntityCollection. /// ////// The binding list is initialized from the EntityCollection, /// and is synchronized with changes made to the EntityCollection membership. /// This class always allows additions and removals from the binding list. /// internal sealed class ObjectViewEntityCollectionData: IObjectViewData where TItemElement : class, IEntityWithRelationships where TViewElement : TItemElement { private List _bindingList; private EntityCollection _entityCollection; private readonly bool _canEditItems; /// /// True if item that was added to binding list but not underlying entity collection /// is now being committed to the collection. /// Otherwise false. /// Used by CommitItemAt and OnCollectionChanged methods to coordinate addition /// of new item to underlying entity collection. /// private bool _itemCommitPending; ////// Construct a new instance of the ObjectViewEntityCollectionData class using the supplied entityCollection. /// /// /// EntityCollection used to populate the binding list. /// internal ObjectViewEntityCollectionData(EntityCollectionentityCollection) { _entityCollection = entityCollection; _canEditItems = typeof(IEntityWithChangeTracker).IsAssignableFrom(typeof(TViewElement)); _bindingList = new List (entityCollection.Count); foreach (TViewElement entity in entityCollection) { _bindingList.Add(entity); } } #region IObjectViewData Members public IList List { get { return _bindingList; } } public bool AllowNew { get { return !_entityCollection.IsReadOnly; } } public bool AllowEdit { get { return _canEditItems; } } public bool AllowRemove { get { return !_entityCollection.IsReadOnly; } } public bool FiresEventOnAdd { get { return true; } } public bool FiresEventOnRemove { get { return true; } } public bool FiresEventOnClear { get { return true; } } public void EnsureCanAddNew() { // nop } public int Add(TViewElement item, bool isAddNew) { if (isAddNew) { // Item is added to bindingList, but pending addition to entity collection. _bindingList.Add(item); } else { _entityCollection.Add(item); // OnCollectionChanged will be fired, where the binding list will be updated. } return _bindingList.Count - 1; } public void CommitItemAt(int index) { TViewElement item = _bindingList[index]; try { _itemCommitPending = true; _entityCollection.Add(item); // OnCollectionChanged will be fired, where the binding list will be updated. } finally { _itemCommitPending = false; } } public void Clear() { if (0 < _bindingList.Count) { List _deletionList = new List (); foreach (object item in _bindingList) { _deletionList.Add(item as IEntityWithRelationships); } _entityCollection.BulkDeleteAll(_deletionList); // EntityCollection will fire change event which this instance will use to clean up the binding list. } } public bool Remove(TViewElement item, bool isCancelNew) { bool removed; if (isCancelNew) { // Item was previously added to binding list, but not entity collection. removed = _bindingList.Remove(item); } else { removed = _entityCollection.Remove(item); // OnCollectionChanged will be fired, where the binding list will be updated. } return removed; } public ListChangedEventArgs OnCollectionChanged(object sender, CollectionChangeEventArgs e, ObjectViewListener listener) { ListChangedEventArgs changeArgs = null; switch (e.Action) { case CollectionChangeAction.Remove: // An Entity is being removed from entity collection, remove it from list. if (e.Element is TViewElement) { TViewElement removedItem = (TViewElement)e.Element; int oldIndex = _bindingList.IndexOf(removedItem); if (oldIndex != -1) { _bindingList.Remove(removedItem); // Unhook from events of removed entity. listener.UnregisterEntityEvents(removedItem); changeArgs = new ListChangedEventArgs(ListChangedType.ItemDeleted, oldIndex /* newIndex*/, -1 /* oldIndex*/); } } break; case CollectionChangeAction.Add: // Add the entity to our list. if (e.Element is TViewElement) { // Do not process Add events that fire as a result of committing an item to the entity collection. if (!_itemCommitPending) { TViewElement addedItem = (TViewElement)e.Element; _bindingList.Add(addedItem); // Register to its events. listener.RegisterEntityEvents(addedItem); changeArgs = new ListChangedEventArgs(ListChangedType.ItemAdded, _bindingList.Count - 1 /* newIndex*/, -1 /* oldIndex*/); } } break; case CollectionChangeAction.Refresh: foreach (TViewElement entity in _bindingList) { Debug.Assert(entity is IEntityWithChangeTracker, "entity must be type IEntityWithChangeTracker"); listener.UnregisterEntityEvents(entity); } _bindingList.Clear(); foreach (TViewElement entity in _entityCollection) { _bindingList.Add(entity); Debug.Assert(entity is IEntityWithChangeTracker, "entity must be type IEntityWithChangeTracker"); listener.RegisterEntityEvents(entity); } changeArgs = new ListChangedEventArgs(ListChangedType.Reset, -1 /*newIndex*/, -1/*oldIndex*/); break; } return changeArgs; } #endregion } } // 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
- GenericTypeParameterBuilder.cs
- TemplateAction.cs
- _NativeSSPI.cs
- PageRanges.cs
- AppSettings.cs
- WebControlsSection.cs
- AliasGenerator.cs
- CounterSet.cs
- InvalidEnumArgumentException.cs
- ListDesigner.cs
- ItemsControlAutomationPeer.cs
- OutputCacheProviderCollection.cs
- SplitterCancelEvent.cs
- SQLBytesStorage.cs
- RoutedCommand.cs
- ObjectDataSourceDisposingEventArgs.cs
- TagPrefixCollection.cs
- BitmapMetadataEnumerator.cs
- recordstatefactory.cs
- FileLogRecordHeader.cs
- ExpressionBinding.cs
- PageThemeCodeDomTreeGenerator.cs
- CompositionAdorner.cs
- MetadataArtifactLoader.cs
- ImportOptions.cs
- EventBindingService.cs
- RoutingUtilities.cs
- TemplateInstanceAttribute.cs
- DataSourceHelper.cs
- EventLogPermissionEntryCollection.cs
- LicenseException.cs
- OdbcHandle.cs
- RemotingConfigParser.cs
- AssociationSetEnd.cs
- WindowsListViewItemCheckBox.cs
- PeerNameResolver.cs
- LocationFactory.cs
- PointLightBase.cs
- IsolatedStorageFile.cs
- DependencyPropertyKind.cs
- PerfCounterSection.cs
- AutoResetEvent.cs
- CursorConverter.cs
- PerfCounters.cs
- PersonalizationDictionary.cs
- HitTestParameters.cs
- SecurityUtils.cs
- TypeUnloadedException.cs
- TreeNodeCollection.cs
- TcpProcessProtocolHandler.cs
- SolidColorBrush.cs
- ExclusiveCanonicalizationTransform.cs
- DataServiceQueryOfT.cs
- HttpInputStream.cs
- XmlCollation.cs
- PnrpPermission.cs
- InvalidProgramException.cs
- UserValidatedEventArgs.cs
- util.cs
- Queue.cs
- ConnectorSelectionGlyph.cs
- StringValueConverter.cs
- IERequestCache.cs
- DbConnectionInternal.cs
- SQLResource.cs
- AuthenticationModulesSection.cs
- MatrixStack.cs
- NavigationWindow.cs
- FixedStringLookup.cs
- MetadataUtil.cs
- BackgroundWorker.cs
- NavigationService.cs
- Range.cs
- recordstatefactory.cs
- DataGridCaption.cs
- WebErrorHandler.cs
- SplitContainerDesigner.cs
- Lasso.cs
- ReadContentAsBinaryHelper.cs
- AssociationEndMember.cs
- glyphs.cs
- CqlLexer.cs
- HostUtils.cs
- TextServicesProperty.cs
- ColumnCollection.cs
- AxisAngleRotation3D.cs
- XmlQualifiedNameTest.cs
- ClaimTypeElementCollection.cs
- ItemsChangedEventArgs.cs
- ListQueryResults.cs
- TypeUtil.cs
- HasCopySemanticsAttribute.cs
- ContextQuery.cs
- ProfilePropertySettings.cs
- WebServiceFault.cs
- MatrixTransform.cs
- QilFactory.cs
- UnauthorizedAccessException.cs
- XmlSubtreeReader.cs
- CellLabel.cs