mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Add header deserialization
This commit is contained in:
@@ -26,10 +26,6 @@ namespace SabreTools.Models.Internal
|
|||||||
/// <remarks>string</remarks>
|
/// <remarks>string</remarks>
|
||||||
public const string CommentKey = "comment";
|
public const string CommentKey = "comment";
|
||||||
|
|
||||||
/// TODO: This needs an internal model OR mapping to fields
|
|
||||||
/// <remarks>Configuration</remarks>
|
|
||||||
public const string ConfigurationKey = "configuration";
|
|
||||||
|
|
||||||
/// <remarks>string</remarks>
|
/// <remarks>string</remarks>
|
||||||
public const string DateKey = "date";
|
public const string DateKey = "date";
|
||||||
|
|
||||||
|
|||||||
@@ -71,6 +71,21 @@ namespace SabreTools.Serialization
|
|||||||
|
|
||||||
#region Deserialize
|
#region Deserialize
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.AttractMode.MetadataFile"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.AttractMode.MetadataFile? ConvertHeaderToAttractMode(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var metadataFile = new Models.AttractMode.MetadataFile
|
||||||
|
{
|
||||||
|
Header = item.ReadStringArray(Models.Internal.Header.HeaderKey),
|
||||||
|
};
|
||||||
|
return metadataFile;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Machine"/> to an array of <cref="Models.AttractMode.Row"/>
|
/// Convert from <cref="Models.Internal.Machine"/> to an array of <cref="Models.AttractMode.Row"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -374,7 +374,36 @@ namespace SabreTools.Serialization
|
|||||||
#region Deserialize
|
#region Deserialize
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Archive"/> to <cref="Models.ClrMamePro.Archive"/>
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.ClrMamePro.ClrMamePro"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.ClrMamePro.ClrMamePro? ConvertHeaderToClrMamePro(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var clrMamePro = new Models.ClrMamePro.ClrMamePro
|
||||||
|
{
|
||||||
|
Name = item.ReadString(Models.Internal.Header.NameKey),
|
||||||
|
Description = item.ReadString(Models.Internal.Header.DescriptionKey),
|
||||||
|
RootDir = item.ReadString(Models.Internal.Header.RootDirKey),
|
||||||
|
Category = item.ReadString(Models.Internal.Header.CategoryKey),
|
||||||
|
Version = item.ReadString(Models.Internal.Header.VersionKey),
|
||||||
|
Date = item.ReadString(Models.Internal.Header.DateKey),
|
||||||
|
Author = item.ReadString(Models.Internal.Header.AuthorKey),
|
||||||
|
Homepage = item.ReadString(Models.Internal.Header.HomepageKey),
|
||||||
|
Url = item.ReadString(Models.Internal.Header.UrlKey),
|
||||||
|
Comment = item.ReadString(Models.Internal.Header.CommentKey),
|
||||||
|
Header = item.ReadString(Models.Internal.Header.HeaderKey),
|
||||||
|
Type = item.ReadString(Models.Internal.Header.TypeKey),
|
||||||
|
ForceMerging = item.ReadString(Models.Internal.Header.ForceMergingKey),
|
||||||
|
ForceZipping = item.ReadString(Models.Internal.Header.ForceZippingKey),
|
||||||
|
ForcePacking = item.ReadString(Models.Internal.Header.ForcePackingKey),
|
||||||
|
};
|
||||||
|
return clrMamePro;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Archive"/> to <cref="Models.ClrMamePro.Machine"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static Models.ClrMamePro.GameBase? ConvertMachineToClrMamePro(Models.Internal.Machine? item, bool game = false)
|
public static Models.ClrMamePro.GameBase? ConvertMachineToClrMamePro(Models.Internal.Machine? item, bool game = false)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ namespace SabreTools.Serialization
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.DosCenter.DosCenter"/> to <cref="Models.Internal.Header"/>
|
/// Convert from <cref="Models.DosCenter.DosCenter"/> to <cref="Models.Internal.Header"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static Models.Internal.Header ConvertHeaderFromArchiveDotOrg(Models.DosCenter.DosCenter item)
|
public static Models.Internal.Header ConvertHeaderFromDosCenter(Models.DosCenter.DosCenter item)
|
||||||
{
|
{
|
||||||
var header = new Models.Internal.Header
|
var header = new Models.Internal.Header
|
||||||
{
|
{
|
||||||
@@ -70,6 +70,27 @@ namespace SabreTools.Serialization
|
|||||||
|
|
||||||
#region Deserialize
|
#region Deserialize
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.DosCenter.DosCenter"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.DosCenter.DosCenter? ConvertHeaderToDosCenter(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var dosCenter = new Models.DosCenter.DosCenter
|
||||||
|
{
|
||||||
|
Name = item.ReadString(Models.Internal.Header.NameKey),
|
||||||
|
Description = item.ReadString(Models.Internal.Header.DescriptionKey),
|
||||||
|
Version = item.ReadString(Models.Internal.Header.VersionKey),
|
||||||
|
Date = item.ReadString(Models.Internal.Header.DateKey),
|
||||||
|
Author = item.ReadString(Models.Internal.Header.AuthorKey),
|
||||||
|
Homepage = item.ReadString(Models.Internal.Header.HomepageKey),
|
||||||
|
Comment = item.ReadString(Models.Internal.Header.CommentKey),
|
||||||
|
};
|
||||||
|
return dosCenter;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Machine"/> to <cref="Models.DosCenter.Game"/>
|
/// Convert from <cref="Models.Internal.Machine"/> to <cref="Models.DosCenter.Game"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -810,6 +810,38 @@ namespace SabreTools.Serialization
|
|||||||
|
|
||||||
#region Deserialize
|
#region Deserialize
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.Listxml.M1"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.Listxml.M1? ConvertHeaderToListxmlM1(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var m1 = new Models.Listxml.M1
|
||||||
|
{
|
||||||
|
Version = item.ReadString(Models.Internal.Header.VersionKey),
|
||||||
|
};
|
||||||
|
return m1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.Listxml.Mame"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.Listxml.Mame? ConvertHeaderToListxmlMame(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var mame = new Models.Listxml.Mame
|
||||||
|
{
|
||||||
|
Build = item.ReadString(Models.Internal.Header.BuildKey),
|
||||||
|
Debug = item.ReadString(Models.Internal.Header.DebugKey),
|
||||||
|
MameConfig = item.ReadString(Models.Internal.Header.MameConfigKey),
|
||||||
|
};
|
||||||
|
return mame;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Machine"/> to <cref="Models.Listxml.GameBase"/>
|
/// Convert from <cref="Models.Internal.Machine"/> to <cref="Models.Listxml.GameBase"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -1081,7 +1113,7 @@ namespace SabreTools.Serialization
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Device"/> to <cref="Models.Listxml.Device"/>
|
/// Convert from <cref="Models.Internal.Device"/> to <cref="Models.Listxml.Device"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private static Models.Listxml.Device ConvertToListxml(Models.Internal.Device item)
|
private static Models.Listxml.Device? ConvertToListxml(Models.Internal.Device? item)
|
||||||
{
|
{
|
||||||
if (item == null)
|
if (item == null)
|
||||||
return null;
|
return null;
|
||||||
|
|||||||
@@ -352,6 +352,68 @@ namespace SabreTools.Serialization
|
|||||||
|
|
||||||
#region Deserialize
|
#region Deserialize
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.Logiqx.Header"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.Logiqx.Header? ConvertHeaderToLogiqx(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var header = new Models.Logiqx.Header
|
||||||
|
{
|
||||||
|
Id = item.ReadString(Models.Internal.Header.IdKey),
|
||||||
|
Name = item.ReadString(Models.Internal.Header.NameKey),
|
||||||
|
Description = item.ReadString(Models.Internal.Header.DescriptionKey),
|
||||||
|
RootDir = item.ReadString(Models.Internal.Header.RootDirKey),
|
||||||
|
Category = item.ReadString(Models.Internal.Header.CategoryKey),
|
||||||
|
Version = item.ReadString(Models.Internal.Header.VersionKey),
|
||||||
|
Date = item.ReadString(Models.Internal.Header.DateKey),
|
||||||
|
Author = item.ReadString(Models.Internal.Header.AuthorKey),
|
||||||
|
Email = item.ReadString(Models.Internal.Header.EmailKey),
|
||||||
|
Homepage = item.ReadString(Models.Internal.Header.HomepageKey),
|
||||||
|
Url = item.ReadString(Models.Internal.Header.UrlKey),
|
||||||
|
Comment = item.ReadString(Models.Internal.Header.CommentKey),
|
||||||
|
Type = item.ReadString(Models.Internal.Header.TypeKey),
|
||||||
|
};
|
||||||
|
|
||||||
|
if (item.ContainsKey(Models.Internal.Header.HeaderKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.ForceMergingKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.ForceNodumpKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.ForcePackingKey))
|
||||||
|
{
|
||||||
|
header.ClrMamePro = new Models.Logiqx.ClrMamePro
|
||||||
|
{
|
||||||
|
Header = item.ReadString(Models.Internal.Header.HeaderKey),
|
||||||
|
ForceMerging = item.ReadString(Models.Internal.Header.ForceMergingKey),
|
||||||
|
ForceNodump = item.ReadString(Models.Internal.Header.ForceNodumpKey),
|
||||||
|
ForcePacking = item.ReadString(Models.Internal.Header.ForcePackingKey),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
if (item.ContainsKey(Models.Internal.Header.PluginKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.RomModeKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.BiosModeKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.SampleModeKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.LockRomModeKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.LockBiosModeKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.LockSampleModeKey))
|
||||||
|
{
|
||||||
|
header.RomCenter = new Models.Logiqx.RomCenter
|
||||||
|
{
|
||||||
|
Plugin = item.ReadString(Models.Internal.Header.PluginKey),
|
||||||
|
RomMode = item.ReadString(Models.Internal.Header.RomModeKey),
|
||||||
|
BiosMode = item.ReadString(Models.Internal.Header.BiosModeKey),
|
||||||
|
SampleMode = item.ReadString(Models.Internal.Header.SampleModeKey),
|
||||||
|
LockRomMode = item.ReadString(Models.Internal.Header.LockRomModeKey),
|
||||||
|
LockBiosMode = item.ReadString(Models.Internal.Header.LockBiosModeKey),
|
||||||
|
LockSampleMode = item.ReadString(Models.Internal.Header.LockSampleModeKey),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return header;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Archive"/> to <cref="Models.Logiqx.Archive"/>
|
/// Convert from <cref="Models.Internal.Archive"/> to <cref="Models.Logiqx.Archive"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -109,6 +109,58 @@ namespace SabreTools.Serialization
|
|||||||
|
|
||||||
#region Deserialize
|
#region Deserialize
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.OfflineList.Dat"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.OfflineList.Dat? ConvertHeaderToOfflineList(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var dat = new Models.OfflineList.Dat
|
||||||
|
{
|
||||||
|
NoNamespaceSchemaLocation = item.ReadString(Models.Internal.Header.NoNamespaceSchemaLocationKey),
|
||||||
|
};
|
||||||
|
|
||||||
|
if (item.ContainsKey(Models.Internal.Header.NameKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.ImFolderKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.DatVersionKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.SystemKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.ScreenshotsWidthKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.ScreenshotsHeightKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.InfosKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.CanOpenKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.NewDatKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.SearchKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.RomTitleKey))
|
||||||
|
{
|
||||||
|
dat.Configuration = new Models.OfflineList.Configuration
|
||||||
|
{
|
||||||
|
DatName = item.ReadString(Models.Internal.Header.NameKey),
|
||||||
|
ImFolder = item.ReadString(Models.Internal.Header.ImFolderKey),
|
||||||
|
DatVersion = item.ReadString(Models.Internal.Header.DatVersionKey),
|
||||||
|
System = item.ReadString(Models.Internal.Header.SystemKey),
|
||||||
|
ScreenshotsWidth = item.ReadString(Models.Internal.Header.ScreenshotsWidthKey),
|
||||||
|
ScreenshotsHeight = item.ReadString(Models.Internal.Header.ScreenshotsHeightKey),
|
||||||
|
Infos = item.Read<Models.OfflineList.Infos>(Models.Internal.Header.InfosKey),
|
||||||
|
CanOpen = item.Read<Models.OfflineList.CanOpen>(Models.Internal.Header.CanOpenKey),
|
||||||
|
NewDat = item.Read<Models.OfflineList.NewDat>(Models.Internal.Header.NewDatKey),
|
||||||
|
Search = item.Read<Models.OfflineList.Search>(Models.Internal.Header.SearchKey),
|
||||||
|
RomTitle = item.ReadString(Models.Internal.Header.RomTitleKey),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
if (item.ContainsKey(Models.Internal.Header.ImagesKey))
|
||||||
|
{
|
||||||
|
dat.GUI = new Models.OfflineList.GUI
|
||||||
|
{
|
||||||
|
Images = item.Read<Models.OfflineList.Images>(Models.Internal.Header.ImagesKey),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return dat;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Machine"/> to <cref="Models.OfflineList.Game"/>
|
/// Convert from <cref="Models.Internal.Machine"/> to <cref="Models.OfflineList.Game"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -110,6 +110,21 @@ namespace SabreTools.Serialization
|
|||||||
|
|
||||||
#region Deserialize
|
#region Deserialize
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.OpenMSX.SoftwareDb"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.OpenMSX.SoftwareDb? ConvertHeaderToOpenMSX(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var softwareDb = new Models.OpenMSX.SoftwareDb
|
||||||
|
{
|
||||||
|
Timestamp = item.ReadString(Models.Internal.Header.TimestampKey),
|
||||||
|
};
|
||||||
|
return softwareDb;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Machine"/> to <cref="Models.OpenMSX.Software"/>
|
/// Convert from <cref="Models.Internal.Machine"/> to <cref="Models.OpenMSX.Software"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -83,6 +83,62 @@ namespace SabreTools.Serialization
|
|||||||
|
|
||||||
#region Deserialize
|
#region Deserialize
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.RomCenter.MetadataFile"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.RomCenter.MetadataFile? ConvertHeaderToRomCenter(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var metadataFile = new Models.RomCenter.MetadataFile();
|
||||||
|
|
||||||
|
if (item.ContainsKey(Models.Internal.Header.AuthorKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.VersionKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.EmailKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.HomepageKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.UrlKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.DateKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.CommentKey))
|
||||||
|
{
|
||||||
|
metadataFile.Credits = new Models.RomCenter.Credits
|
||||||
|
{
|
||||||
|
Author = item.ReadString(Models.Internal.Header.AuthorKey),
|
||||||
|
Version = item.ReadString(Models.Internal.Header.VersionKey),
|
||||||
|
Email = item.ReadString(Models.Internal.Header.EmailKey),
|
||||||
|
Homepage = item.ReadString(Models.Internal.Header.HomepageKey),
|
||||||
|
Url = item.ReadString(Models.Internal.Header.UrlKey),
|
||||||
|
Date = item.ReadString(Models.Internal.Header.DateKey),
|
||||||
|
Comment = item.ReadString(Models.Internal.Header.CommentKey),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
if (item.ContainsKey(Models.Internal.Header.DatVersionKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.PluginKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.ForceMergingKey))
|
||||||
|
{
|
||||||
|
metadataFile.Dat = new Models.RomCenter.Dat
|
||||||
|
{
|
||||||
|
Version = item.ReadString(Models.Internal.Header.DatVersionKey),
|
||||||
|
Plugin = item.ReadString(Models.Internal.Header.PluginKey),
|
||||||
|
Split = item.ReadString(Models.Internal.Header.ForceMergingKey) == "split" ? "yes" : "no",
|
||||||
|
Merge = item.ReadString(Models.Internal.Header.ForceMergingKey) == "merge" ? "yes" : "no",
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
if (item.ContainsKey(Models.Internal.Header.RefNameKey)
|
||||||
|
|| item.ContainsKey(Models.Internal.Header.EmulatorVersionKey))
|
||||||
|
{
|
||||||
|
metadataFile.Emulator = new Models.RomCenter.Emulator
|
||||||
|
{
|
||||||
|
RefName = item.ReadString(Models.Internal.Header.RefNameKey),
|
||||||
|
Version = item.ReadString(Models.Internal.Header.EmulatorVersionKey),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return metadataFile;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Machine"/> to an array of <cref="Models.RomCenter.Rom"/>
|
/// Convert from <cref="Models.Internal.Machine"/> to an array of <cref="Models.RomCenter.Rom"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -13,7 +13,7 @@ namespace SabreTools.Serialization
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.SeparatedValue.MetadataFile"/> to <cref="Models.Internal.Header"/>
|
/// Convert from <cref="Models.SeparatedValue.MetadataFile"/> to <cref="Models.Internal.Header"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public static Models.Internal.Header ConvertHeaderFromArchiveDotOrg(Models.SeparatedValue.MetadataFile item)
|
public static Models.Internal.Header ConvertHeaderFromSeparatedValue(Models.SeparatedValue.MetadataFile item)
|
||||||
{
|
{
|
||||||
var header = new Models.Internal.Header
|
var header = new Models.Internal.Header
|
||||||
{
|
{
|
||||||
@@ -104,6 +104,21 @@ namespace SabreTools.Serialization
|
|||||||
|
|
||||||
#region Deserialize
|
#region Deserialize
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.SeparatedValue.MetadataFile"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.SeparatedValue.MetadataFile? ConvertHeaderToSeparatedValue(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var metadataFile = new Models.SeparatedValue.MetadataFile
|
||||||
|
{
|
||||||
|
Header = item.ReadStringArray(Models.Internal.Header.HeaderKey),
|
||||||
|
};
|
||||||
|
return metadataFile;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Machine"/> to an array of <cref="Models.SeparatedValue.Row"/>
|
/// Convert from <cref="Models.Internal.Machine"/> to an array of <cref="Models.SeparatedValue.Row"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -294,6 +294,23 @@ namespace SabreTools.Serialization
|
|||||||
|
|
||||||
#region Deserialize
|
#region Deserialize
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Convert from <cref="Models.Internal.Header"/> to <cref="Models.SoftwareList.SoftwareList"/>
|
||||||
|
/// </summary>
|
||||||
|
public static Models.SoftwareList.SoftwareList? ConvertHeaderToSoftwareList(Models.Internal.Header? item)
|
||||||
|
{
|
||||||
|
if (item == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var softwareList = new Models.SoftwareList.SoftwareList
|
||||||
|
{
|
||||||
|
Name = item.ReadString(Models.Internal.Header.NameKey),
|
||||||
|
Description = item.ReadString(Models.Internal.Header.DescriptionKey),
|
||||||
|
Notes = item.ReadString(Models.Internal.Header.NotesKey),
|
||||||
|
};
|
||||||
|
return softwareList;
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Convert from <cref="Models.Internal.Machine"/> to <cref="Models.SoftwareList.Software"/>
|
/// Convert from <cref="Models.Internal.Machine"/> to <cref="Models.SoftwareList.Software"/>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
Reference in New Issue
Block a user