本文整理匯總了C#中QuantConnect.Data.BaseData.Clone方法的典型用法代碼示例。如果您正苦於以下問題:C# BaseData.Clone方法的具體用法?C# BaseData.Clone怎麽用?C# BaseData.Clone使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類QuantConnect.Data.BaseData
的用法示例。
在下文中一共展示了BaseData.Clone方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: RequiresFillForwardData
/// <summary>
/// Determines whether or not fill forward is required, and if true, will produce the new fill forward data
/// </summary>
/// <param name="fillForwardResolution"></param>
/// <param name="previous">The last piece of data emitted by this enumerator</param>
/// <param name="next">The next piece of data on the source enumerator, this may be null</param>
/// <param name="fillForward">When this function returns true, this will have a non-null value, null when the function returns false</param>
/// <returns>True when a new fill forward piece of data was produced and should be emitted by this enumerator</returns>
protected override bool RequiresFillForwardData(TimeSpan fillForwardResolution, BaseData previous, BaseData next, out BaseData fillForward)
{
fillForward = null;
var nextExpectedDataPointTime = (previous.EndTime + fillForwardResolution);
if (next != null)
{
// if not future data, just return the 'next'
if (next.EndTime <= nextExpectedDataPointTime)
{
return false;
}
// next is future data, fill forward in between
var clone = previous.Clone(true);
clone.Time = previous.Time + fillForwardResolution;
fillForward = clone;
return true;
}
// the underlying enumerator returned null, check to see if time has passed for fill fowarding
var currentLocalTime = _timeProvider.GetUtcNow().ConvertFromUtc(Exchange.TimeZone);
if (nextExpectedDataPointTime <= currentLocalTime)
{
var clone = previous.Clone(true);
clone.Time = previous.Time + fillForwardResolution;
fillForward = clone;
return true;
}
return false;
}