Lean  $LEAN_TAG$
FuncSecurityInitializer.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 
17 using System;
18 using Python.Runtime;
19 using QuantConnect.Util;
20 
22 {
23  /// <summary>
24  /// Provides a functional implementation of <see cref="ISecurityInitializer"/>
25  /// </summary>
27  {
28  private readonly Action<Security> _initializer;
29 
30  /// <summary>
31  /// Initializes a new instance of the <see cref="FuncSecurityInitializer"/> class
32  /// </summary>
33  /// <param name="initializer">The functional implementation of <see cref="ISecurityInitializer.Initialize"/></param>
34  public FuncSecurityInitializer(PyObject initializer)
35  {
36  _initializer = PythonUtil.ToAction<Security>(initializer);
37  if (_initializer == null)
38  {
39  throw new InvalidOperationException("FuncSecurityInitializer constructor requires an action taking a single security instance as an argument");
40  }
41  }
42 
43  /// <summary>
44  /// Initializes a new instance of the <see cref="FuncSecurityInitializer"/> class
45  /// </summary>
46  /// <param name="initializer">The functional implementation of <see cref="ISecurityInitializer.Initialize"/></param>
47  public FuncSecurityInitializer(Action<Security> initializer)
48  {
49  _initializer = initializer;
50  }
51 
52  /// <summary>
53  /// Initializes the specified security
54  /// </summary>
55  /// <param name="security">The security to be initialized</param>
56  public void Initialize(Security security)
57  {
58  _initializer(security);
59  }
60  }
61 }