Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Data / System / Data / DataRowCollection.cs / 1305376 / DataRowCollection.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //[....] //[....] //----------------------------------------------------------------------------- namespace System.Data { using System; using System.Collections; using System.ComponentModel; using System.Diagnostics; public sealed class DataRowCollection : InternalDataCollectionBase { private sealed class DataRowTree : RBTree{ internal DataRowTree() : base(TreeAccessMethod.INDEX_ONLY) { } protected override int CompareNode (DataRow record1, DataRow record2) { throw ExceptionBuilder.InternalRBTreeError(RBTreeError.CompareNodeInDataRowTree); } protected override int CompareSateliteTreeNode (DataRow record1, DataRow record2) { throw ExceptionBuilder.InternalRBTreeError(RBTreeError.CompareSateliteTreeNodeInDataRowTree); } } private readonly DataTable table; private readonly DataRowTree list = new DataRowTree(); internal int nullInList = 0; /// /// Creates the DataRowCollection for the given table. /// internal DataRowCollection(DataTable table) { this.table = table; } public override int Count { get { return list.Count; } } ////// public DataRow this[int index] { get { return list[index]; } } ///Gets the row at the specified index. ////// public void Add(DataRow row) { table.AddRow(row, -1); } public void InsertAt(DataRow row, int pos) { if (pos < 0) throw ExceptionBuilder.RowInsertOutOfRange(pos); if (pos >= list.Count) table.AddRow(row, -1); else table.InsertRow(row, -1, pos); } internal void DiffInsertAt(DataRow row, int pos) { if ((pos < 0) || (pos == list.Count)) { table.AddRow(row, pos >-1? pos+1 : -1); return; } if (table.NestedParentRelations.Length > 0) { // get in this trouble only if table has a nested parent // get into trouble if table has JUST a nested parent? how about multi parent! if (pos < list.Count) { if (list[pos] != null) { throw ExceptionBuilder.RowInsertTwice(pos, table.TableName); } list.RemoveAt(pos); nullInList--; table.InsertRow(row, pos+1, pos); } else { while (pos>list.Count) { list.Add(null); nullInList++; } table.AddRow(row, pos+1); } } else { table.InsertRow(row, pos+1, pos > list.Count ? -1 : pos); } } public Int32 IndexOf(DataRow row) { if ((null == row) || (row.Table != this.table) || ((0 == row.RBTreeNodeId) && (row.RowState == DataRowState.Detached))) //Webdata 102857 return -1; return list.IndexOf(row.RBTreeNodeId, row); } ///Adds the specified ///to the object. /// internal DataRow AddWithColumnEvents(params object[] values) { DataRow row = table.NewRow(-1); row.ItemArray = values; table.AddRow(row, -1); return row; } public DataRow Add(params object[] values) { int record = table.NewRecordFromArray(values); DataRow row = table.NewRow(record); table.AddRow(row, -1); return row; } internal void ArrayAdd(DataRow row) { row.RBTreeNodeId = list.Add(row); } internal void ArrayInsert(DataRow row, int pos) { row.RBTreeNodeId = list.Insert(pos, row); } internal void ArrayClear() { list.Clear(); } internal void ArrayRemove(DataRow row) { if (row.RBTreeNodeId == 0) { throw ExceptionBuilder.InternalRBTreeError(RBTreeError.AttachedNodeWithZerorbTreeNodeId); } list.RBDelete(row.RBTreeNodeId); row.RBTreeNodeId = 0; } ///Creates a row using specified values and adds it to the /// ///. /// public DataRow Find(object key) { return table.FindByPrimaryKey(key); } ///Gets /// the row specified by the primary key value. /// ////// public DataRow Find(object[] keys) { return table.FindByPrimaryKey(keys); } ///Gets the row containing the specified primary key values. ////// public void Clear() { table.Clear(false); } ///Clears the collection of all rows. ////// public bool Contains(object key) { return(table.FindByPrimaryKey(key) != null); } ////// Gets a value indicating whether the primary key of any row in the /// collection contains the specified value. /// ////// public bool Contains(object[] keys) { return(table.FindByPrimaryKey(keys) != null); } public override void CopyTo(Array ar, int index) { list.CopyTo(ar, index); } public void CopyTo(DataRow[] array, int index) { list.CopyTo(array, index); } public override IEnumerator GetEnumerator() { return list.GetEnumerator(); } ////// Gets a value indicating if the ///with /// the specified primary key values exists. /// /// public void Remove(DataRow row) { if ((null == row) || (row.Table != table) || (-1 == row.rowID)) { throw ExceptionBuilder.RowOutOfRange(); } if ((row.RowState != DataRowState.Deleted) && (row.RowState != DataRowState.Detached)) row.Delete(); if (row.RowState != DataRowState.Detached) row.AcceptChanges(); } ///Removes the specified ///from the collection. /// public void RemoveAt(int index) { Remove(this[index]); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ ///// Removes the row with the specified index from /// the collection. /// ///// Copyright (c) Microsoft Corporation. All rights reserved. // //[....] //[....] //[....] //----------------------------------------------------------------------------- namespace System.Data { using System; using System.Collections; using System.ComponentModel; using System.Diagnostics; public sealed class DataRowCollection : InternalDataCollectionBase { private sealed class DataRowTree : RBTree{ internal DataRowTree() : base(TreeAccessMethod.INDEX_ONLY) { } protected override int CompareNode (DataRow record1, DataRow record2) { throw ExceptionBuilder.InternalRBTreeError(RBTreeError.CompareNodeInDataRowTree); } protected override int CompareSateliteTreeNode (DataRow record1, DataRow record2) { throw ExceptionBuilder.InternalRBTreeError(RBTreeError.CompareSateliteTreeNodeInDataRowTree); } } private readonly DataTable table; private readonly DataRowTree list = new DataRowTree(); internal int nullInList = 0; /// /// Creates the DataRowCollection for the given table. /// internal DataRowCollection(DataTable table) { this.table = table; } public override int Count { get { return list.Count; } } ////// public DataRow this[int index] { get { return list[index]; } } ///Gets the row at the specified index. ////// public void Add(DataRow row) { table.AddRow(row, -1); } public void InsertAt(DataRow row, int pos) { if (pos < 0) throw ExceptionBuilder.RowInsertOutOfRange(pos); if (pos >= list.Count) table.AddRow(row, -1); else table.InsertRow(row, -1, pos); } internal void DiffInsertAt(DataRow row, int pos) { if ((pos < 0) || (pos == list.Count)) { table.AddRow(row, pos >-1? pos+1 : -1); return; } if (table.NestedParentRelations.Length > 0) { // get in this trouble only if table has a nested parent // get into trouble if table has JUST a nested parent? how about multi parent! if (pos < list.Count) { if (list[pos] != null) { throw ExceptionBuilder.RowInsertTwice(pos, table.TableName); } list.RemoveAt(pos); nullInList--; table.InsertRow(row, pos+1, pos); } else { while (pos>list.Count) { list.Add(null); nullInList++; } table.AddRow(row, pos+1); } } else { table.InsertRow(row, pos+1, pos > list.Count ? -1 : pos); } } public Int32 IndexOf(DataRow row) { if ((null == row) || (row.Table != this.table) || ((0 == row.RBTreeNodeId) && (row.RowState == DataRowState.Detached))) //Webdata 102857 return -1; return list.IndexOf(row.RBTreeNodeId, row); } ///Adds the specified ///to the object. /// internal DataRow AddWithColumnEvents(params object[] values) { DataRow row = table.NewRow(-1); row.ItemArray = values; table.AddRow(row, -1); return row; } public DataRow Add(params object[] values) { int record = table.NewRecordFromArray(values); DataRow row = table.NewRow(record); table.AddRow(row, -1); return row; } internal void ArrayAdd(DataRow row) { row.RBTreeNodeId = list.Add(row); } internal void ArrayInsert(DataRow row, int pos) { row.RBTreeNodeId = list.Insert(pos, row); } internal void ArrayClear() { list.Clear(); } internal void ArrayRemove(DataRow row) { if (row.RBTreeNodeId == 0) { throw ExceptionBuilder.InternalRBTreeError(RBTreeError.AttachedNodeWithZerorbTreeNodeId); } list.RBDelete(row.RBTreeNodeId); row.RBTreeNodeId = 0; } ///Creates a row using specified values and adds it to the /// ///. /// public DataRow Find(object key) { return table.FindByPrimaryKey(key); } ///Gets /// the row specified by the primary key value. /// ////// public DataRow Find(object[] keys) { return table.FindByPrimaryKey(keys); } ///Gets the row containing the specified primary key values. ////// public void Clear() { table.Clear(false); } ///Clears the collection of all rows. ////// public bool Contains(object key) { return(table.FindByPrimaryKey(key) != null); } ////// Gets a value indicating whether the primary key of any row in the /// collection contains the specified value. /// ////// public bool Contains(object[] keys) { return(table.FindByPrimaryKey(keys) != null); } public override void CopyTo(Array ar, int index) { list.CopyTo(ar, index); } public void CopyTo(DataRow[] array, int index) { list.CopyTo(array, index); } public override IEnumerator GetEnumerator() { return list.GetEnumerator(); } ////// Gets a value indicating if the ///with /// the specified primary key values exists. /// /// public void Remove(DataRow row) { if ((null == row) || (row.Table != table) || (-1 == row.rowID)) { throw ExceptionBuilder.RowOutOfRange(); } if ((row.RowState != DataRowState.Deleted) && (row.RowState != DataRowState.Detached)) row.Delete(); if (row.RowState != DataRowState.Detached) row.AcceptChanges(); } ///Removes the specified ///from the collection. /// public void RemoveAt(int index) { Remove(this[index]); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007./// Removes the row with the specified index from /// the collection. /// ///
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- PrintDialog.cs
- NotifyInputEventArgs.cs
- Constants.cs
- EncodingNLS.cs
- ResourceContainer.cs
- TextEndOfLine.cs
- Int32KeyFrameCollection.cs
- HashAlgorithm.cs
- FormViewUpdateEventArgs.cs
- NotificationContext.cs
- DataGridViewAccessibleObject.cs
- InputEventArgs.cs
- WsdlWriter.cs
- ComplexPropertyEntry.cs
- TraceData.cs
- IDReferencePropertyAttribute.cs
- Expression.DebuggerProxy.cs
- MD5HashHelper.cs
- WebPartAuthorizationEventArgs.cs
- PenThreadWorker.cs
- EntityDataSourceStatementEditor.cs
- Brush.cs
- ColumnReorderedEventArgs.cs
- ChannelDispatcherCollection.cs
- EntityDesignPluralizationHandler.cs
- ParsedAttributeCollection.cs
- ISAPIRuntime.cs
- StringUtil.cs
- LoginUtil.cs
- ContractTypeNameElement.cs
- NumericUpDownAccelerationCollection.cs
- odbcmetadatacollectionnames.cs
- XmlWriterTraceListener.cs
- UserControlBuildProvider.cs
- PropertySourceInfo.cs
- MetadataCache.cs
- CompiledELinqQueryState.cs
- SafeNativeMethods.cs
- _ConnectionGroup.cs
- AnimationStorage.cs
- GregorianCalendarHelper.cs
- SqlPersonalizationProvider.cs
- Span.cs
- WebPartAddingEventArgs.cs
- AbsoluteQuery.cs
- ValidatingPropertiesEventArgs.cs
- TabletDeviceInfo.cs
- XsdCachingReader.cs
- CodeRemoveEventStatement.cs
- BitmapEffectGroup.cs
- ColorConverter.cs
- AdRotator.cs
- HtmlInputReset.cs
- EntityCollection.cs
- RandomNumberGenerator.cs
- HtmlTableCellCollection.cs
- ResourceSetExpression.cs
- DataGridHyperlinkColumn.cs
- TextBoxDesigner.cs
- DataChangedEventManager.cs
- ProcessActivityTreeOptions.cs
- SqlNotificationEventArgs.cs
- XmlAggregates.cs
- ControlPersister.cs
- HtmlImageAdapter.cs
- RootAction.cs
- ComponentSerializationService.cs
- AdornerHitTestResult.cs
- ReflectTypeDescriptionProvider.cs
- CompensationTokenData.cs
- KeyedHashAlgorithm.cs
- ContextMenuService.cs
- FrameworkName.cs
- ToolStripDropTargetManager.cs
- _DomainName.cs
- ProfileSettingsCollection.cs
- ListChangedEventArgs.cs
- RoutedEventConverter.cs
- ConfigurationStrings.cs
- SqlRowUpdatingEvent.cs
- LayoutTable.cs
- TileBrush.cs
- XPathChildIterator.cs
- XmlChoiceIdentifierAttribute.cs
- Shape.cs
- Effect.cs
- XmlIncludeAttribute.cs
- CacheDependency.cs
- CroppedBitmap.cs
- _NegoState.cs
- ImagingCache.cs
- ApplicationServicesHostFactory.cs
- PerformanceCounterPermission.cs
- HandleRef.cs
- AssemblyCache.cs
- PocoEntityKeyStrategy.cs
- SequentialWorkflowHeaderFooter.cs
- Cursor.cs
- UpdatePanelControlTrigger.cs
- WebPageTraceListener.cs