/* * 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.Collections.Generic; using Newtonsoft.Json; namespace QuantConnect.Util { /// /// Reads json and always produces a List, even if the input has just an object /// public class SingleValueListConverter : JsonConverter { /// /// Writes the JSON representation of the object. If the instance is not a list then it will /// be wrapped in a list /// /// The to write to. /// The value. /// The calling serializer. public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer) { if (value is T) { value = new List {(T)value}; } serializer.Serialize(writer, value); } /// /// Reads the JSON representation of the object. If the JSON represents a singular instance, it will be returned /// in a list. /// /// The to read from. /// Type of the object. /// The existing value of object being read. /// The calling serializer. /// The object value public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer) { switch (reader.TokenType) { case JsonToken.String: case JsonToken.StartObject: return new List {serializer.Deserialize(reader)}; case JsonToken.StartArray: return serializer.Deserialize>(reader); default: throw new ArgumentException("The JsonReader is expected to point at a JsonToken.StartObject or JsonToken.StartArray."); } } /// /// Determines whether this instance can convert the specified object type. /// /// Type of the object. /// true if this instance can convert the specified object type; otherwise, false. public override bool CanConvert(Type objectType) { return objectType == typeof(T) || objectType == typeof(List); } } }