using System;
using System.Linq;
using SabreTools.Core;
using SabreTools.Core.Tools;
using SabreTools.DatItems;
using SabreTools.DatItems.Formats;
namespace SabreTools.DatFiles.Formats
{
///
/// Represents parsing a value-separated DAT
///
internal partial class SeparatedValue : DatFile
{
///
public override void ParseFile(string filename, int indexId, bool keep, bool statsOnly = false, bool throwOnError = false)
{
try
{
// Deserialize the input file
var metadataFile = new Serialization.Files.SeparatedValue().Deserialize(filename, _delim);
// Convert the row data to the internal format
ConvertRows(metadataFile?.Row, filename, indexId, statsOnly);
}
catch (Exception ex) when (!throwOnError)
{
string message = $"'{filename}' - An error occurred during parsing";
logger.Error(ex, message);
}
}
#region Converters
///
/// Convert rows information
///
/// Array of deserialized models to convert
/// Name of the file to be parsed
/// Index ID for the DAT
/// True to only add item statistics while parsing, false otherwise
private void ConvertRows(Models.SeparatedValue.Row[]? rows, string filename, int indexId, bool statsOnly)
{
// If the rows array is missing, we can't do anything
if (rows == null || !rows.Any())
return;
// Loop through the rows and add
foreach (var row in rows)
{
ConvertRow(row, filename, indexId, statsOnly);
}
}
///
/// Convert rows information
///
/// Deserialized model to convert
/// Name of the file to be parsed
/// Index ID for the DAT
/// True to only add item statistics while parsing, false otherwise
private void ConvertRow(Models.SeparatedValue.Row? row, string filename, int indexId, bool statsOnly)
{
// If the row is missing, we can't do anything
if (row == null)
return;
// Read DAT-level values
//Header.FileName ??= row.FileName;
Header.Name ??= row.InternalName;
Header.Description ??= row.Description;
// Read Machine values
var machine = new Machine();
machine.SetFieldValue(Models.Metadata.Machine.DescriptionKey, row.GameDescription);
machine.SetFieldValue(Models.Metadata.Machine.NameKey, row.GameName);
// Read item values
DatItem? item = null;
switch (row.Type.AsEnumValue())
{
case ItemType.Disk:
item = new Disk
{
Source = new Source { Index = indexId, Name = filename },
};
item.SetName(row.DiskName);
item.SetFieldValue(Models.Metadata.Disk.StatusKey, row.Status?.AsEnumValue() ?? ItemStatus.NULL);
item.SetFieldValue(Models.Metadata.Disk.MD5Key, row.MD5);
item.SetFieldValue(Models.Metadata.Disk.SHA1Key, row.SHA1);
break;
case ItemType.Media:
item = new Media
{
Source = new Source { Index = indexId, Name = filename },
};
item.SetName(row.DiskName);
item.SetFieldValue(Models.Metadata.Media.MD5Key, row.MD5);
item.SetFieldValue(Models.Metadata.Media.SHA1Key, row.SHA1);
item.SetFieldValue(Models.Metadata.Media.SHA256Key, row.SHA256);
item.SetFieldValue(Models.Metadata.Media.SpamSumKey, row.SpamSum);
break;
case ItemType.Rom:
item = new Rom
{
Source = new Source { Index = indexId, Name = filename },
};
item.SetName(row.RomName);
item.SetFieldValue(Models.Metadata.Rom.CRCKey, row.CRC);
item.SetFieldValue(Models.Metadata.Rom.MD5Key, row.MD5);
item.SetFieldValue(Models.Metadata.Rom.SHA1Key, row.SHA1);
item.SetFieldValue(Models.Metadata.Rom.SHA256Key, row.SHA256);
item.SetFieldValue(Models.Metadata.Rom.SHA384Key, row.SHA384);
item.SetFieldValue(Models.Metadata.Rom.SHA512Key, row.SHA512);
item.SetFieldValue(Models.Metadata.Rom.SpamSumKey, row.SpamSum);
item.SetFieldValue(Models.Metadata.Rom.StatusKey, row.Status.AsEnumValue());
break;
}
// Now process and add the item
if (item != null)
{
item.CopyMachineInformation(machine);
ParseAddHelper(item, statsOnly);
}
}
#endregion
}
}