diff --git a/SabreTools.Serialization/Internal.ArchiveDotOrg.cs b/SabreTools.Serialization/Internal.ArchiveDotOrg.cs
index 75e06122..36850327 100644
--- a/SabreTools.Serialization/Internal.ArchiveDotOrg.cs
+++ b/SabreTools.Serialization/Internal.ArchiveDotOrg.cs
@@ -9,6 +9,18 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromArchiveDotOrg(Models.ArchiveDotOrg.Files item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.NameKey] = "archive.org",
+ };
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.AttractMode.cs b/SabreTools.Serialization/Internal.AttractMode.cs
index 352baa9b..8f1b5f73 100644
--- a/SabreTools.Serialization/Internal.AttractMode.cs
+++ b/SabreTools.Serialization/Internal.AttractMode.cs
@@ -9,6 +9,18 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromAttractMode(Models.AttractMode.MetadataFile item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.HeaderKey] = item.Header,
+ };
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.ClrMamePro.cs b/SabreTools.Serialization/Internal.ClrMamePro.cs
index acf0e0d2..45d532c6 100644
--- a/SabreTools.Serialization/Internal.ClrMamePro.cs
+++ b/SabreTools.Serialization/Internal.ClrMamePro.cs
@@ -10,6 +10,32 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromClrMamePro(Models.ClrMamePro.ClrMamePro item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.NameKey] = item.Name,
+ [Models.Internal.Header.DescriptionKey] = item.Description,
+ [Models.Internal.Header.RootDirKey] = item.RootDir,
+ [Models.Internal.Header.CategoryKey] = item.Category,
+ [Models.Internal.Header.VersionKey] = item.Version,
+ [Models.Internal.Header.DateKey] = item.Date,
+ [Models.Internal.Header.AuthorKey] = item.Author,
+ [Models.Internal.Header.HomepageKey] = item.Homepage,
+ [Models.Internal.Header.UrlKey] = item.Url,
+ [Models.Internal.Header.CommentKey] = item.Comment,
+ [Models.Internal.Header.HeaderKey] = item.Header,
+ [Models.Internal.Header.TypeKey] = item.Type,
+ [Models.Internal.Header.ForceMergingKey] = item.ForceMerging,
+ [Models.Internal.Header.ForceZippingKey] = item.ForceZipping,
+ [Models.Internal.Header.ForcePackingKey] = item.ForcePacking,
+ };
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.DosCenter.cs b/SabreTools.Serialization/Internal.DosCenter.cs
index 81c463a3..1ec947d4 100644
--- a/SabreTools.Serialization/Internal.DosCenter.cs
+++ b/SabreTools.Serialization/Internal.DosCenter.cs
@@ -10,6 +10,24 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromArchiveDotOrg(Models.DosCenter.DosCenter item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.NameKey] = item.Name,
+ [Models.Internal.Header.DescriptionKey] = item.Description,
+ [Models.Internal.Header.VersionKey] = item.Version,
+ [Models.Internal.Header.DateKey] = item.Date,
+ [Models.Internal.Header.AuthorKey] = item.Author,
+ [Models.Internal.Header.HomepageKey] = item.Homepage,
+ [Models.Internal.Header.CommentKey] = item.Comment,
+ };
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.EverdriveSMDB.cs b/SabreTools.Serialization/Internal.EverdriveSMDB.cs
index a45389cd..08b09ff6 100644
--- a/SabreTools.Serialization/Internal.EverdriveSMDB.cs
+++ b/SabreTools.Serialization/Internal.EverdriveSMDB.cs
@@ -1,4 +1,3 @@
-using System.Collections.Generic;
using System.Linq;
namespace SabreTools.Serialization
@@ -10,6 +9,18 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromEverdriveSMDB(Models.EverdriveSMDB.MetadataFile item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.NameKey] = "Everdrive SMDB",
+ };
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.Hashfile.cs b/SabreTools.Serialization/Internal.Hashfile.cs
index d930d2bd..3ca1e082 100644
--- a/SabreTools.Serialization/Internal.Hashfile.cs
+++ b/SabreTools.Serialization/Internal.Hashfile.cs
@@ -11,6 +11,18 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromHashfile(Models.Hashfile.Hashfile item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.NameKey] = "Hashfile",
+ };
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.Listrom.cs b/SabreTools.Serialization/Internal.Listrom.cs
index 67c559dd..775e2a76 100644
--- a/SabreTools.Serialization/Internal.Listrom.cs
+++ b/SabreTools.Serialization/Internal.Listrom.cs
@@ -10,6 +10,18 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromListrom(Models.Listrom.MetadataFile item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.NameKey] = "MAME Listrom",
+ };
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.Listxml.cs b/SabreTools.Serialization/Internal.Listxml.cs
index 6617ccce..93afdd4f 100644
--- a/SabreTools.Serialization/Internal.Listxml.cs
+++ b/SabreTools.Serialization/Internal.Listxml.cs
@@ -10,6 +10,32 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromListxml(Models.Listxml.M1 item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.VersionKey] = item.Version,
+ };
+ return header;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromListxml(Models.Listxml.Mame item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.BuildKey] = item.Build,
+ [Models.Internal.Header.DebugKey] = item.Debug,
+ [Models.Internal.Header.MameConfigKey] = item.MameConfig,
+ };
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.Logiqx.cs b/SabreTools.Serialization/Internal.Logiqx.cs
index 57009074..a28f23b5 100644
--- a/SabreTools.Serialization/Internal.Logiqx.cs
+++ b/SabreTools.Serialization/Internal.Logiqx.cs
@@ -10,6 +10,50 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromLogiqx(Models.Logiqx.Header item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.IdKey] = item.Id,
+ [Models.Internal.Header.NameKey] = item.Name,
+ [Models.Internal.Header.DescriptionKey] = item.Description,
+ [Models.Internal.Header.RootDirKey] = item.RootDir,
+ [Models.Internal.Header.CategoryKey] = item.Category,
+ [Models.Internal.Header.VersionKey] = item.Version,
+ [Models.Internal.Header.DateKey] = item.Date,
+ [Models.Internal.Header.AuthorKey] = item.Author,
+ [Models.Internal.Header.EmailKey] = item.Email,
+ [Models.Internal.Header.HomepageKey] = item.Homepage,
+ [Models.Internal.Header.UrlKey] = item.Url,
+ [Models.Internal.Header.CommentKey] = item.Comment,
+ [Models.Internal.Header.TypeKey] = item.Type,
+ };
+
+ if (item.ClrMamePro != null)
+ {
+ header[Models.Internal.Header.HeaderKey] = item.ClrMamePro.Header;
+ header[Models.Internal.Header.ForceMergingKey] = item.ClrMamePro.ForceMerging;
+ header[Models.Internal.Header.ForceNodumpKey] = item.ClrMamePro.ForceNodump;
+ header[Models.Internal.Header.ForcePackingKey] = item.ClrMamePro.ForcePacking;
+ }
+
+ if (item.RomCenter != null)
+ {
+ header[Models.Internal.Header.PluginKey] = item.RomCenter.Plugin;
+ header[Models.Internal.Header.RomModeKey] = item.RomCenter.RomMode;
+ header[Models.Internal.Header.BiosModeKey] = item.RomCenter.BiosMode;
+ header[Models.Internal.Header.SampleModeKey] = item.RomCenter.SampleMode;
+ header[Models.Internal.Header.LockRomModeKey] = item.RomCenter.LockRomMode;
+ header[Models.Internal.Header.LockBiosModeKey] = item.RomCenter.LockBiosMode;
+ header[Models.Internal.Header.LockSampleModeKey] = item.RomCenter.LockSampleMode;
+ }
+
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.OfflineList.cs b/SabreTools.Serialization/Internal.OfflineList.cs
index b55f9f0e..1548140a 100644
--- a/SabreTools.Serialization/Internal.OfflineList.cs
+++ b/SabreTools.Serialization/Internal.OfflineList.cs
@@ -10,6 +10,39 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromOfflineList(Models.OfflineList.Dat item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.NoNamespaceSchemaLocationKey] = item.NoNamespaceSchemaLocation,
+ };
+
+ if (item.Configuration != null)
+ {
+ header[Models.Internal.Header.NameKey] = item.Configuration.DatName;
+ header[Models.Internal.Header.ImFolderKey] = item.Configuration.ImFolder;
+ header[Models.Internal.Header.DatVersionKey] = item.Configuration.DatVersion;
+ header[Models.Internal.Header.SystemKey] = item.Configuration.System;
+ header[Models.Internal.Header.ScreenshotsWidthKey] = item.Configuration.ScreenshotsWidth;
+ header[Models.Internal.Header.ScreenshotsHeightKey] = item.Configuration.ScreenshotsHeight;
+ header[Models.Internal.Header.InfosKey] = item.Configuration.Infos;
+ header[Models.Internal.Header.CanOpenKey] = item.Configuration.CanOpen;
+ header[Models.Internal.Header.NewDatKey] = item.Configuration.NewDat;
+ header[Models.Internal.Header.SearchKey] = item.Configuration.Search;
+ header[Models.Internal.Header.RomTitleKey] = item.Configuration.RomTitle;
+ }
+
+ if (item.GUI != null)
+ {
+ header[Models.Internal.Header.ImagesKey] = item.GUI.Images;
+ }
+
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.OpenMSX.cs b/SabreTools.Serialization/Internal.OpenMSX.cs
index 8280a04f..eaf9d5ed 100644
--- a/SabreTools.Serialization/Internal.OpenMSX.cs
+++ b/SabreTools.Serialization/Internal.OpenMSX.cs
@@ -10,6 +10,18 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromOpenMSX(Models.OpenMSX.SoftwareDb item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.TimestampKey] = item.Timestamp,
+ };
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.RomCenter.cs b/SabreTools.Serialization/Internal.RomCenter.cs
index 3673758a..53ce7d63 100644
--- a/SabreTools.Serialization/Internal.RomCenter.cs
+++ b/SabreTools.Serialization/Internal.RomCenter.cs
@@ -9,6 +9,44 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromRomCenter(Models.RomCenter.MetadataFile item)
+ {
+ var header = new Models.Internal.Header();
+
+ if (item.Credits != null)
+ {
+ header[Models.Internal.Header.AuthorKey] = item.Credits.Author;
+ header[Models.Internal.Header.VersionKey] = item.Credits.Version;
+ header[Models.Internal.Header.EmailKey] = item.Credits.Email;
+ header[Models.Internal.Header.HomepageKey] = item.Credits.Homepage;
+ header[Models.Internal.Header.UrlKey] = item.Credits.Url;
+ header[Models.Internal.Header.DateKey] = item.Credits.Date;
+ header[Models.Internal.Header.CommentKey] = item.Credits.Comment;
+ }
+
+ if (item.Dat != null)
+ {
+ header[Models.Internal.Header.DatVersionKey] = item.Dat.Version;
+ header[Models.Internal.Header.PluginKey] = item.Dat.Plugin;
+
+ if (item.Dat.Split == "yes" || item.Dat.Split == "1")
+ header[Models.Internal.Header.ForceMergingKey] = "split";
+ else if (item.Dat.Merge == "yes" || item.Dat.Merge == "1")
+ header[Models.Internal.Header.ForceMergingKey] = "merge";
+ }
+
+ if (item.Emulator != null)
+ {
+ header[Models.Internal.Header.RefNameKey] = item.Emulator.RefName;
+ header[Models.Internal.Header.EmulatorVersionKey] = item.Emulator.Version;
+ }
+
+ return header;
+ }
+
///
/// Convert from to
///
@@ -17,7 +55,7 @@ namespace SabreTools.Serialization
var machine = new Models.Internal.Machine
{
[Models.Internal.Machine.RomOfKey] = item.ParentName,
- //[Models.Internal.Machine.RomOfKey] = item.ParentDescription, // This is unmappable
+ //[Models.Internal.Machine.ParentDescriptionKey] = item.ParentDescription, // This is unmappable
[Models.Internal.Machine.NameKey] = item.GameName,
[Models.Internal.Machine.DescriptionKey] = item.GameDescription,
[Models.Internal.Machine.RomKey] = new Models.Internal.Rom[] { ConvertFromRomCenter(item) },
diff --git a/SabreTools.Serialization/Internal.SeparatedValue.cs b/SabreTools.Serialization/Internal.SeparatedValue.cs
index ebeef684..86ba4736 100644
--- a/SabreTools.Serialization/Internal.SeparatedValue.cs
+++ b/SabreTools.Serialization/Internal.SeparatedValue.cs
@@ -10,6 +10,27 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromArchiveDotOrg(Models.SeparatedValue.MetadataFile item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.HeaderKey] = item.Header,
+ };
+
+ if (item.Row != null && item.Row.Any())
+ {
+ var first = item.Row[0];
+ //header[Models.Internal.Header.FileNameKey] = first.FileName; // Not possible to map
+ header[Models.Internal.Header.NameKey] = first.FileName;
+ header[Models.Internal.Header.DescriptionKey] = first.Description;
+ }
+
+ return header;
+ }
+
///
/// Convert from to
///
diff --git a/SabreTools.Serialization/Internal.SoftwareList.cs b/SabreTools.Serialization/Internal.SoftwareList.cs
index 8d81dc5b..c2f0ad28 100644
--- a/SabreTools.Serialization/Internal.SoftwareList.cs
+++ b/SabreTools.Serialization/Internal.SoftwareList.cs
@@ -10,6 +10,20 @@ namespace SabreTools.Serialization
{
#region Serialize
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Header ConvertHeaderFromSoftwareList(Models.SoftwareList.SoftwareList item)
+ {
+ var header = new Models.Internal.Header
+ {
+ [Models.Internal.Header.NameKey] = item.Name,
+ [Models.Internal.Header.DescriptionKey] = item.Description,
+ [Models.Internal.Header.NotesKey] = item.Notes,
+ };
+ return header;
+ }
+
///
/// Convert from to
///