mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Add SeparatedValue internal converters
This commit is contained in:
@@ -1278,19 +1278,6 @@ namespace SabreTools.Serialization
|
|||||||
return dump;
|
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>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Rom"/> to <cref="Models.OpenMSX.MegaRom"/>
|
/// Convert from <cref="Models.Internal.Rom"/> to <cref="Models.OpenMSX.MegaRom"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -1306,6 +1293,19 @@ namespace SabreTools.Serialization
|
|||||||
return megaRom;
|
return megaRom;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <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>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Rom"/> to <cref="Models.OpenMSX.Rom"/>
|
/// Convert from <cref="Models.Internal.Rom"/> to <cref="Models.OpenMSX.Rom"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -1356,5 +1356,64 @@ namespace SabreTools.Serialization
|
|||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region SeparatedValue
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Disk"/> to <cref="Models.SeparatedValue.Row"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.SeparatedValue.Row ConvertToSeparatedValue(Models.Internal.Disk item)
|
||||||
|
{
|
||||||
|
var row = new Models.SeparatedValue.Row
|
||||||
|
{
|
||||||
|
Type = "disk",
|
||||||
|
DiskName = item.ReadString(Models.Internal.Disk.NameKey),
|
||||||
|
MD5 = item.ReadString(Models.Internal.Disk.MD5Key),
|
||||||
|
SHA1 = item.ReadString(Models.Internal.Disk.SHA1Key),
|
||||||
|
Status = item.ReadString(Models.Internal.Disk.StatusKey),
|
||||||
|
};
|
||||||
|
return row;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Media"/> to <cref="Models.SeparatedValue.Row"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.SeparatedValue.Row ConvertToSeparatedValue(Models.Internal.Media item)
|
||||||
|
{
|
||||||
|
var row = new Models.SeparatedValue.Row
|
||||||
|
{
|
||||||
|
Type = "media",
|
||||||
|
DiskName = item.ReadString(Models.Internal.Media.NameKey),
|
||||||
|
MD5 = item.ReadString(Models.Internal.Media.MD5Key),
|
||||||
|
SHA1 = item.ReadString(Models.Internal.Media.SHA1Key),
|
||||||
|
SHA256 = item.ReadString(Models.Internal.Media.SHA256Key),
|
||||||
|
SpamSum = item.ReadString(Models.Internal.Media.SpamSumKey),
|
||||||
|
};
|
||||||
|
return row;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Rom"/> to <cref="Models.SeparatedValue.Row"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.SeparatedValue.Row ConvertToSeparatedValue(Models.Internal.Rom item)
|
||||||
|
{
|
||||||
|
var row = new Models.SeparatedValue.Row
|
||||||
|
{
|
||||||
|
Type = "rom",
|
||||||
|
RomName = item.ReadString(Models.Internal.Rom.NameKey),
|
||||||
|
Size = item.ReadString(Models.Internal.Rom.SizeKey),
|
||||||
|
CRC = item.ReadString(Models.Internal.Rom.CRCKey),
|
||||||
|
MD5 = item.ReadString(Models.Internal.Rom.MD5Key),
|
||||||
|
SHA1 = item.ReadString(Models.Internal.Rom.SHA1Key),
|
||||||
|
SHA256 = item.ReadString(Models.Internal.Rom.SHA256Key),
|
||||||
|
SHA384 = item.ReadString(Models.Internal.Rom.SHA384Key),
|
||||||
|
SHA512 = item.ReadString(Models.Internal.Rom.SHA512Key),
|
||||||
|
SpamSum = item.ReadString(Models.Internal.Rom.SpamSumKey),
|
||||||
|
Status = item.ReadString(Models.Internal.Rom.StatusKey),
|
||||||
|
};
|
||||||
|
return row;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -457,7 +457,7 @@ namespace SabreTools.Serialization
|
|||||||
#region Listrom
|
#region Listrom
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Listrom.Row"/> to <cref="Models.Internal.Disk"/> or <cref="Models.Internal.Rom"/>
|
/// Convert from <cref="Models.Listrom.Row"/> to <cref="Models.Internal.DatItem"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static Models.Internal.DatItem ConvertFromListrom(Models.Listrom.Row item)
|
public static Models.Internal.DatItem ConvertFromListrom(Models.Listrom.Row item)
|
||||||
{
|
{
|
||||||
@@ -1329,5 +1329,48 @@ namespace SabreTools.Serialization
|
|||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region SeparatedValue
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.SeparatedValue.Row"/> to <cref="Models.Internal.DatItem"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.Internal.DatItem? ConvertFromSeparatedValue(Models.SeparatedValue.Row item)
|
||||||
|
{
|
||||||
|
return item.Type switch
|
||||||
|
{
|
||||||
|
"disk" => new Models.Internal.Disk
|
||||||
|
{
|
||||||
|
[Models.Internal.Disk.NameKey] = item.DiskName,
|
||||||
|
[Models.Internal.Disk.MD5Key] = item.MD5,
|
||||||
|
[Models.Internal.Disk.SHA1Key] = item.SHA1,
|
||||||
|
[Models.Internal.Disk.StatusKey] = item.Status,
|
||||||
|
},
|
||||||
|
"media" => new Models.Internal.Media
|
||||||
|
{
|
||||||
|
[Models.Internal.Media.NameKey] = item.DiskName,
|
||||||
|
[Models.Internal.Media.MD5Key] = item.MD5,
|
||||||
|
[Models.Internal.Media.SHA1Key] = item.SHA1,
|
||||||
|
[Models.Internal.Media.SHA256Key] = item.SHA256,
|
||||||
|
[Models.Internal.Media.SpamSumKey] = item.SpamSum,
|
||||||
|
},
|
||||||
|
"rom" => new Models.Internal.Rom
|
||||||
|
{
|
||||||
|
[Models.Internal.Rom.NameKey] = item.RomName,
|
||||||
|
[Models.Internal.Rom.SizeKey] = item.Size,
|
||||||
|
[Models.Internal.Rom.CRCKey] = item.CRC,
|
||||||
|
[Models.Internal.Rom.MD5Key] = item.MD5,
|
||||||
|
[Models.Internal.Rom.SHA1Key] = item.SHA1,
|
||||||
|
[Models.Internal.Rom.SHA256Key] = item.SHA256,
|
||||||
|
[Models.Internal.Rom.SHA384Key] = item.SHA384,
|
||||||
|
[Models.Internal.Rom.SHA512Key] = item.SHA512,
|
||||||
|
[Models.Internal.Rom.SpamSumKey] = item.SpamSum,
|
||||||
|
[Models.Internal.Rom.StatusKey] = item.Status,
|
||||||
|
},
|
||||||
|
_ => null,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user