/* * QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals. * Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ using System; using System.IO; using QuantConnect.Util; using System.Collections; using System.Collections.Generic; namespace QuantConnect.Lean.Engine.DataFeeds.Enumerators { /// /// Provides an implementation of that will /// always return true via MoveNext. /// /// public class RefreshEnumerator : IEnumerator { private T _current; private IEnumerator _enumerator; private readonly Func> _enumeratorFactory; /// /// Initializes a new instance of the class /// /// Enumerator factory used to regenerate the underlying /// enumerator when it ends public RefreshEnumerator(Func> enumeratorFactory) { _enumeratorFactory = enumeratorFactory; } /// /// Advances the enumerator to the next element of the collection. /// /// /// true if the enumerator was successfully advanced to the next element; false if the enumerator has passed the end of the collection. /// /// The collection was modified after the enumerator was created. 2 public bool MoveNext() { if (_enumerator == null) { _enumerator = _enumeratorFactory.Invoke(); } var moveNext = false; try { moveNext = _enumerator.MoveNext(); if (moveNext) { _current = _enumerator.Current; } } catch (IOException exception) { // we will ignore stale file handle exceptions and retry instead, enumerator will be refreshed if (exception.Message == null || !exception.Message.Contains("Stale file handle", StringComparison.InvariantCultureIgnoreCase)) { throw; } } if (!moveNext) { _enumerator.DisposeSafely(); _enumerator = null; _current = default(T); } return true; } /// /// Sets the enumerator to its initial position, which is before the first element in the collection. /// /// The collection was modified after the enumerator was created. 2 public void Reset() { if (_enumerator != null) { _enumerator.Reset(); } } /// /// Gets the element in the collection at the current position of the enumerator. /// /// /// The element in the collection at the current position of the enumerator. /// public T Current { get { return _current; } } /// /// Gets the current element in the collection. /// /// /// The current element in the collection. /// /// 2 object IEnumerator.Current { get { return Current; } } /// /// Performs application-defined tasks associated with freeing, releasing, or resetting unmanaged resources. /// /// 2 public void Dispose() { if (_enumerator != null) { _enumerator.Dispose(); } } } }