mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Add OpenMSX internal converters
This commit is contained in:
@@ -1249,5 +1249,93 @@ namespace SabreTools.Serialization
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region OpenMSX
|
||||
|
||||
/// <summary>
|
||||
/// Convert from <cref="Models.Internal.Dump"/> to <cref="Models.OpenMSX.Dump"/>
|
||||
/// </summary>
|
||||
public static Models.OpenMSX.Dump ConvertToOpenMSX(Models.Internal.Dump item)
|
||||
{
|
||||
var dump = new Models.OpenMSX.Dump();
|
||||
|
||||
if (item.ContainsKey(Models.Internal.Dump.OriginalKey) && item[Models.Internal.Dump.OriginalKey] is Models.Internal.Original original)
|
||||
dump.Original = ConvertToOpenMSX(original);
|
||||
|
||||
if (item.ContainsKey(Models.Internal.Dump.RomKey) && item[Models.Internal.Dump.RomKey] is Models.Internal.Rom rom)
|
||||
{
|
||||
dump.Rom = ConvertToOpenMSXRom(rom);
|
||||
}
|
||||
else if (item.ContainsKey(Models.Internal.Dump.MegaRomKey) && item[Models.Internal.Dump.MegaRomKey] is Models.Internal.Rom megaRom)
|
||||
{
|
||||
dump.Rom = ConvertToOpenMSXMegaRom(megaRom);
|
||||
}
|
||||
else if (item.ContainsKey(Models.Internal.Dump.SCCPlusCartKey) && item[Models.Internal.Dump.SCCPlusCartKey] is Models.Internal.Rom sccPlusCart)
|
||||
{
|
||||
dump.Rom = ConvertToOpenMSXSCCPlusCart(sccPlusCart);
|
||||
}
|
||||
|
||||
return dump;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Convert from <cref="Models.Internal.Original"/> to <cref="Models.OpenMSX.Original"/>
|
||||
/// </summary>
|
||||
public static Models.OpenMSX.Original ConvertToOpenMSX(Models.Internal.Original item)
|
||||
{
|
||||
var original = new Models.OpenMSX.Original
|
||||
{
|
||||
Value = item.ReadString(Models.Internal.Original.ValueKey),
|
||||
Content = item.ReadString(Models.Internal.Original.ContentKey),
|
||||
};
|
||||
return original;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Convert from <cref="Models.Internal.Rom"/> to <cref="Models.OpenMSX.MegaRom"/>
|
||||
/// </summary>
|
||||
public static Models.OpenMSX.MegaRom ConvertToOpenMSXMegaRom(Models.Internal.Rom item)
|
||||
{
|
||||
var megaRom = new Models.OpenMSX.MegaRom
|
||||
{
|
||||
Start = item.ReadString(Models.Internal.Rom.StartKey),
|
||||
Type = item.ReadString(Models.Internal.Rom.TypeKey),
|
||||
Hash = item.ReadString(Models.Internal.Rom.SHA1Key),
|
||||
Remark = item.ReadString(Models.Internal.Rom.RemarkKey),
|
||||
};
|
||||
return megaRom;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Convert from <cref="Models.Internal.Rom"/> to <cref="Models.OpenMSX.Rom"/>
|
||||
/// </summary>
|
||||
public static Models.OpenMSX.Rom ConvertToOpenMSXRom(Models.Internal.Rom item)
|
||||
{
|
||||
var rom = new Models.OpenMSX.Rom
|
||||
{
|
||||
Start = item.ReadString(Models.Internal.Rom.StartKey),
|
||||
Type = item.ReadString(Models.Internal.Rom.TypeKey),
|
||||
Hash = item.ReadString(Models.Internal.Rom.SHA1Key),
|
||||
Remark = item.ReadString(Models.Internal.Rom.RemarkKey),
|
||||
};
|
||||
return rom;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Convert from <cref="Models.Internal.Rom"/> to <cref="Models.OpenMSX.SCCPlusCart"/>
|
||||
/// </summary>
|
||||
public static Models.OpenMSX.SCCPlusCart ConvertToOpenMSXSCCPlusCart(Models.Internal.Rom item)
|
||||
{
|
||||
var sccPlusCart = new Models.OpenMSX.SCCPlusCart
|
||||
{
|
||||
Start = item.ReadString(Models.Internal.Rom.StartKey),
|
||||
Type = item.ReadString(Models.Internal.Rom.TypeKey),
|
||||
Hash = item.ReadString(Models.Internal.Rom.SHA1Key),
|
||||
Remark = item.ReadString(Models.Internal.Rom.RemarkKey),
|
||||
};
|
||||
return sccPlusCart;
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user