mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Implement more internal header processing
This commit is contained in:
@@ -1,6 +1,4 @@
|
||||
using System;
|
||||
using SabreTools.Core;
|
||||
using SabreTools.Models.RomCenter;
|
||||
|
||||
namespace SabreTools.DatFiles.Formats
|
||||
{
|
||||
@@ -18,15 +16,6 @@ namespace SabreTools.DatFiles.Formats
|
||||
var metadataFile = new Serialization.Files.RomCenter().Deserialize(filename);
|
||||
var metadata = new Serialization.CrossModel.RomCenter().Serialize(metadataFile);
|
||||
|
||||
// Convert the credits data to the internal format
|
||||
ConvertCredits(metadataFile?.Credits);
|
||||
|
||||
// Convert the dat data to the internal format
|
||||
ConvertDat(metadataFile?.Dat);
|
||||
|
||||
// Convert the emulator data to the internal format
|
||||
ConvertEmulator(metadataFile?.Emulator);
|
||||
|
||||
// Convert to the internal format
|
||||
ConvertMetadata(metadata, filename, indexId, keep, statsOnly);
|
||||
}
|
||||
@@ -36,71 +25,5 @@ namespace SabreTools.DatFiles.Formats
|
||||
logger.Error(ex, message);
|
||||
}
|
||||
}
|
||||
|
||||
#region Converters
|
||||
|
||||
/// <summary>
|
||||
/// Convert credits information
|
||||
/// </summary>
|
||||
/// <param name="credits">Deserialized model to convert</param>
|
||||
private void ConvertCredits(Models.RomCenter.Credits? credits)
|
||||
{
|
||||
// If the credits is missing, we can't do anything
|
||||
if (credits == null)
|
||||
return;
|
||||
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.AuthorKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.AuthorKey, credits.Author);
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.CommentKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.CommentKey, credits.Comment);
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.DateKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.DateKey, credits.Date);
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.EmailKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.EmailKey, credits.Email);
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.HomepageKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.HomepageKey, credits.Homepage);
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.UrlKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.UrlKey, credits.Url);
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.VersionKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.VersionKey, credits.Version);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Convert dat information
|
||||
/// </summary>
|
||||
/// <param name="dat">Deserialized model to convert</param>
|
||||
private void ConvertDat(Models.RomCenter.Dat? dat)
|
||||
{
|
||||
// If the dat is missing, we can't do anything
|
||||
if (dat == null)
|
||||
return;
|
||||
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.DatVersionKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.DatVersionKey, dat.Version);
|
||||
if (Header.GetFieldValue<MergingFlag>(Models.Metadata.Header.ForceMergingKey) == MergingFlag.None && dat.Split == "1")
|
||||
Header.SetFieldValue<MergingFlag>(Models.Metadata.Header.ForceMergingKey, MergingFlag.Split);
|
||||
if (Header.GetFieldValue<MergingFlag>(Models.Metadata.Header.ForceMergingKey) == MergingFlag.None && dat.Merge == "1")
|
||||
Header.SetFieldValue<MergingFlag>(Models.Metadata.Header.ForceMergingKey, MergingFlag.Merged);
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.SystemKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.SystemKey, dat.Plugin);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Convert emulator information
|
||||
/// </summary>
|
||||
/// <param name="games">Deserialized model to convert</param>
|
||||
private void ConvertEmulator(Models.RomCenter.Emulator? emulator)
|
||||
{
|
||||
// If the emulator is missing, we can't do anything
|
||||
if (emulator == null)
|
||||
return;
|
||||
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.EmulatorVersionKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.EmulatorVersionKey, emulator.Version);
|
||||
if (Header.GetFieldValue<string?>(Models.Metadata.Header.RefNameKey) == null)
|
||||
Header.SetFieldValue<string?>(Models.Metadata.Header.RefNameKey, emulator.RefName);
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user