Add doctype writing to serializers

This commit is contained in:
Matt Nadareski
2023-07-31 11:24:24 -04:00
parent 2b19129118
commit 74631d1f87
5 changed files with 118 additions and 7 deletions

View File

@@ -10,6 +10,16 @@ namespace SabreTools.Serialization
/// </summary>
public abstract partial class XmlSerializer<T>
{
/// <summary>
/// Serializes the defined type to an XML file
/// </summary>
/// <param name="obj">Data to serialize</param>
/// <param name="path">Path to the file to serialize to</param>
/// <param name="obj">Data to serialize</param>
/// <returns>True on successful serialization, false otherwise</returns>
public static bool SerializeToFile(T? obj, string path)
=> SerializeToFile(obj, path, null, null, null, null);
/// <summary>
/// Serializes the defined type to an XML file
/// </summary>
@@ -21,9 +31,9 @@ namespace SabreTools.Serialization
/// <param name="sysid">Optional DOCTYPE sysid</param>
/// <param name="subset">Optional DOCTYPE name</param>
/// <returns>True on successful serialization, false otherwise</returns>
public static bool SerializeToFile(T? obj, string path, string? name = null, string? pubid = null, string? sysid = null, string? subset = null)
protected static bool SerializeToFile(T? obj, string path, string? name = null, string? pubid = null, string? sysid = null, string? subset = null)
{
using var stream = SerializeToStream(obj);
using var stream = SerializeToStream(obj, name, pubid, sysid, subset);
if (stream == null)
return false;
@@ -32,6 +42,14 @@ namespace SabreTools.Serialization
return true;
}
/// <summary>
/// Serializes the defined type to a stream
/// </summary>
/// <param name="obj">Data to serialize</param>
/// <returns>Stream containing serialized data on success, null otherwise</returns>
public static Stream? SerializeToStream(T? obj)
=> SerializeToStream(obj, null, null, null, null);
/// <summary>
/// Serializes the defined type to a stream
/// </summary>
@@ -41,7 +59,7 @@ namespace SabreTools.Serialization
/// <param name="sysid">Optional DOCTYPE sysid</param>
/// <param name="subset">Optional DOCTYPE name</param>
/// <returns>Stream containing serialized data on success, null otherwise</returns>
public static Stream? SerializeToStream(T? obj, string? name = null, string? pubid = null, string? sysid = null, string? subset = null)
protected static Stream? SerializeToStream(T? obj, string? name = null, string? pubid = null, string? sysid = null, string? subset = null)
{
// If the object is null
if (obj == null)
@@ -70,5 +88,6 @@ namespace SabreTools.Serialization
stream.Seek(0, SeekOrigin.Begin);
return stream;
}
}
}