DSInternals/Src/Microsoft.Database.Isam/RecordEnumerator.cs

87 lines
2.7 KiB
C#
Raw Normal View History

2016-01-23 21:00:26 +00:00
// ---------------------------------------------------------------------------
// <copyright file="RecordEnumerator.cs" company="Microsoft">
// Copyright (c) Microsoft Corporation. All rights reserved.
// </copyright>
// ---------------------------------------------------------------------------
// ---------------------------------------------------------------------
// <summary>
// </summary>
// ---------------------------------------------------------------------
namespace Microsoft.Database.Isam
{
using System.Collections;
/// <summary>
/// Enumerates the fields for a given record.
/// </summary>
public class RecordEnumerator : IEnumerator
{
/// <summary>
/// The enumerator
/// </summary>
private IDictionaryEnumerator enumerator;
/// <summary>
/// Initializes a new instance of the <see cref="RecordEnumerator"/> class.
/// </summary>
/// <param name="enumerator">The enumerator.</param>
internal RecordEnumerator(IDictionaryEnumerator enumerator)
{
this.enumerator = enumerator;
}
/// <summary>
/// Gets the current element in the collection.
/// </summary>
/// <returns>The current element in the collection.</returns>
/// <remarks>
/// This is the type safe version that may not work in other CLR
/// languages.
/// </remarks>
public FieldValueCollection Current
{
get
{
return (FieldValueCollection)this.enumerator.Value;
}
}
/// <summary>
/// Gets the current element in the collection.
/// </summary>
/// <returns>The current element in the collection.</returns>
/// <remarks>
/// This is the standard version that will work with other CLR
/// languages.
/// </remarks>
object IEnumerator.Current
{
get
{
return this.Current;
}
}
/// <summary>
/// Sets the enumerator to its initial position, which is before the first element in the collection.
/// </summary>
public void Reset()
{
this.enumerator.Reset();
}
/// <summary>
/// Advances the enumerator to the next element of the collection.
/// </summary>
/// <returns>
/// true if the enumerator was successfully advanced to the next element; false if the enumerator has passed the end of the collection.
/// </returns>
public bool MoveNext()
{
return this.enumerator.MoveNext();
}
}
}