// LumenWorks.Framework.IO.CSV.CsvReader.RecordEnumerator
// Copyright (c) 2005 Sébastien Lorion
//
// MIT license (http://en.wikipedia.org/wiki/MIT_License)
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
// of the Software, and to permit persons to whom the Software is furnished to do so,
// subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in all
// copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED,
// INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
// PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE
// FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
using System;
using System.Collections;
using System.Collections.Generic;
using LumenWorks.Framework.IO.Csv.Resources;
namespace LumenWorks.Framework.IO.Csv
{
public partial class CsvReader
{
///
/// Supports a simple iteration over the records of a .
///
public struct RecordEnumerator
: IEnumerator, IEnumerator
{
#region Fields
///
/// Contains the enumerated .
///
private CsvReader _reader;
///
/// Contains the current record.
///
private string[] _current;
///
/// Contains the current record index.
///
private long _currentRecordIndex;
#endregion
#region Constructors
///
/// Initializes a new instance of the class.
///
/// The to iterate over.
///
/// is a .
///
public RecordEnumerator(CsvReader reader)
{
if (reader == null)
throw new ArgumentNullException("reader");
_reader = reader;
_current = null;
_currentRecordIndex = reader._currentRecordIndex;
}
#endregion
#region IEnumerator Members
///
/// Gets the current record.
///
public string[] Current
{
get { return _current; }
}
///
/// Advances the enumerator to the next record of the CSV.
///
/// if the enumerator was successfully advanced to the next record, if the enumerator has passed the end of the CSV.
public bool MoveNext()
{
if (_reader._currentRecordIndex != _currentRecordIndex)
throw new InvalidOperationException(ExceptionMessage.EnumerationVersionCheckFailed);
if (_reader.ReadNextRecord())
{
_current = new string[_reader._fieldCount];
_reader.CopyCurrentRecordTo(_current);
_currentRecordIndex = _reader._currentRecordIndex;
return true;
}
else
{
_current = null;
_currentRecordIndex = _reader._currentRecordIndex;
return false;
}
}
#endregion
#region IEnumerator Members
///
/// Sets the enumerator to its initial position, which is before the first record in the CSV.
///
public void Reset()
{
if (_reader._currentRecordIndex != _currentRecordIndex)
throw new InvalidOperationException(ExceptionMessage.EnumerationVersionCheckFailed);
_reader.MoveTo(-1);
_current = null;
_currentRecordIndex = _reader._currentRecordIndex;
}
///
/// Gets the current record.
///
object IEnumerator.Current
{
get
{
if (_reader._currentRecordIndex != _currentRecordIndex)
throw new InvalidOperationException(ExceptionMessage.EnumerationVersionCheckFailed);
return this.Current;
}
}
#endregion
#region IDisposable Members
///
/// Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources.
///
public void Dispose()
{
_reader = null;
_current = null;
}
#endregion
}
}
}