2023-07-30 15:13:16 -04:00
|
|
|
using System;
|
|
|
|
|
|
|
|
|
|
namespace SabreTools.DatFiles.Formats
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Represents parsing and writing of a DosCenter DAT
|
|
|
|
|
/// </summary>
|
|
|
|
|
internal partial class DosCenter : DatFile
|
|
|
|
|
{
|
|
|
|
|
/// <inheritdoc/>
|
|
|
|
|
public override void ParseFile(string filename, int indexId, bool keep, bool statsOnly = false, bool throwOnError = false)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
// Deserialize the input file
|
2023-09-11 01:20:21 -04:00
|
|
|
var metadataFile = new Serialization.Files.DosCenter().Deserialize(filename);
|
2024-03-10 00:28:31 -05:00
|
|
|
var metadata = new Serialization.CrossModel.DosCenter().Serialize(metadataFile);
|
2023-07-30 15:13:16 -04:00
|
|
|
|
|
|
|
|
// Convert the header to the internal format
|
|
|
|
|
ConvertHeader(metadataFile?.DosCenter, keep);
|
|
|
|
|
|
2024-03-10 00:28:31 -05:00
|
|
|
// Convert to the internal format
|
|
|
|
|
ConvertMetadata(metadata, filename, indexId, statsOnly);
|
2023-07-30 15:13:16 -04:00
|
|
|
}
|
|
|
|
|
catch (Exception ex) when (!throwOnError)
|
|
|
|
|
{
|
|
|
|
|
string message = $"'{filename}' - An error occurred during parsing";
|
|
|
|
|
logger.Error(ex, message);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#region Converters
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Convert header information
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="doscenter">Deserialized model to convert</param>
|
|
|
|
|
/// <param name="keep">True if full pathnames are to be kept, false otherwise (default)</param>
|
|
|
|
|
private void ConvertHeader(Models.DosCenter.DosCenter? doscenter, bool keep)
|
|
|
|
|
{
|
|
|
|
|
// If the header is missing, we can't do anything
|
|
|
|
|
if (doscenter == null)
|
|
|
|
|
return;
|
|
|
|
|
|
2024-03-10 04:10:37 -04:00
|
|
|
if (Header.GetFieldValue<string?>(Models.Metadata.Header.AuthorKey) == null)
|
|
|
|
|
Header.SetFieldValue<string?>(Models.Metadata.Header.AuthorKey, doscenter.Author);
|
|
|
|
|
if (Header.GetFieldValue<string?>(Models.Metadata.Header.CommentKey) == null)
|
|
|
|
|
Header.SetFieldValue<string?>(Models.Metadata.Header.CommentKey, doscenter.Comment);
|
|
|
|
|
if (Header.GetFieldValue<string?>(Models.Metadata.Header.DateKey) == null)
|
|
|
|
|
Header.SetFieldValue<string?>(Models.Metadata.Header.DateKey, doscenter.Date);
|
|
|
|
|
if (Header.GetFieldValue<string?>(Models.Metadata.Header.DescriptionKey) == null)
|
|
|
|
|
Header.SetFieldValue<string?>(Models.Metadata.Header.DescriptionKey, doscenter.Description);
|
|
|
|
|
if (Header.GetFieldValue<string?>(Models.Metadata.Header.HomepageKey) == null)
|
|
|
|
|
Header.SetFieldValue<string?>(Models.Metadata.Header.HomepageKey, doscenter.Homepage);
|
|
|
|
|
if (Header.GetFieldValue<string?>(Models.Metadata.Header.NameKey) == null)
|
|
|
|
|
Header.SetFieldValue<string?>(Models.Metadata.Header.NameKey, doscenter.Name);
|
|
|
|
|
if (Header.GetFieldValue<string?>(Models.Metadata.Header.VersionKey) == null)
|
|
|
|
|
Header.SetFieldValue<string?>(Models.Metadata.Header.VersionKey, doscenter.Version);
|
2023-07-30 15:13:16 -04:00
|
|
|
|
|
|
|
|
// Handle implied SuperDAT
|
2023-07-31 13:44:15 -04:00
|
|
|
if (doscenter.Name?.Contains(" - SuperDAT") == true && keep)
|
2024-03-10 04:10:37 -04:00
|
|
|
{
|
|
|
|
|
if (Header.GetFieldValue<string?>(Models.Metadata.Header.TypeKey) == null)
|
|
|
|
|
Header.SetFieldValue<string?>(Models.Metadata.Header.TypeKey, "SuperDAT");
|
|
|
|
|
}
|
2023-07-30 15:13:16 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endregion
|
|
|
|
|
}
|
|
|
|
|
}
|