Files
SabreTools/SabreTools.DatFiles/SerializableDatFile.cs

94 lines
3.8 KiB
C#
Raw Normal View History

using System;
2024-03-19 19:54:03 -04:00
using SabreTools.Models.Metadata;
using SabreTools.Serialization.Interfaces;
namespace SabreTools.DatFiles
{
/// <summary>
/// Represents a DAT that can be serialized
/// </summary>
2024-04-24 13:45:38 -04:00
/// <typeparam name="TModel">Base internal model for the DAT type</typeparam>
/// <typeparam name="TFileDeserializer">IFileDeserializer type to use for conversion</typeparam>
/// <typeparam name="TFileSerializer">IFileSerializer type to use for conversion</typeparam>
/// <typeparam name="TModelSerializer">IModelSerializer for cross-model serialization</typeparam>
public abstract class SerializableDatFile<TModel, TFileDeserializer, TFileSerializer, TModelSerializer> : DatFile
where TFileDeserializer : IFileDeserializer<TModel>
where TFileSerializer : IFileSerializer<TModel>
where TModelSerializer : IModelSerializer<TModel, MetadataFile>
{
/// <inheritdoc/>
protected SerializableDatFile(DatFile? datFile) : base(datFile) { }
/// <inheritdoc/>
public override void ParseFile(string filename, int indexId, bool keep, bool statsOnly = false, bool throwOnError = false)
{
try
{
// Deserialize the input file in two steps
2024-04-24 13:45:38 -04:00
var specificFormat = Activator.CreateInstance<TFileDeserializer>().Deserialize(filename);
var internalFormat = Activator.CreateInstance<TModelSerializer>().Serialize(specificFormat);
// Convert to the internal format
ConvertMetadata(internalFormat, filename, indexId, keep, statsOnly);
}
catch (Exception ex) when (!throwOnError)
{
string message = $"'{filename}' - An error occurred during parsing";
logger.Error(ex, message);
}
}
/// <inheritdoc/>
public override bool WriteToFile(string outfile, bool ignoreblanks = false, bool throwOnError = false)
{
try
{
logger.User($"Writing to '{outfile}'...");
// Serialize the input file in two steps
var internalFormat = ConvertMetadata(ignoreblanks);
2024-04-24 13:45:38 -04:00
var specificFormat = Activator.CreateInstance<TModelSerializer>().Deserialize(internalFormat);
if (!Activator.CreateInstance<TFileSerializer>().Serialize(specificFormat, outfile))
{
logger.Warning($"File '{outfile}' could not be written! See the log for more details.");
return false;
}
}
catch (Exception ex) when (!throwOnError)
{
logger.Error(ex);
return false;
}
logger.User($"'{outfile}' written!{Environment.NewLine}");
return true;
}
/// <inheritdoc/>
public override bool WriteToFileDB(string outfile, bool ignoreblanks = false, bool throwOnError = false)
{
try
{
logger.User($"Writing to '{outfile}'...");
// Serialize the input file in two steps
var internalFormat = ConvertMetadataDB(ignoreblanks);
2024-04-24 13:45:38 -04:00
var specificFormat = Activator.CreateInstance<TModelSerializer>().Deserialize(internalFormat);
if (!Activator.CreateInstance<TFileSerializer>().Serialize(specificFormat, outfile))
{
logger.Warning($"File '{outfile}' could not be written! See the log for more details.");
return false;
}
}
catch (Exception ex) when (!throwOnError)
{
logger.Error(ex);
return false;
}
logger.User($"'{outfile}' written!{Environment.NewLine}");
return true;
}
}
}