Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / ndp / fx / src / DLinq / Dlinq / DataBindingList.cs / 1 / DataBindingList.cs
using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Linq; using System.Data.Linq.Mapping; using System.Reflection; namespace System.Data.Linq.Provider { internal static class BindingList { 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; namespace System.Data.Linq.Provider { internal static class BindingList { 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
- PolicyImporterElement.cs
- ListDesigner.cs
- ConnectivityStatus.cs
- ObjectHandle.cs
- CodeConditionStatement.cs
- TCEAdapterGenerator.cs
- PropertyGridEditorPart.cs
- ResXResourceSet.cs
- DriveNotFoundException.cs
- CompatibleComparer.cs
- XmlTypeAttribute.cs
- AutomationPropertyInfo.cs
- basenumberconverter.cs
- SendOperation.cs
- ImmutableObjectAttribute.cs
- ResourcePropertyMemberCodeDomSerializer.cs
- FileEnumerator.cs
- ChannelPoolSettings.cs
- DataTableExtensions.cs
- OdbcConnectionOpen.cs
- DataGridViewColumnTypePicker.cs
- LogReserveAndAppendState.cs
- UnknownBitmapEncoder.cs
- ColumnWidthChangingEvent.cs
- StringStorage.cs
- Dictionary.cs
- CodeArrayCreateExpression.cs
- MsmqIntegrationOutputChannel.cs
- LogArchiveSnapshot.cs
- FixedSOMTable.cs
- Misc.cs
- InfoCardAsymmetricCrypto.cs
- GenericIdentity.cs
- ZoneButton.cs
- QilParameter.cs
- FlowDocumentPage.cs
- GCHandleCookieTable.cs
- PermissionSet.cs
- CodePropertyReferenceExpression.cs
- ADConnectionHelper.cs
- DesignerImageAdapter.cs
- RtfToXamlReader.cs
- UICuesEvent.cs
- TableStyle.cs
- Int16AnimationUsingKeyFrames.cs
- StorageComplexPropertyMapping.cs
- BitmapEffectDrawing.cs
- DesignerAttribute.cs
- HttpPostServerProtocol.cs
- FileDialog_Vista.cs
- ClrProviderManifest.cs
- InfoCardServiceInstallComponent.cs
- SecurityContextTokenValidationException.cs
- Stroke.cs
- BindValidationContext.cs
- TimersDescriptionAttribute.cs
- XmlDataSourceNodeDescriptor.cs
- RTLAwareMessageBox.cs
- WebPartTransformerAttribute.cs
- IOThreadTimer.cs
- Vector3DAnimationBase.cs
- DataGridViewCellStyleConverter.cs
- LayoutInformation.cs
- RealProxy.cs
- ColumnResizeAdorner.cs
- MemberRestriction.cs
- WindowsMenu.cs
- ExpressionBuilderCollection.cs
- MouseOverProperty.cs
- EmptyTextWriter.cs
- StylusOverProperty.cs
- DataGridViewImageColumn.cs
- ProfileBuildProvider.cs
- XmlSchemaSimpleType.cs
- TableLayoutPanelCodeDomSerializer.cs
- DelegatedStream.cs
- PlaceHolder.cs
- ExceptionValidationRule.cs
- StubHelpers.cs
- DocumentSchemaValidator.cs
- XmlNodeReader.cs
- UnhandledExceptionEventArgs.cs
- PolyBezierSegment.cs
- MonitorWrapper.cs
- QilXmlReader.cs
- DeadCharTextComposition.cs
- DuplexChannel.cs
- FormattedTextSymbols.cs
- ConvertersCollection.cs
- ClientSponsor.cs
- XmlILIndex.cs
- DataGridPageChangedEventArgs.cs
- GlyphRunDrawing.cs
- CmsUtils.cs
- GeometryGroup.cs
- AdornerDecorator.cs
- DataGridViewLinkCell.cs
- ModelService.cs
- DecoderFallbackWithFailureFlag.cs
- TraceListener.cs