Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / DLinq / Dlinq / DataBindingList.cs / 1599186 / DataBindingList.cs
using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Linq; using System.Data.Linq.Mapping; using System.Reflection; using System.Runtime.CompilerServices; namespace System.Data.Linq.Provider { internal static class BindingList { [MethodImpl(MethodImplOptions.NoInlining | MethodImplOptions.NoOptimization)] internal static IBindingList Create(DataContext context, IEnumerable sequence) { List list = sequence.ToList(); MetaTable metaTable = context.Services.Model.GetTable(typeof(T)); if (metaTable != null) { ITable table = context.GetTable(metaTable.RowType.Type); Type bindingType = typeof(DataBindingList<>).MakeGenericType(metaTable.RowType.Type); return (IBindingList)Activator.CreateInstance(bindingType, BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic, null, new object[] { list, table }, null ); } else { return new SortableBindingList (list); } } } internal class DataBindingList : SortableBindingList where TEntity : class { private Table data; private TEntity addNewInstance; private TEntity cancelNewInstance; private bool addingNewInstance; internal DataBindingList(IList sequence, Table data) : base(sequence != null ? sequence : new List ()) { if (sequence == null) { throw Error.ArgumentNull("sequence"); } if (data == null) { throw Error.ArgumentNull("data"); } this.data = data; } protected override object AddNewCore() { addingNewInstance = true; addNewInstance = (TEntity)base.AddNewCore(); return addNewInstance; } protected override void InsertItem(int index, TEntity item) { base.InsertItem(index, item); if (!addingNewInstance && index >= 0 && index <= Count) { this.data.InsertOnSubmit(item); } } protected override void RemoveItem(int index) { if (index >= 0 && index < Count && this[index] == cancelNewInstance) { cancelNewInstance = null; } else { this.data.DeleteOnSubmit(this[index]); } base.RemoveItem(index); } protected override void SetItem(int index, TEntity item) { TEntity removedItem = this[index]; base.SetItem(index, item); if (index >= 0 && index < Count) { //Check to see if the user is trying to set an item that is currently being added via AddNew //If so then the list should not continue the AddNew; but instead add the item //that is being passed in. if (removedItem == addNewInstance) { addNewInstance = null; addingNewInstance = false; } else { this.data.DeleteOnSubmit(removedItem); } this.data.InsertOnSubmit(item); } } protected override void ClearItems() { this.data.DeleteAllOnSubmit(this.data.ToList()); base.ClearItems(); } public override void EndNew(int itemIndex) { if (itemIndex >= 0 && itemIndex < Count && this[itemIndex] == addNewInstance) { this.data.InsertOnSubmit(addNewInstance); addNewInstance = null; addingNewInstance = false; } base.EndNew(itemIndex); } public override void CancelNew(int itemIndex) { if (itemIndex >= 0 && itemIndex < Count && this[itemIndex] == addNewInstance) { cancelNewInstance = addNewInstance; addNewInstance = null; addingNewInstance = false; } base.CancelNew(itemIndex); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Linq; using System.Data.Linq.Mapping; using System.Reflection; using System.Runtime.CompilerServices; namespace System.Data.Linq.Provider { internal static class BindingList { [MethodImpl(MethodImplOptions.NoInlining | MethodImplOptions.NoOptimization)] internal static IBindingList Create (DataContext context, IEnumerable sequence) { List list = sequence.ToList(); MetaTable metaTable = context.Services.Model.GetTable(typeof(T)); if (metaTable != null) { ITable table = context.GetTable(metaTable.RowType.Type); Type bindingType = typeof(DataBindingList<>).MakeGenericType(metaTable.RowType.Type); return (IBindingList)Activator.CreateInstance(bindingType, BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic, null, new object[] { list, table }, null ); } else { return new SortableBindingList (list); } } } internal class DataBindingList : SortableBindingList where TEntity : class { private Table data; private TEntity addNewInstance; private TEntity cancelNewInstance; private bool addingNewInstance; internal DataBindingList(IList sequence, Table data) : base(sequence != null ? sequence : new List ()) { if (sequence == null) { throw Error.ArgumentNull("sequence"); } if (data == null) { throw Error.ArgumentNull("data"); } this.data = data; } protected override object AddNewCore() { addingNewInstance = true; addNewInstance = (TEntity)base.AddNewCore(); return addNewInstance; } protected override void InsertItem(int index, TEntity item) { base.InsertItem(index, item); if (!addingNewInstance && index >= 0 && index <= Count) { this.data.InsertOnSubmit(item); } } protected override void RemoveItem(int index) { if (index >= 0 && index < Count && this[index] == cancelNewInstance) { cancelNewInstance = null; } else { this.data.DeleteOnSubmit(this[index]); } base.RemoveItem(index); } protected override void SetItem(int index, TEntity item) { TEntity removedItem = this[index]; base.SetItem(index, item); if (index >= 0 && index < Count) { //Check to see if the user is trying to set an item that is currently being added via AddNew //If so then the list should not continue the AddNew; but instead add the item //that is being passed in. if (removedItem == addNewInstance) { addNewInstance = null; addingNewInstance = false; } else { this.data.DeleteOnSubmit(removedItem); } this.data.InsertOnSubmit(item); } } protected override void ClearItems() { this.data.DeleteAllOnSubmit(this.data.ToList()); base.ClearItems(); } public override void EndNew(int itemIndex) { if (itemIndex >= 0 && itemIndex < Count && this[itemIndex] == addNewInstance) { this.data.InsertOnSubmit(addNewInstance); addNewInstance = null; addingNewInstance = false; } base.EndNew(itemIndex); } public override void CancelNew(int itemIndex) { if (itemIndex >= 0 && itemIndex < Count && this[itemIndex] == addNewInstance) { cancelNewInstance = addNewInstance; addNewInstance = null; addingNewInstance = false; } base.CancelNew(itemIndex); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- RtfToken.cs
- PeerInvitationResponse.cs
- ComboBoxRenderer.cs
- DataContract.cs
- XsltException.cs
- DateTimeSerializationSection.cs
- Binding.cs
- UnsafeNativeMethods.cs
- NotifyCollectionChangedEventArgs.cs
- DBDataPermissionAttribute.cs
- TransactionFlowElement.cs
- RtType.cs
- ClonableStack.cs
- XmlAtomicValue.cs
- ResourceReader.cs
- _ConnectOverlappedAsyncResult.cs
- OdbcParameter.cs
- wgx_render.cs
- DiscoveryClientDocuments.cs
- GcHandle.cs
- BaseDataList.cs
- AttributeProviderAttribute.cs
- DataPagerFieldCollection.cs
- SortedDictionary.cs
- DataTableReader.cs
- GeometryDrawing.cs
- RulePatternOps.cs
- TransactionManager.cs
- WebExceptionStatus.cs
- GroupDescription.cs
- StyleModeStack.cs
- OperatorExpressions.cs
- HtmlToClrEventProxy.cs
- XPathDocumentIterator.cs
- WebPartUtil.cs
- OracleTimeSpan.cs
- MailAddress.cs
- UserControl.cs
- WebPartEditorApplyVerb.cs
- DetailsViewActionList.cs
- PrinterResolution.cs
- AnimatedTypeHelpers.cs
- XmlDocumentType.cs
- PointCollection.cs
- AnimatedTypeHelpers.cs
- SqlBulkCopyColumnMapping.cs
- ResourceType.cs
- StateMachineExecutionState.cs
- TraceHwndHost.cs
- DebugHandleTracker.cs
- RMEnrollmentPage2.cs
- NavigatingCancelEventArgs.cs
- TreeView.cs
- PreloadedPackages.cs
- MiniLockedBorderGlyph.cs
- PenCursorManager.cs
- MoveSizeWinEventHandler.cs
- BrushMappingModeValidation.cs
- DbMetaDataCollectionNames.cs
- ComponentConverter.cs
- NonBatchDirectoryCompiler.cs
- UTF7Encoding.cs
- PreProcessInputEventArgs.cs
- Thread.cs
- EditorZone.cs
- AuthenticatingEventArgs.cs
- SelectingProviderEventArgs.cs
- PackageDigitalSignatureManager.cs
- XmlSchemaComplexType.cs
- TypeConverterHelper.cs
- DiagnosticsElement.cs
- RoleBoolean.cs
- TemplatePartAttribute.cs
- NonVisualControlAttribute.cs
- DocumentApplicationJournalEntry.cs
- PartitionedStream.cs
- CacheForPrimitiveTypes.cs
- TransferRequestHandler.cs
- Encoding.cs
- WindowsTokenRoleProvider.cs
- ToolboxBitmapAttribute.cs
- ComponentSerializationService.cs
- ScriptDescriptor.cs
- SafeEventLogReadHandle.cs
- PageThemeBuildProvider.cs
- UTF7Encoding.cs
- SQLBytesStorage.cs
- WebPartConnectionCollection.cs
- TableLayoutPanelCellPosition.cs
- ProcessInfo.cs
- InterleavedZipPartStream.cs
- StorageSetMapping.cs
- DesignObjectWrapper.cs
- AudioFormatConverter.cs
- MenuTracker.cs
- HyperLink.cs
- ProtectedConfiguration.cs
- QilList.cs
- ErrorTableItemStyle.cs
- SendAgentStatusRequest.cs