mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Add Listrom internal converters
This commit is contained in:
@@ -449,5 +449,50 @@ namespace SabreTools.Serialization
|
|||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region Listrom
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Disk"/> to <cref="Models.Listrom.Row"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.Listrom.Row ConvertToListrom(Models.Internal.Disk item)
|
||||||
|
{
|
||||||
|
var row = new Models.Listrom.Row
|
||||||
|
{
|
||||||
|
Name = item.ReadString(Models.Internal.Disk.NameKey),
|
||||||
|
MD5 = item.ReadString(Models.Internal.Disk.MD5Key),
|
||||||
|
SHA1 = item.ReadString(Models.Internal.Disk.SHA1Key),
|
||||||
|
};
|
||||||
|
|
||||||
|
if (item[Models.Internal.Disk.StatusKey] as string == "nodump")
|
||||||
|
row.NoGoodDumpKnown = true;
|
||||||
|
else if (item[Models.Internal.Disk.StatusKey] as string == "baddump")
|
||||||
|
row.Bad = true;
|
||||||
|
|
||||||
|
return row;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Rom"/> to <cref="Models.Listrom.Row"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.Listrom.Row ConvertToListrom(Models.Internal.Rom item)
|
||||||
|
{
|
||||||
|
var row = new Models.Listrom.Row
|
||||||
|
{
|
||||||
|
Name = item.ReadString(Models.Internal.Rom.NameKey),
|
||||||
|
Size = item.ReadString(Models.Internal.Rom.SizeKey),
|
||||||
|
CRC = item.ReadString(Models.Internal.Rom.CRCKey),
|
||||||
|
SHA1 = item.ReadString(Models.Internal.Rom.SHA1Key),
|
||||||
|
};
|
||||||
|
|
||||||
|
if (item[Models.Internal.Rom.StatusKey] as string == "nodump")
|
||||||
|
row.NoGoodDumpKnown = true;
|
||||||
|
else if (item[Models.Internal.Rom.StatusKey] as string == "baddump")
|
||||||
|
row.Bad = true;
|
||||||
|
|
||||||
|
return row;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -334,7 +334,7 @@ namespace SabreTools.Serialization
|
|||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region EverdriveSMDB
|
#region EverdriveSMDB
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -355,7 +355,7 @@ namespace SabreTools.Serialization
|
|||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
#region Hashfile
|
#region Hashfile
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -450,5 +450,49 @@ namespace SabreTools.Serialization
|
|||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region Listrom
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Listrom.Row"/> to <cref="Models.Internal.Disk"/> or <cref="Models.Internal.Rom"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.Internal.DatItem ConvertFromListrom(Models.Listrom.Row item)
|
||||||
|
{
|
||||||
|
if (item.Size == null)
|
||||||
|
{
|
||||||
|
var disk = new Models.Internal.Disk
|
||||||
|
{
|
||||||
|
[Models.Internal.Disk.NameKey] = item.Name,
|
||||||
|
[Models.Internal.Disk.MD5Key] = item.MD5,
|
||||||
|
[Models.Internal.Disk.SHA1Key] = item.SHA1,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (item.NoGoodDumpKnown)
|
||||||
|
disk[Models.Internal.Disk.StatusKey] = "nodump";
|
||||||
|
else if (item.Bad)
|
||||||
|
disk[Models.Internal.Disk.StatusKey] = "baddump";
|
||||||
|
|
||||||
|
return disk;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var rom = new Models.Internal.Rom
|
||||||
|
{
|
||||||
|
[Models.Internal.Rom.NameKey] = item.Name,
|
||||||
|
[Models.Internal.Rom.SizeKey] = item.Size,
|
||||||
|
[Models.Internal.Rom.CRCKey] = item.CRC,
|
||||||
|
[Models.Internal.Rom.SHA1Key] = item.SHA1,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (item.NoGoodDumpKnown)
|
||||||
|
rom[Models.Internal.Rom.StatusKey] = "nodump";
|
||||||
|
else if (item.Bad)
|
||||||
|
rom[Models.Internal.Rom.StatusKey] = "baddump";
|
||||||
|
|
||||||
|
return rom;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Reference in New Issue
Block a user