mirror of
https://github.com/ShareX/ShareX.git
synced 2024-07-04 22:21:23 +12:00
JsonHelpers refactor
This commit is contained in:
parent
21d1073113
commit
955ae9128b
|
@ -35,6 +35,8 @@ public static class JsonHelpers
|
||||||
{
|
{
|
||||||
public static void Serialize<T>(T obj, TextWriter textWriter, DefaultValueHandling defaultValueHandling = DefaultValueHandling.Include,
|
public static void Serialize<T>(T obj, TextWriter textWriter, DefaultValueHandling defaultValueHandling = DefaultValueHandling.Include,
|
||||||
NullValueHandling nullValueHandling = NullValueHandling.Include, ISerializationBinder serializationBinder = null)
|
NullValueHandling nullValueHandling = NullValueHandling.Include, ISerializationBinder serializationBinder = null)
|
||||||
|
{
|
||||||
|
if (textWriter != null)
|
||||||
{
|
{
|
||||||
using (JsonTextWriter jsonTextWriter = new JsonTextWriter(textWriter))
|
using (JsonTextWriter jsonTextWriter = new JsonTextWriter(textWriter))
|
||||||
{
|
{
|
||||||
|
@ -50,6 +52,7 @@ public static class JsonHelpers
|
||||||
serializer.Serialize(jsonTextWriter, obj);
|
serializer.Serialize(jsonTextWriter, obj);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static string SerializeToString<T>(T obj, DefaultValueHandling defaultValueHandling = DefaultValueHandling.Include,
|
public static string SerializeToString<T>(T obj, DefaultValueHandling defaultValueHandling = DefaultValueHandling.Include,
|
||||||
NullValueHandling nullValueHandling = NullValueHandling.Include, ISerializationBinder serializationBinder = null)
|
NullValueHandling nullValueHandling = NullValueHandling.Include, ISerializationBinder serializationBinder = null)
|
||||||
|
@ -66,12 +69,15 @@ public static class JsonHelpers
|
||||||
|
|
||||||
public static void SerializeToStream<T>(T obj, Stream stream, DefaultValueHandling defaultValueHandling = DefaultValueHandling.Include,
|
public static void SerializeToStream<T>(T obj, Stream stream, DefaultValueHandling defaultValueHandling = DefaultValueHandling.Include,
|
||||||
NullValueHandling nullValueHandling = NullValueHandling.Include, ISerializationBinder serializationBinder = null)
|
NullValueHandling nullValueHandling = NullValueHandling.Include, ISerializationBinder serializationBinder = null)
|
||||||
|
{
|
||||||
|
if (stream != null)
|
||||||
{
|
{
|
||||||
using (StreamWriter streamWriter = new StreamWriter(stream))
|
using (StreamWriter streamWriter = new StreamWriter(stream))
|
||||||
{
|
{
|
||||||
Serialize(obj, streamWriter, defaultValueHandling, nullValueHandling, serializationBinder);
|
Serialize(obj, streamWriter, defaultValueHandling, nullValueHandling, serializationBinder);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static MemoryStream SerializeToMemoryStream<T>(T obj, DefaultValueHandling defaultValueHandling = DefaultValueHandling.Include,
|
public static MemoryStream SerializeToMemoryStream<T>(T obj, DefaultValueHandling defaultValueHandling = DefaultValueHandling.Include,
|
||||||
NullValueHandling nullValueHandling = NullValueHandling.Include, ISerializationBinder serializationBinder = null)
|
NullValueHandling nullValueHandling = NullValueHandling.Include, ISerializationBinder serializationBinder = null)
|
||||||
|
@ -96,6 +102,8 @@ public static class JsonHelpers
|
||||||
}
|
}
|
||||||
|
|
||||||
public static T Deserialize<T>(TextReader textReader, ISerializationBinder serializationBinder = null)
|
public static T Deserialize<T>(TextReader textReader, ISerializationBinder serializationBinder = null)
|
||||||
|
{
|
||||||
|
if (textReader != null)
|
||||||
{
|
{
|
||||||
using (JsonTextReader jsonTextReader = new JsonTextReader(textReader))
|
using (JsonTextReader jsonTextReader = new JsonTextReader(textReader))
|
||||||
{
|
{
|
||||||
|
@ -109,6 +117,9 @@ public static T Deserialize<T>(TextReader textReader, ISerializationBinder seria
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return default;
|
||||||
|
}
|
||||||
|
|
||||||
public static T DeserializeFromString<T>(string json, ISerializationBinder serializationBinder = null)
|
public static T DeserializeFromString<T>(string json, ISerializationBinder serializationBinder = null)
|
||||||
{
|
{
|
||||||
if (!string.IsNullOrEmpty(json))
|
if (!string.IsNullOrEmpty(json))
|
||||||
|
@ -122,6 +133,19 @@ public static T DeserializeFromString<T>(string json, ISerializationBinder seria
|
||||||
return default;
|
return default;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static T DeserializeFromStream<T>(Stream stream, ISerializationBinder serializationBinder = null)
|
||||||
|
{
|
||||||
|
if (stream != null)
|
||||||
|
{
|
||||||
|
using (StreamReader streamReader = new StreamReader(stream))
|
||||||
|
{
|
||||||
|
return Deserialize<T>(streamReader, serializationBinder);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return default;
|
||||||
|
}
|
||||||
|
|
||||||
public static T DeserializeFromFile<T>(string filePath, ISerializationBinder serializationBinder = null)
|
public static T DeserializeFromFile<T>(string filePath, ISerializationBinder serializationBinder = null)
|
||||||
{
|
{
|
||||||
if (!string.IsNullOrEmpty(filePath) && File.Exists(filePath))
|
if (!string.IsNullOrEmpty(filePath) && File.Exists(filePath))
|
||||||
|
@ -130,10 +154,7 @@ public static T DeserializeFromFile<T>(string filePath, ISerializationBinder ser
|
||||||
{
|
{
|
||||||
if (fileStream.Length > 0)
|
if (fileStream.Length > 0)
|
||||||
{
|
{
|
||||||
using (StreamReader streamReader = new StreamReader(fileStream))
|
return DeserializeFromStream<T>(fileStream, serializationBinder);
|
||||||
{
|
|
||||||
return Deserialize<T>(streamReader, serializationBinder);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue