mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Add GetMissingRequiredFields tests
This commit is contained in:
File diff suppressed because it is too large
Load Diff
@@ -13,14 +13,6 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
{
|
{
|
||||||
#region Fields
|
#region Fields
|
||||||
|
|
||||||
/// <inheritdoc/>
|
|
||||||
public override ItemType[] SupportedTypes
|
|
||||||
=> [
|
|
||||||
ItemType.Disk,
|
|
||||||
ItemType.Media,
|
|
||||||
ItemType.Rom,
|
|
||||||
];
|
|
||||||
|
|
||||||
// Private instance variables specific to Hashfile DATs
|
// Private instance variables specific to Hashfile DATs
|
||||||
protected HashType _hash;
|
protected HashType _hash;
|
||||||
|
|
||||||
@@ -53,167 +45,6 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <inheritdoc/>
|
|
||||||
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
|
|
||||||
{
|
|
||||||
List<string> missingFields = [];
|
|
||||||
|
|
||||||
// Check item name
|
|
||||||
if (string.IsNullOrEmpty(datItem.GetName()))
|
|
||||||
missingFields.Add(Models.Metadata.Rom.NameKey);
|
|
||||||
|
|
||||||
// Check hash linked to specific Hashfile type
|
|
||||||
switch (_hash)
|
|
||||||
{
|
|
||||||
case HashType.CRC32:
|
|
||||||
case HashType.CRC32_AIXM:
|
|
||||||
case HashType.CRC32_AUTOSAR:
|
|
||||||
case HashType.CRC32_BASE91D:
|
|
||||||
case HashType.CRC32_BZIP2:
|
|
||||||
case HashType.CRC32_CDROMEDC:
|
|
||||||
case HashType.CRC32_CKSUM:
|
|
||||||
case HashType.CRC32_ISCSI:
|
|
||||||
case HashType.CRC32_ISOHDLC:
|
|
||||||
case HashType.CRC32_JAMCRC:
|
|
||||||
case HashType.CRC32_MEF:
|
|
||||||
case HashType.CRC32_MPEG2:
|
|
||||||
case HashType.CRC32_XFER:
|
|
||||||
switch (datItem)
|
|
||||||
{
|
|
||||||
case Rom rom:
|
|
||||||
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.CRCKey)))
|
|
||||||
missingFields.Add(Models.Metadata.Rom.CRCKey);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
missingFields.Add(Models.Metadata.Rom.CRCKey);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HashType.MD2:
|
|
||||||
switch (datItem)
|
|
||||||
{
|
|
||||||
case Rom rom:
|
|
||||||
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD2Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Rom.MD2Key);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
missingFields.Add(Models.Metadata.Rom.MD2Key);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HashType.MD4:
|
|
||||||
switch (datItem)
|
|
||||||
{
|
|
||||||
case Rom rom:
|
|
||||||
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD4Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Rom.MD4Key);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
missingFields.Add(Models.Metadata.Rom.MD4Key);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HashType.MD5:
|
|
||||||
switch (datItem)
|
|
||||||
{
|
|
||||||
case Disk disk:
|
|
||||||
if (string.IsNullOrEmpty(disk.GetStringFieldValue(Models.Metadata.Disk.MD5Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Disk.MD5Key);
|
|
||||||
break;
|
|
||||||
case Media medium:
|
|
||||||
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.MD5Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Media.MD5Key);
|
|
||||||
break;
|
|
||||||
case Rom rom:
|
|
||||||
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD5Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Rom.MD5Key);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
missingFields.Add(Models.Metadata.Rom.MD5Key);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HashType.SHA1:
|
|
||||||
switch (datItem)
|
|
||||||
{
|
|
||||||
case Disk disk:
|
|
||||||
if (string.IsNullOrEmpty(disk.GetStringFieldValue(Models.Metadata.Disk.SHA1Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Disk.SHA1Key);
|
|
||||||
break;
|
|
||||||
case Media medium:
|
|
||||||
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SHA1Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Media.SHA1Key);
|
|
||||||
break;
|
|
||||||
case Rom rom:
|
|
||||||
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA1Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Rom.SHA1Key);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
missingFields.Add(Models.Metadata.Rom.SHA1Key);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HashType.SHA256:
|
|
||||||
switch (datItem)
|
|
||||||
{
|
|
||||||
case Media medium:
|
|
||||||
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SHA256Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Media.SHA256Key);
|
|
||||||
break;
|
|
||||||
case Rom rom:
|
|
||||||
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA256Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Rom.SHA256Key);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
missingFields.Add(Models.Metadata.Rom.SHA256Key);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HashType.SHA384:
|
|
||||||
switch (datItem)
|
|
||||||
{
|
|
||||||
case Rom rom:
|
|
||||||
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA384Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Rom.SHA384Key);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
missingFields.Add(Models.Metadata.Rom.SHA384Key);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HashType.SHA512:
|
|
||||||
switch (datItem)
|
|
||||||
{
|
|
||||||
case Rom rom:
|
|
||||||
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA512Key)))
|
|
||||||
missingFields.Add(Models.Metadata.Rom.SHA512Key);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
missingFields.Add(Models.Metadata.Rom.SHA512Key);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HashType.SpamSum:
|
|
||||||
switch (datItem)
|
|
||||||
{
|
|
||||||
case Media medium:
|
|
||||||
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SpamSumKey)))
|
|
||||||
missingFields.Add(Models.Metadata.Media.SpamSumKey);
|
|
||||||
break;
|
|
||||||
case Rom rom:
|
|
||||||
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SpamSumKey)))
|
|
||||||
missingFields.Add(Models.Metadata.Rom.SpamSumKey);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
missingFields.Add(Models.Metadata.Rom.SpamSumKey);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return missingFields;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <inheritdoc/>
|
/// <inheritdoc/>
|
||||||
public override bool WriteToFile(string outfile, bool ignoreblanks = false, bool throwOnError = false)
|
public override bool WriteToFile(string outfile, bool ignoreblanks = false, bool throwOnError = false)
|
||||||
{
|
{
|
||||||
@@ -224,7 +55,7 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
// Serialize the input file
|
// Serialize the input file
|
||||||
var metadata = ConvertToMetadata(ignoreblanks);
|
var metadata = ConvertToMetadata(ignoreblanks);
|
||||||
var hashfile = new Serialization.CrossModel.Hashfile().Deserialize(metadata, _hash);
|
var hashfile = new Serialization.CrossModel.Hashfile().Deserialize(metadata, _hash);
|
||||||
if (!(Serialization.Serializers.Hashfile.SerializeFile(hashfile, outfile, _hash)))
|
if (!Serialization.Serializers.Hashfile.SerializeFile(hashfile, outfile, _hash))
|
||||||
{
|
{
|
||||||
_logger.Warning($"File '{outfile}' could not be written! See the log for more details.");
|
_logger.Warning($"File '{outfile}' could not be written! See the log for more details.");
|
||||||
return false;
|
return false;
|
||||||
@@ -246,6 +77,12 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public sealed class SfvFile : Hashfile
|
public sealed class SfvFile : Hashfile
|
||||||
{
|
{
|
||||||
|
/// <inheritdoc/>
|
||||||
|
public override ItemType[] SupportedTypes
|
||||||
|
=> [
|
||||||
|
ItemType.Rom,
|
||||||
|
];
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor designed for casting a base DatFile
|
/// Constructor designed for casting a base DatFile
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -254,6 +91,26 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
{
|
{
|
||||||
_hash = HashType.CRC32;
|
_hash = HashType.CRC32;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc/>
|
||||||
|
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
|
||||||
|
{
|
||||||
|
List<string> missingFields = [];
|
||||||
|
|
||||||
|
// Check item name
|
||||||
|
if (string.IsNullOrEmpty(datItem.GetName()))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.NameKey);
|
||||||
|
|
||||||
|
switch (datItem)
|
||||||
|
{
|
||||||
|
case Rom rom:
|
||||||
|
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.CRCKey)))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.CRCKey);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return missingFields;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -261,6 +118,12 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public sealed class Md2File : Hashfile
|
public sealed class Md2File : Hashfile
|
||||||
{
|
{
|
||||||
|
/// <inheritdoc/>
|
||||||
|
public override ItemType[] SupportedTypes
|
||||||
|
=> [
|
||||||
|
ItemType.Rom,
|
||||||
|
];
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor designed for casting a base DatFile
|
/// Constructor designed for casting a base DatFile
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -269,6 +132,26 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
{
|
{
|
||||||
_hash = HashType.MD2;
|
_hash = HashType.MD2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc/>
|
||||||
|
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
|
||||||
|
{
|
||||||
|
List<string> missingFields = [];
|
||||||
|
|
||||||
|
// Check item name
|
||||||
|
if (string.IsNullOrEmpty(datItem.GetName()))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.NameKey);
|
||||||
|
|
||||||
|
switch (datItem)
|
||||||
|
{
|
||||||
|
case Rom rom:
|
||||||
|
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD2Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.MD2Key);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return missingFields;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -276,6 +159,12 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public sealed class Md4File : Hashfile
|
public sealed class Md4File : Hashfile
|
||||||
{
|
{
|
||||||
|
/// <inheritdoc/>
|
||||||
|
public override ItemType[] SupportedTypes
|
||||||
|
=> [
|
||||||
|
ItemType.Rom,
|
||||||
|
];
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor designed for casting a base DatFile
|
/// Constructor designed for casting a base DatFile
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -284,6 +173,26 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
{
|
{
|
||||||
_hash = HashType.MD4;
|
_hash = HashType.MD4;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc/>
|
||||||
|
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
|
||||||
|
{
|
||||||
|
List<string> missingFields = [];
|
||||||
|
|
||||||
|
// Check item name
|
||||||
|
if (string.IsNullOrEmpty(datItem.GetName()))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.NameKey);
|
||||||
|
|
||||||
|
switch (datItem)
|
||||||
|
{
|
||||||
|
case Rom rom:
|
||||||
|
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD4Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.MD4Key);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return missingFields;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -291,6 +200,14 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public sealed class Md5File : Hashfile
|
public sealed class Md5File : Hashfile
|
||||||
{
|
{
|
||||||
|
/// <inheritdoc/>
|
||||||
|
public override ItemType[] SupportedTypes
|
||||||
|
=> [
|
||||||
|
ItemType.Disk,
|
||||||
|
ItemType.Media,
|
||||||
|
ItemType.Rom,
|
||||||
|
];
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor designed for casting a base DatFile
|
/// Constructor designed for casting a base DatFile
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -299,6 +216,36 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
{
|
{
|
||||||
_hash = HashType.MD5;
|
_hash = HashType.MD5;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc/>
|
||||||
|
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
|
||||||
|
{
|
||||||
|
List<string> missingFields = [];
|
||||||
|
|
||||||
|
// Check item name
|
||||||
|
if (string.IsNullOrEmpty(datItem.GetName()))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.NameKey);
|
||||||
|
|
||||||
|
switch (datItem)
|
||||||
|
{
|
||||||
|
case Disk disk:
|
||||||
|
if (string.IsNullOrEmpty(disk.GetStringFieldValue(Models.Metadata.Disk.MD5Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Disk.MD5Key);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Media medium:
|
||||||
|
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.MD5Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Media.MD5Key);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Rom rom:
|
||||||
|
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.MD5Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.MD5Key);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return missingFields;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -306,6 +253,14 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public sealed class Sha1File : Hashfile
|
public sealed class Sha1File : Hashfile
|
||||||
{
|
{
|
||||||
|
/// <inheritdoc/>
|
||||||
|
public override ItemType[] SupportedTypes
|
||||||
|
=> [
|
||||||
|
ItemType.Disk,
|
||||||
|
ItemType.Media,
|
||||||
|
ItemType.Rom,
|
||||||
|
];
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor designed for casting a base DatFile
|
/// Constructor designed for casting a base DatFile
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -314,6 +269,36 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
{
|
{
|
||||||
_hash = HashType.SHA1;
|
_hash = HashType.SHA1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc/>
|
||||||
|
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
|
||||||
|
{
|
||||||
|
List<string> missingFields = [];
|
||||||
|
|
||||||
|
// Check item name
|
||||||
|
if (string.IsNullOrEmpty(datItem.GetName()))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.NameKey);
|
||||||
|
|
||||||
|
switch (datItem)
|
||||||
|
{
|
||||||
|
case Disk disk:
|
||||||
|
if (string.IsNullOrEmpty(disk.GetStringFieldValue(Models.Metadata.Disk.SHA1Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Disk.SHA1Key);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Media medium:
|
||||||
|
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SHA1Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Media.SHA1Key);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Rom rom:
|
||||||
|
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA1Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.SHA1Key);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return missingFields;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -321,6 +306,13 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public sealed class Sha256File : Hashfile
|
public sealed class Sha256File : Hashfile
|
||||||
{
|
{
|
||||||
|
/// <inheritdoc/>
|
||||||
|
public override ItemType[] SupportedTypes
|
||||||
|
=> [
|
||||||
|
ItemType.Media,
|
||||||
|
ItemType.Rom,
|
||||||
|
];
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor designed for casting a base DatFile
|
/// Constructor designed for casting a base DatFile
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -329,6 +321,31 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
{
|
{
|
||||||
_hash = HashType.SHA256;
|
_hash = HashType.SHA256;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc/>
|
||||||
|
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
|
||||||
|
{
|
||||||
|
List<string> missingFields = [];
|
||||||
|
|
||||||
|
// Check item name
|
||||||
|
if (string.IsNullOrEmpty(datItem.GetName()))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.NameKey);
|
||||||
|
|
||||||
|
switch (datItem)
|
||||||
|
{
|
||||||
|
case Media medium:
|
||||||
|
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SHA256Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Media.SHA256Key);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Rom rom:
|
||||||
|
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA256Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.SHA256Key);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return missingFields;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -336,6 +353,12 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public sealed class Sha384File : Hashfile
|
public sealed class Sha384File : Hashfile
|
||||||
{
|
{
|
||||||
|
/// <inheritdoc/>
|
||||||
|
public override ItemType[] SupportedTypes
|
||||||
|
=> [
|
||||||
|
ItemType.Rom,
|
||||||
|
];
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor designed for casting a base DatFile
|
/// Constructor designed for casting a base DatFile
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -344,6 +367,26 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
{
|
{
|
||||||
_hash = HashType.SHA384;
|
_hash = HashType.SHA384;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc/>
|
||||||
|
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
|
||||||
|
{
|
||||||
|
List<string> missingFields = [];
|
||||||
|
|
||||||
|
// Check item name
|
||||||
|
if (string.IsNullOrEmpty(datItem.GetName()))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.NameKey);
|
||||||
|
|
||||||
|
switch (datItem)
|
||||||
|
{
|
||||||
|
case Rom rom:
|
||||||
|
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA384Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.SHA384Key);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return missingFields;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -351,6 +394,12 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public sealed class Sha512File : Hashfile
|
public sealed class Sha512File : Hashfile
|
||||||
{
|
{
|
||||||
|
/// <inheritdoc/>
|
||||||
|
public override ItemType[] SupportedTypes
|
||||||
|
=> [
|
||||||
|
ItemType.Rom,
|
||||||
|
];
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor designed for casting a base DatFile
|
/// Constructor designed for casting a base DatFile
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -359,6 +408,26 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
{
|
{
|
||||||
_hash = HashType.SHA512;
|
_hash = HashType.SHA512;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc/>
|
||||||
|
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
|
||||||
|
{
|
||||||
|
List<string> missingFields = [];
|
||||||
|
|
||||||
|
// Check item name
|
||||||
|
if (string.IsNullOrEmpty(datItem.GetName()))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.NameKey);
|
||||||
|
|
||||||
|
switch (datItem)
|
||||||
|
{
|
||||||
|
case Rom rom:
|
||||||
|
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SHA512Key)))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.SHA512Key);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return missingFields;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -366,6 +435,13 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public sealed class SpamSumFile : Hashfile
|
public sealed class SpamSumFile : Hashfile
|
||||||
{
|
{
|
||||||
|
/// <inheritdoc/>
|
||||||
|
public override ItemType[] SupportedTypes
|
||||||
|
=> [
|
||||||
|
ItemType.Media,
|
||||||
|
ItemType.Rom,
|
||||||
|
];
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Constructor designed for casting a base DatFile
|
/// Constructor designed for casting a base DatFile
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -374,5 +450,30 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
{
|
{
|
||||||
_hash = HashType.SpamSum;
|
_hash = HashType.SpamSum;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <inheritdoc/>
|
||||||
|
protected internal override List<string>? GetMissingRequiredFields(DatItem datItem)
|
||||||
|
{
|
||||||
|
List<string> missingFields = [];
|
||||||
|
|
||||||
|
// Check item name
|
||||||
|
if (string.IsNullOrEmpty(datItem.GetName()))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.NameKey);
|
||||||
|
|
||||||
|
switch (datItem)
|
||||||
|
{
|
||||||
|
case Media medium:
|
||||||
|
if (string.IsNullOrEmpty(medium.GetStringFieldValue(Models.Metadata.Media.SpamSumKey)))
|
||||||
|
missingFields.Add(Models.Metadata.Media.SpamSumKey);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Rom rom:
|
||||||
|
if (string.IsNullOrEmpty(rom.GetStringFieldValue(Models.Metadata.Rom.SpamSumKey)))
|
||||||
|
missingFields.Add(Models.Metadata.Rom.SpamSumKey);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return missingFields;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -53,7 +53,7 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return missingFields;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -356,7 +356,7 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case Device device:
|
case Device device:
|
||||||
if (device.GetStringFieldValue(Models.Metadata.Device.DeviceTypeKey).AsEnumValue<DeviceType>() != DeviceType.NULL)
|
if (device.GetStringFieldValue(Models.Metadata.Device.DeviceTypeKey).AsEnumValue<DeviceType>() == DeviceType.NULL)
|
||||||
missingFields.Add(Models.Metadata.Device.DeviceTypeKey);
|
missingFields.Add(Models.Metadata.Device.DeviceTypeKey);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|||||||
@@ -228,11 +228,14 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
=> [
|
=> [
|
||||||
ItemType.Archive,
|
ItemType.Archive,
|
||||||
ItemType.BiosSet,
|
ItemType.BiosSet,
|
||||||
|
ItemType.DeviceRef,
|
||||||
ItemType.Disk,
|
ItemType.Disk,
|
||||||
|
ItemType.Driver,
|
||||||
ItemType.Media,
|
ItemType.Media,
|
||||||
ItemType.Release,
|
ItemType.Release,
|
||||||
ItemType.Rom,
|
ItemType.Rom,
|
||||||
ItemType.Sample,
|
ItemType.Sample,
|
||||||
|
ItemType.SoftwareList,
|
||||||
];
|
];
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
|||||||
@@ -73,6 +73,16 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case Media media:
|
||||||
|
if (string.IsNullOrEmpty(media.GetStringFieldValue(Models.Metadata.Media.MD5Key))
|
||||||
|
&& string.IsNullOrEmpty(media.GetStringFieldValue(Models.Metadata.Media.SHA1Key))
|
||||||
|
&& string.IsNullOrEmpty(media.GetStringFieldValue(Models.Metadata.Media.SHA256Key))
|
||||||
|
&& string.IsNullOrEmpty(media.GetStringFieldValue(Models.Metadata.Media.SpamSumKey)))
|
||||||
|
{
|
||||||
|
missingFields.Add(Models.Metadata.Media.SHA1Key);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case Rom rom:
|
case Rom rom:
|
||||||
if (rom.GetInt64FieldValue(Models.Metadata.Rom.SizeKey) == null || rom.GetInt64FieldValue(Models.Metadata.Rom.SizeKey) < 0)
|
if (rom.GetInt64FieldValue(Models.Metadata.Rom.SizeKey) == null || rom.GetInt64FieldValue(Models.Metadata.Rom.SizeKey) < 0)
|
||||||
missingFields.Add(Models.Metadata.Rom.SizeKey);
|
missingFields.Add(Models.Metadata.Rom.SizeKey);
|
||||||
@@ -102,7 +112,7 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
// Serialize the input file
|
// Serialize the input file
|
||||||
var metadata = ConvertToMetadata(ignoreblanks);
|
var metadata = ConvertToMetadata(ignoreblanks);
|
||||||
var metadataFile = new Serialization.CrossModel.SeparatedValue().Deserialize(metadata);
|
var metadataFile = new Serialization.CrossModel.SeparatedValue().Deserialize(metadata);
|
||||||
if (!(Serialization.Serializers.SeparatedValue.SerializeFile(metadataFile, outfile, _delim)))
|
if (!Serialization.Serializers.SeparatedValue.SerializeFile(metadataFile, outfile, _delim))
|
||||||
{
|
{
|
||||||
_logger.Warning($"File '{outfile}' could not be written! See the log for more details.");
|
_logger.Warning($"File '{outfile}' could not be written! See the log for more details.");
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -197,9 +197,6 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
if (string.IsNullOrEmpty(sharedFeat.GetName()))
|
if (string.IsNullOrEmpty(sharedFeat.GetName()))
|
||||||
missingFields.Add(Models.Metadata.SharedFeat.NameKey);
|
missingFields.Add(Models.Metadata.SharedFeat.NameKey);
|
||||||
break;
|
break;
|
||||||
default:
|
|
||||||
// Unsupported ItemTypes should be caught already
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return missingFields;
|
return missingFields;
|
||||||
|
|||||||
Reference in New Issue
Block a user