mirror of
https://github.com/ICDSystems/ICD.Common.Utils.git
synced 2026-02-16 05:05:05 +00:00
refactor: Splitting JSON extensions into Reader and Writer extensions, removing unused code
This commit is contained in:
@@ -3,39 +3,14 @@ using System.Collections.Generic;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using ICD.Common.Properties;
|
using ICD.Common.Properties;
|
||||||
using Newtonsoft.Json;
|
using Newtonsoft.Json;
|
||||||
using Newtonsoft.Json.Linq;
|
|
||||||
|
|
||||||
namespace ICD.Common.Utils.Extensions
|
namespace ICD.Common.Utils.Extensions
|
||||||
{
|
{
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Extension methods for working with JSON.
|
/// Extension methods for working with JSON.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static class JsonExtensions
|
public static class JsonReaderExtensions
|
||||||
{
|
{
|
||||||
/// <summary>
|
|
||||||
/// Writes the object value.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="extends"></param>
|
|
||||||
/// <param name="value"></param>
|
|
||||||
/// <param name="serializer"></param>
|
|
||||||
/// <param name="converter"></param>
|
|
||||||
[PublicAPI]
|
|
||||||
public static void WriteObject(this JsonWriter extends, object value, JsonSerializer serializer,
|
|
||||||
JsonConverter converter)
|
|
||||||
{
|
|
||||||
if (extends == null)
|
|
||||||
throw new ArgumentNullException("extends");
|
|
||||||
|
|
||||||
if (serializer == null)
|
|
||||||
throw new ArgumentNullException("serializer");
|
|
||||||
|
|
||||||
if (converter == null)
|
|
||||||
throw new ArgumentNullException("converter");
|
|
||||||
|
|
||||||
JObject jObject = JObject.FromObject(value, serializer);
|
|
||||||
jObject.WriteTo(extends, converter);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Reads the current token in the reader and deserializes to the given type.
|
/// Reads the current token in the reader and deserializes to the given type.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -110,31 +85,6 @@ namespace ICD.Common.Utils.Extensions
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Writes the type value.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="extends"></param>
|
|
||||||
/// <param name="type"></param>
|
|
||||||
[PublicAPI]
|
|
||||||
public static void WriteType(this JsonWriter extends, Type type)
|
|
||||||
{
|
|
||||||
if (extends == null)
|
|
||||||
throw new ArgumentNullException("extends");
|
|
||||||
|
|
||||||
if (type == null)
|
|
||||||
{
|
|
||||||
extends.WriteNull();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Find the smallest possible name representation for the type that will still resolve
|
|
||||||
string name = Type.GetType(type.FullName) == null
|
|
||||||
? type.AssemblyQualifiedName
|
|
||||||
: type.FullName;
|
|
||||||
|
|
||||||
extends.WriteValue(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Gets the current value as a Type.
|
/// Gets the current value as a Type.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -240,58 +190,6 @@ namespace ICD.Common.Utils.Extensions
|
|||||||
return (T)(object)extends.GetValueAsInt();
|
return (T)(object)extends.GetValueAsInt();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Serializes the given sequence of items to the writer.
|
|
||||||
/// </summary>
|
|
||||||
/// <typeparam name="TItem"></typeparam>
|
|
||||||
/// <param name="extends"></param>
|
|
||||||
/// <param name="writer"></param>
|
|
||||||
/// <param name="items"></param>
|
|
||||||
public static void SerializeArray<TItem>(this JsonSerializer extends, JsonWriter writer, IEnumerable<TItem> items)
|
|
||||||
{
|
|
||||||
if (extends == null)
|
|
||||||
throw new ArgumentNullException("extends");
|
|
||||||
|
|
||||||
if (writer == null)
|
|
||||||
throw new ArgumentNullException("writer");
|
|
||||||
|
|
||||||
if (items == null)
|
|
||||||
throw new ArgumentNullException("items");
|
|
||||||
|
|
||||||
extends.SerializeArray(writer, items, (s, w, item) => s.Serialize(w, item));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Serializes the given sequence of items to the writer.
|
|
||||||
/// </summary>
|
|
||||||
/// <typeparam name="TItem"></typeparam>
|
|
||||||
/// <param name="extends"></param>
|
|
||||||
/// <param name="writer"></param>
|
|
||||||
/// <param name="items"></param>
|
|
||||||
/// <param name="write"></param>
|
|
||||||
public static void SerializeArray<TItem>(this JsonSerializer extends, JsonWriter writer, IEnumerable<TItem> items,
|
|
||||||
Action<JsonSerializer, JsonWriter, TItem> write)
|
|
||||||
{
|
|
||||||
if (extends == null)
|
|
||||||
throw new ArgumentNullException("extends");
|
|
||||||
|
|
||||||
if (writer == null)
|
|
||||||
throw new ArgumentNullException("writer");
|
|
||||||
|
|
||||||
if (items == null)
|
|
||||||
throw new ArgumentNullException("items");
|
|
||||||
|
|
||||||
if (write == null)
|
|
||||||
throw new ArgumentNullException("write");
|
|
||||||
|
|
||||||
writer.WriteStartArray();
|
|
||||||
{
|
|
||||||
foreach (TItem item in items)
|
|
||||||
write(extends, writer, item);
|
|
||||||
}
|
|
||||||
writer.WriteEndArray();
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Deserializes an array of items from the reader's current value.
|
/// Deserializes an array of items from the reader's current value.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
87
ICD.Common.Utils/Extensions/JsonWriterExtensions.cs
Normal file
87
ICD.Common.Utils/Extensions/JsonWriterExtensions.cs
Normal file
@@ -0,0 +1,87 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using ICD.Common.Properties;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
|
||||||
|
namespace ICD.Common.Utils.Extensions
|
||||||
|
{
|
||||||
|
public static class JsonWriterExtensions
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// Writes the type value.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="extends"></param>
|
||||||
|
/// <param name="type"></param>
|
||||||
|
[PublicAPI]
|
||||||
|
public static void WriteType(this JsonWriter extends, Type type)
|
||||||
|
{
|
||||||
|
if (extends == null)
|
||||||
|
throw new ArgumentNullException("extends");
|
||||||
|
|
||||||
|
if (type == null)
|
||||||
|
{
|
||||||
|
extends.WriteNull();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Find the smallest possible name representation for the type that will still resolve
|
||||||
|
string name = Type.GetType(type.FullName) == null
|
||||||
|
? type.AssemblyQualifiedName
|
||||||
|
: type.FullName;
|
||||||
|
|
||||||
|
extends.WriteValue(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Serializes the given sequence of items to the writer.
|
||||||
|
/// </summary>
|
||||||
|
/// <typeparam name="TItem"></typeparam>
|
||||||
|
/// <param name="extends"></param>
|
||||||
|
/// <param name="writer"></param>
|
||||||
|
/// <param name="items"></param>
|
||||||
|
public static void SerializeArray<TItem>(this JsonSerializer extends, JsonWriter writer, IEnumerable<TItem> items)
|
||||||
|
{
|
||||||
|
if (extends == null)
|
||||||
|
throw new ArgumentNullException("extends");
|
||||||
|
|
||||||
|
if (writer == null)
|
||||||
|
throw new ArgumentNullException("writer");
|
||||||
|
|
||||||
|
if (items == null)
|
||||||
|
throw new ArgumentNullException("items");
|
||||||
|
|
||||||
|
extends.SerializeArray(writer, items, (s, w, item) => s.Serialize(w, item));
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Serializes the given sequence of items to the writer.
|
||||||
|
/// </summary>
|
||||||
|
/// <typeparam name="TItem"></typeparam>
|
||||||
|
/// <param name="extends"></param>
|
||||||
|
/// <param name="writer"></param>
|
||||||
|
/// <param name="items"></param>
|
||||||
|
/// <param name="write"></param>
|
||||||
|
public static void SerializeArray<TItem>(this JsonSerializer extends, JsonWriter writer, IEnumerable<TItem> items,
|
||||||
|
Action<JsonSerializer, JsonWriter, TItem> write)
|
||||||
|
{
|
||||||
|
if (extends == null)
|
||||||
|
throw new ArgumentNullException("extends");
|
||||||
|
|
||||||
|
if (writer == null)
|
||||||
|
throw new ArgumentNullException("writer");
|
||||||
|
|
||||||
|
if (items == null)
|
||||||
|
throw new ArgumentNullException("items");
|
||||||
|
|
||||||
|
if (write == null)
|
||||||
|
throw new ArgumentNullException("write");
|
||||||
|
|
||||||
|
writer.WriteStartArray();
|
||||||
|
{
|
||||||
|
foreach (TItem item in items)
|
||||||
|
write(extends, writer, item);
|
||||||
|
}
|
||||||
|
writer.WriteEndArray();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -106,6 +106,7 @@
|
|||||||
<Compile Include="Extensions\BoolExtensions.cs" />
|
<Compile Include="Extensions\BoolExtensions.cs" />
|
||||||
<Compile Include="Extensions\ByteExtensions.cs" />
|
<Compile Include="Extensions\ByteExtensions.cs" />
|
||||||
<Compile Include="Extensions\DayOfWeekExtensions.cs" />
|
<Compile Include="Extensions\DayOfWeekExtensions.cs" />
|
||||||
|
<Compile Include="Extensions\JsonWriterExtensions.cs" />
|
||||||
<Compile Include="Extensions\ListExtensions.cs" />
|
<Compile Include="Extensions\ListExtensions.cs" />
|
||||||
<Compile Include="Comparers\PredicateEqualityComparer.cs" />
|
<Compile Include="Comparers\PredicateEqualityComparer.cs" />
|
||||||
<Compile Include="Extensions\MethodInfoExtensions.cs" />
|
<Compile Include="Extensions\MethodInfoExtensions.cs" />
|
||||||
@@ -154,7 +155,7 @@
|
|||||||
<Compile Include="Extensions\EnumerableExtensions.cs" />
|
<Compile Include="Extensions\EnumerableExtensions.cs" />
|
||||||
<Compile Include="Extensions\EnumExtensions.cs" />
|
<Compile Include="Extensions\EnumExtensions.cs" />
|
||||||
<Compile Include="Extensions\EventHandlerExtensions.cs" />
|
<Compile Include="Extensions\EventHandlerExtensions.cs" />
|
||||||
<Compile Include="Extensions\JsonExtensions.cs" />
|
<Compile Include="Extensions\JsonReaderExtensions.cs" />
|
||||||
<Compile Include="Extensions\QueueExtensions.cs" />
|
<Compile Include="Extensions\QueueExtensions.cs" />
|
||||||
<Compile Include="Extensions\ReflectionExtensions.cs" />
|
<Compile Include="Extensions\ReflectionExtensions.cs" />
|
||||||
<Compile Include="Extensions\StringBuilderExtensions.cs" />
|
<Compile Include="Extensions\StringBuilderExtensions.cs" />
|
||||||
|
|||||||
Reference in New Issue
Block a user