Lean  $LEAN_TAG$
ISecuritySeeder.cs
1 /*
2  * QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.
3  * Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation.
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  *
15 */
16 
18 {
19  /// <summary>
20  /// Used to seed the security with the correct price
21  /// </summary>
22  public interface ISecuritySeeder
23  {
24  /// <summary>
25  /// Seed the security
26  /// </summary>
27  /// <param name="security"><see cref="Security"/> being seeded</param>
28  /// <returns>true if the security was seeded, false otherwise</returns>
29  bool SeedSecurity(Security security);
30  }
31 
32  /// <summary>
33  /// Provides access to a null implementation for <see cref="ISecuritySeeder"/>
34  /// </summary>
35  public static class SecuritySeeder
36  {
37  /// <summary>
38  /// Gets an instance of <see cref="ISecuritySeeder"/> that is a no-op
39  /// </summary>
40  public static readonly ISecuritySeeder Null = new NullSecuritySeeder();
41 
42  private sealed class NullSecuritySeeder : ISecuritySeeder
43  {
44  public bool SeedSecurity(Security security)
45  {
46  return true;
47  }
48  }
49  }
50 }