diff --git a/SabreTools.Serialization/Internal.Deserializer.cs b/SabreTools.Serialization/Internal.Deserializer.cs
index e6bdc7b6..74f24eca 100644
--- a/SabreTools.Serialization/Internal.Deserializer.cs
+++ b/SabreTools.Serialization/Internal.Deserializer.cs
@@ -64,7 +64,7 @@ namespace SabreTools.Serialization
WordConfidenceInterval71To80 = item.ReadString(Models.Internal.Rom.WordConfidenceInterval71To80Key),
WordConfidenceInterval81To90 = item.ReadString(Models.Internal.Rom.WordConfidenceInterval81To90Key),
WordConfidenceInterval91To100 = item.ReadString(Models.Internal.Rom.WordConfidenceInterval91To100Key),
-
+
Album = item.ReadString(Models.Internal.Rom.AlbumKey),
Artist = item.ReadString(Models.Internal.Rom.ArtistKey),
Bitrate = item.ReadString(Models.Internal.Rom.BitrateKey),
@@ -89,13 +89,228 @@ namespace SabreTools.Serialization
///
public static Models.AttractMode.Row ConvertToAttractMode(Models.Internal.Rom item)
{
- var file = new Models.AttractMode.Row
+ var row = new Models.AttractMode.Row
{
Title = item.ReadString(Models.Internal.Rom.NameKey),
AltRomname = item.ReadString(Models.Internal.Rom.AltRomnameKey),
AltTitle = item.ReadString(Models.Internal.Rom.AltTitleKey),
};
- return file;
+ return row;
+ }
+
+ #endregion
+
+ #region ClrMamePro
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Archive ConvertToClrMamePro(Models.Internal.Archive item)
+ {
+ var archive = new Models.ClrMamePro.Archive
+ {
+ Name = item.ReadString(Models.Internal.Archive.NameKey),
+ };
+ return archive;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.BiosSet ConvertToClrMamePro(Models.Internal.BiosSet item)
+ {
+ var biosset = new Models.ClrMamePro.BiosSet
+ {
+ Name = item.ReadString(Models.Internal.BiosSet.NameKey),
+ Description = item.ReadString(Models.Internal.BiosSet.DescriptionKey),
+ Default = item.ReadString(Models.Internal.BiosSet.DefaultKey),
+ };
+ return biosset;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Chip ConvertToClrMamePro(Models.Internal.Chip item)
+ {
+ var chip = new Models.ClrMamePro.Chip
+ {
+ Type = item.ReadString(Models.Internal.Chip.ChipTypeKey),
+ Name = item.ReadString(Models.Internal.Chip.NameKey),
+ Flags = item.ReadString(Models.Internal.Chip.FlagsKey),
+ Clock = item.ReadString(Models.Internal.Chip.ClockKey),
+ };
+ return chip;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.DipSwitch ConvertToClrMamePro(Models.Internal.DipSwitch item)
+ {
+ var dipswitch = new Models.ClrMamePro.DipSwitch
+ {
+ Name = item.ReadString(Models.Internal.DipSwitch.NameKey),
+ Entry = item[Models.Internal.DipSwitch.EntryKey] as string[],
+ Default = item.ReadString(Models.Internal.DipSwitch.DefaultKey),
+ };
+ return dipswitch;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Disk ConvertToClrMamePro(Models.Internal.Disk item)
+ {
+ var disk = new Models.ClrMamePro.Disk
+ {
+ Name = item.ReadString(Models.Internal.Disk.NameKey),
+ MD5 = item.ReadString(Models.Internal.Disk.MD5Key),
+ SHA1 = item.ReadString(Models.Internal.Disk.SHA1Key),
+ Merge = item.ReadString(Models.Internal.Disk.MergeKey),
+ Status = item.ReadString(Models.Internal.Disk.StatusKey),
+ Flags = item.ReadString(Models.Internal.Disk.FlagsKey),
+ };
+ return disk;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Driver ConvertToClrMamePro(Models.Internal.Driver item)
+ {
+ var driver = new Models.ClrMamePro.Driver
+ {
+ Status = item.ReadString(Models.Internal.Driver.StatusKey),
+ Color = item.ReadString(Models.Internal.Driver.ColorKey),
+ Sound = item.ReadString(Models.Internal.Driver.SoundKey),
+ PaletteSize = item.ReadString(Models.Internal.Driver.PaletteSizeKey),
+ Blit = item.ReadString(Models.Internal.Driver.BlitKey),
+ };
+ return driver;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Input ConvertToClrMamePro(Models.Internal.Input item)
+ {
+ var input = new Models.ClrMamePro.Input
+ {
+ Players = item.ReadString(Models.Internal.Input.PlayersKey),
+ Control = item.ReadString(Models.Internal.Input.ControlKey),
+ Buttons = item.ReadString(Models.Internal.Input.ButtonsKey),
+ Coins = item.ReadString(Models.Internal.Input.CoinsKey),
+ Tilt = item.ReadString(Models.Internal.Input.TiltKey),
+ Service = item.ReadString(Models.Internal.Input.ServiceKey),
+ };
+ return input;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Media ConvertToClrMamePro(Models.Internal.Media item)
+ {
+ var media = new Models.ClrMamePro.Media
+ {
+ Name = 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 media;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Release ConvertToClrMamePro(Models.Internal.Release item)
+ {
+ var release = new Models.ClrMamePro.Release
+ {
+ Name = item.ReadString(Models.Internal.Release.NameKey),
+ Region = item.ReadString(Models.Internal.Release.RegionKey),
+ Language = item.ReadString(Models.Internal.Release.LanguageKey),
+ Date = item.ReadString(Models.Internal.Release.DateKey),
+ Default = item.ReadString(Models.Internal.Release.DefaultKey),
+ };
+ return release;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Rom ConvertToClrMamePro(Models.Internal.Rom item)
+ {
+ var rom = new Models.ClrMamePro.Rom
+ {
+ Name = 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),
+ xxHash364 = item.ReadString(Models.Internal.Rom.xxHash364Key),
+ xxHash3128 = item.ReadString(Models.Internal.Rom.xxHash3128Key),
+ Merge = item.ReadString(Models.Internal.Rom.MergeKey),
+ Status = item.ReadString(Models.Internal.Rom.StatusKey),
+ Region = item.ReadString(Models.Internal.Rom.RegionKey),
+ Flags = item.ReadString(Models.Internal.Rom.FlagsKey),
+ Offs = item.ReadString(Models.Internal.Rom.OffsetKey),
+ Serial = item.ReadString(Models.Internal.Rom.SerialKey),
+ Header = item.ReadString(Models.Internal.Rom.HeaderKey),
+ Date = item.ReadString(Models.Internal.Rom.DateKey),
+ Inverted = item.ReadString(Models.Internal.Rom.InvertedKey),
+ MIA = item.ReadString(Models.Internal.Rom.MIAKey),
+ };
+ return rom;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Sample ConvertToClrMamePro(Models.Internal.Sample item)
+ {
+ var sample = new Models.ClrMamePro.Sample
+ {
+ Name = item.ReadString(Models.Internal.Sample.NameKey),
+ };
+ return sample;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Sound ConvertToClrMamePro(Models.Internal.Sound item)
+ {
+ var sound = new Models.ClrMamePro.Sound
+ {
+ Channels = item.ReadString(Models.Internal.Sound.ChannelsKey),
+ };
+ return sound;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.ClrMamePro.Video ConvertToClrMamePro(Models.Internal.Video item)
+ {
+ var video = new Models.ClrMamePro.Video
+ {
+ Screen = item.ReadString(Models.Internal.Video.ScreenKey),
+ Orientation = item.ReadString(Models.Internal.Video.OrientationKey),
+ X = item.ReadString(Models.Internal.Video.WidthKey),
+ Y = item.ReadString(Models.Internal.Video.HeightKey),
+ AspectX = item.ReadString(Models.Internal.Video.AspectXKey),
+ AspectY = item.ReadString(Models.Internal.Video.AspectYKey),
+ Freq = item.ReadString(Models.Internal.Video.RefreshKey),
+ };
+ return video;
}
#endregion
diff --git a/SabreTools.Serialization/Internal.Serializer.cs b/SabreTools.Serialization/Internal.Serializer.cs
index 8fcb6e88..2492f4c6 100644
--- a/SabreTools.Serialization/Internal.Serializer.cs
+++ b/SabreTools.Serialization/Internal.Serializer.cs
@@ -100,5 +100,220 @@ namespace SabreTools.Serialization
}
#endregion
+
+ #region ClrMamePro
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Archive ConvertFromClrMamePro(Models.ClrMamePro.Archive item)
+ {
+ var archive = new Models.Internal.Archive
+ {
+ [Models.Internal.Archive.NameKey] = item.Name,
+ };
+ return archive;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.BiosSet ConvertFromClrMamePro(Models.ClrMamePro.BiosSet item)
+ {
+ var biosset = new Models.Internal.BiosSet
+ {
+ [Models.Internal.BiosSet.NameKey] = item.Name,
+ [Models.Internal.BiosSet.DescriptionKey] = item.Description,
+ [Models.Internal.BiosSet.DefaultKey] = item.Default,
+ };
+ return biosset;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Chip ConvertFromClrMamePro(Models.ClrMamePro.Chip item)
+ {
+ var chip = new Models.Internal.Chip
+ {
+ [Models.Internal.Chip.ChipTypeKey] = item.Type,
+ [Models.Internal.Chip.NameKey] = item.Name,
+ [Models.Internal.Chip.FlagsKey] = item.Flags,
+ [Models.Internal.Chip.ClockKey] = item.Clock,
+ };
+ return chip;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.DipSwitch ConvertFromClrMamePro(Models.ClrMamePro.DipSwitch item)
+ {
+ var dipswitch = new Models.Internal.DipSwitch
+ {
+ [Models.Internal.DipSwitch.NameKey] = item.Name,
+ [Models.Internal.DipSwitch.EntryKey] = item.Entry,
+ [Models.Internal.DipSwitch.DefaultKey] = item.Default,
+ };
+ return dipswitch;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Disk ConvertFromClrMamePro(Models.ClrMamePro.Disk item)
+ {
+ var disk = new Models.Internal.Disk
+ {
+ [Models.Internal.Disk.NameKey] = item.Name,
+ [Models.Internal.Disk.MD5Key] = item.MD5,
+ [Models.Internal.Disk.SHA1Key] = item.SHA1,
+ [Models.Internal.Disk.MergeKey] = item.Merge,
+ [Models.Internal.Disk.StatusKey] = item.Status,
+ [Models.Internal.Disk.FlagsKey] = item.Flags,
+ };
+ return disk;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Driver ConvertFromClrMamePro(Models.ClrMamePro.Driver item)
+ {
+ var driver = new Models.Internal.Driver
+ {
+ [Models.Internal.Driver.StatusKey] = item.Status,
+ [Models.Internal.Driver.ColorKey] = item.Color,
+ [Models.Internal.Driver.SoundKey] = item.Sound,
+ [Models.Internal.Driver.PaletteSizeKey] = item.PaletteSize,
+ [Models.Internal.Driver.BlitKey] = item.Blit,
+ };
+ return driver;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Input ConvertFromClrMamePro(Models.ClrMamePro.Input item)
+ {
+ var input = new Models.Internal.Input
+ {
+ [Models.Internal.Input.PlayersKey] = item.Players,
+ [Models.Internal.Input.ControlKey] = item.Control,
+ [Models.Internal.Input.ButtonsKey] = item.Buttons,
+ [Models.Internal.Input.CoinsKey] = item.Coins,
+ [Models.Internal.Input.TiltKey] = item.Tilt,
+ [Models.Internal.Input.ServiceKey] = item.Service,
+ };
+ return input;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Media ConvertFromClrMamePro(Models.ClrMamePro.Media item)
+ {
+ var media = new Models.Internal.Media
+ {
+ [Models.Internal.Media.NameKey] = item.Name,
+ [Models.Internal.Media.MD5Key] = item.MD5,
+ [Models.Internal.Media.SHA1Key] = item.SHA1,
+ [Models.Internal.Media.SHA256Key] = item.SHA256,
+ [Models.Internal.Media.SpamSumKey] = item.SpamSum,
+ };
+ return media;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Release ConvertFromClrMamePro(Models.ClrMamePro.Release item)
+ {
+ var release = new Models.Internal.Release
+ {
+ [Models.Internal.Release.NameKey] = item.Name,
+ [Models.Internal.Release.RegionKey] = item.Region,
+ [Models.Internal.Release.LanguageKey] = item.Language,
+ [Models.Internal.Release.DateKey] = item.Date,
+ [Models.Internal.Release.DefaultKey] = item.Default,
+ };
+ return release;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Rom ConvertFromClrMamePro(Models.ClrMamePro.Rom item)
+ {
+ 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.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.xxHash364Key] = item.xxHash364,
+ [Models.Internal.Rom.xxHash3128Key] = item.xxHash3128,
+ [Models.Internal.Rom.MergeKey] = item.Merge,
+ [Models.Internal.Rom.StatusKey] = item.Status,
+ [Models.Internal.Rom.RegionKey] = item.Region,
+ [Models.Internal.Rom.FlagsKey] = item.Flags,
+ [Models.Internal.Rom.OffsetKey] = item.Offs,
+ [Models.Internal.Rom.SerialKey] = item.Serial,
+ [Models.Internal.Rom.HeaderKey] = item.Header,
+ [Models.Internal.Rom.DateKey] = item.Date,
+ [Models.Internal.Rom.InvertedKey] = item.Inverted,
+ [Models.Internal.Rom.MIAKey] = item.MIA,
+ };
+ return rom;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Sample ConvertFromClrMamePro(Models.ClrMamePro.Sample item)
+ {
+ var sample = new Models.Internal.Sample
+ {
+ [Models.Internal.Sample.NameKey] = item.Name,
+ };
+ return sample;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Sound ConvertFromClrMamePro(Models.ClrMamePro.Sound item)
+ {
+ var sound = new Models.Internal.Sound
+ {
+ [Models.Internal.Sound.ChannelsKey] = item.Channels,
+ };
+ return sound;
+ }
+
+ ///
+ /// Convert from to
+ ///
+ public static Models.Internal.Video ConvertFromClrMamePro(Models.ClrMamePro.Video item)
+ {
+ var video = new Models.Internal.Video
+ {
+ [Models.Internal.Video.ScreenKey] = item.Screen,
+ [Models.Internal.Video.OrientationKey] = item.Orientation,
+ [Models.Internal.Video.WidthKey] = item.X,
+ [Models.Internal.Video.HeightKey] = item.Y,
+ [Models.Internal.Video.AspectXKey] = item.AspectX,
+ [Models.Internal.Video.AspectYKey] = item.AspectY,
+ [Models.Internal.Video.RefreshKey] = item.Freq,
+ };
+ return video;
+ }
+
+ #endregion
}
}
\ No newline at end of file