mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Implement SetFields
This commit is contained in:
@@ -2,6 +2,8 @@
|
||||
|
||||
using SabreTools.Library.Filtering;
|
||||
using Newtonsoft.Json;
|
||||
using System.Linq;
|
||||
using SabreTools.Library.Tools;
|
||||
|
||||
namespace SabreTools.Library.DatItems
|
||||
{
|
||||
@@ -60,6 +62,23 @@ namespace SabreTools.Library.DatItems
|
||||
return fieldValue;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Set fields with given values
|
||||
/// </summary>
|
||||
/// <param name="mappings">Mappings dictionary</param>
|
||||
public override void SetFields(Dictionary<Field, string> mappings)
|
||||
{
|
||||
// Set base fields
|
||||
base.SetFields(mappings);
|
||||
|
||||
// Handle BiosSet-specific fields
|
||||
if (mappings.Keys.Contains(Field.Default))
|
||||
Default = mappings[Field.Default].AsYesNo();
|
||||
|
||||
if (mappings.Keys.Contains(Field.BiosDescription))
|
||||
Description = mappings[Field.BiosDescription];
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Constructors
|
||||
|
||||
@@ -285,6 +285,65 @@ namespace SabreTools.Library.DatItems
|
||||
return fieldValue;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Set fields with given values
|
||||
/// </summary>
|
||||
/// <param name="mappings">Mappings dictionary</param>
|
||||
public virtual void SetFields(Dictionary<Field, string> mappings)
|
||||
{
|
||||
// Set machine fields
|
||||
Machine.SetFields(mappings);
|
||||
|
||||
#region Common
|
||||
|
||||
if (mappings.Keys.Contains(Field.Name))
|
||||
Name = mappings[Field.Name];
|
||||
|
||||
#endregion
|
||||
|
||||
#region AttractMode
|
||||
|
||||
if (mappings.Keys.Contains(Field.AltName))
|
||||
AltName = mappings[Field.AltName];
|
||||
|
||||
if (mappings.Keys.Contains(Field.AltTitle))
|
||||
AltTitle = mappings[Field.AltTitle];
|
||||
|
||||
#endregion
|
||||
|
||||
#region SoftwareList
|
||||
|
||||
if (mappings.Keys.Contains(Field.PartName))
|
||||
PartName = mappings[Field.PartName];
|
||||
|
||||
if (mappings.Keys.Contains(Field.PartInterface))
|
||||
PartInterface = mappings[Field.PartInterface];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Features))
|
||||
{
|
||||
if (Features == null)
|
||||
Features = new List<KeyValuePair<string, string>>();
|
||||
|
||||
string[] pairs = mappings[Field.Features].Split(';');
|
||||
foreach (string pair in pairs)
|
||||
{
|
||||
string[] split = pair.Split('=');
|
||||
Features.Add(new KeyValuePair<string, string>(split[0], split[1]));
|
||||
}
|
||||
}
|
||||
|
||||
if (mappings.Keys.Contains(Field.AreaName))
|
||||
AreaName = mappings[Field.AreaName];
|
||||
|
||||
if (mappings.Keys.Contains(Field.AreaSize))
|
||||
{
|
||||
if (Int64.TryParse(mappings[Field.AreaSize], out long areaSize))
|
||||
AreaSize = areaSize;
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Constructors
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
using SabreTools.Library.DatFiles;
|
||||
using SabreTools.Library.FileTypes;
|
||||
@@ -194,6 +195,55 @@ namespace SabreTools.Library.DatItems
|
||||
return fieldValue;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Set fields with given values
|
||||
/// </summary>
|
||||
/// <param name="mappings">Mappings dictionary</param>
|
||||
public override void SetFields(Dictionary<Field, string> mappings)
|
||||
{
|
||||
// Set base fields
|
||||
base.SetFields(mappings);
|
||||
|
||||
// Handle Disk-specific fields
|
||||
if (mappings.Keys.Contains(Field.MD5))
|
||||
MD5 = mappings[Field.MD5];
|
||||
|
||||
#if NET_FRAMEWORK
|
||||
if (mappings.Keys.Contains(Field.RIPEMD160))
|
||||
RIPEMD160 = mappings[Field.RIPEMD160];
|
||||
#endif
|
||||
|
||||
if (mappings.Keys.Contains(Field.SHA1))
|
||||
SHA1 = mappings[Field.SHA1];
|
||||
|
||||
if (mappings.Keys.Contains(Field.SHA256))
|
||||
SHA256 = mappings[Field.SHA256];
|
||||
|
||||
if (mappings.Keys.Contains(Field.SHA384))
|
||||
SHA384 = mappings[Field.SHA384];
|
||||
|
||||
if (mappings.Keys.Contains(Field.SHA512))
|
||||
SHA512 = mappings[Field.SHA512];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Merge))
|
||||
MergeTag = mappings[Field.Merge];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Region))
|
||||
Region = mappings[Field.Region];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Index))
|
||||
Index = mappings[Field.Index];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Writable))
|
||||
Writable = mappings[Field.Writable].AsYesNo();
|
||||
|
||||
if (mappings.Keys.Contains(Field.Status))
|
||||
ItemStatus = mappings[Field.Status].AsItemStatus();
|
||||
|
||||
if (mappings.Keys.Contains(Field.Optional))
|
||||
Optional = mappings[Field.Optional].AsYesNo();
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Constructors
|
||||
|
||||
@@ -4,6 +4,7 @@ using System.Linq;
|
||||
|
||||
using SabreTools.Library.Filtering;
|
||||
using Newtonsoft.Json;
|
||||
using SabreTools.Library.Tools;
|
||||
|
||||
namespace SabreTools.Library.DatItems
|
||||
{
|
||||
@@ -416,6 +417,164 @@ namespace SabreTools.Library.DatItems
|
||||
return fieldValue;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Set fields with given values
|
||||
/// </summary>
|
||||
/// <param name="mappings">Mappings dictionary</param>
|
||||
public void SetFields(Dictionary<Field, string> mappings)
|
||||
{
|
||||
#region Common
|
||||
|
||||
if (mappings.Keys.Contains(Field.MachineName))
|
||||
Name = mappings[Field.MachineName];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Comment))
|
||||
Comment = mappings[Field.Comment];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Description))
|
||||
Description = mappings[Field.Description];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Year))
|
||||
Year = mappings[Field.Year];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Manufacturer))
|
||||
Manufacturer = mappings[Field.Manufacturer];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Publisher))
|
||||
Publisher = mappings[Field.Publisher];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Category))
|
||||
Category = mappings[Field.Category];
|
||||
|
||||
if (mappings.Keys.Contains(Field.RomOf))
|
||||
RomOf = mappings[Field.RomOf];
|
||||
|
||||
if (mappings.Keys.Contains(Field.CloneOf))
|
||||
CloneOf = mappings[Field.CloneOf];
|
||||
|
||||
if (mappings.Keys.Contains(Field.SampleOf))
|
||||
SampleOf = mappings[Field.SampleOf];
|
||||
|
||||
if (mappings.Keys.Contains(Field.MachineType))
|
||||
MachineType = mappings[Field.MachineType].AsMachineType();
|
||||
|
||||
#endregion
|
||||
|
||||
#region AttractMode
|
||||
|
||||
if (mappings.Keys.Contains(Field.Players))
|
||||
Players = mappings[Field.Players];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Rotation))
|
||||
Rotation = mappings[Field.Rotation];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Control))
|
||||
Control = mappings[Field.Control];
|
||||
|
||||
if (mappings.Keys.Contains(Field.SupportStatus))
|
||||
Status = mappings[Field.SupportStatus];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DisplayCount))
|
||||
DisplayCount = mappings[Field.DisplayCount];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DisplayType))
|
||||
DisplayType = mappings[Field.DisplayType];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Buttons))
|
||||
Buttons = mappings[Field.Buttons];
|
||||
|
||||
#endregion
|
||||
|
||||
#region ListXML
|
||||
|
||||
if (mappings.Keys.Contains(Field.SourceFile))
|
||||
SourceFile = mappings[Field.SourceFile];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Runnable))
|
||||
Runnable = mappings[Field.Runnable].AsYesNo();
|
||||
|
||||
if (mappings.Keys.Contains(Field.Devices))
|
||||
{
|
||||
if (Devices == null)
|
||||
Devices = new List<string>();
|
||||
|
||||
string[] devices = mappings[Field.Devices].Split(';');
|
||||
Devices.AddRange(devices);
|
||||
}
|
||||
|
||||
if (mappings.Keys.Contains(Field.SlotOptions))
|
||||
{
|
||||
if (SlotOptions == null)
|
||||
SlotOptions = new List<string>();
|
||||
|
||||
string[] slotOptions = mappings[Field.SlotOptions].Split(';');
|
||||
SlotOptions.AddRange(slotOptions);
|
||||
}
|
||||
|
||||
if (mappings.Keys.Contains(Field.Infos))
|
||||
{
|
||||
if (Infos == null)
|
||||
Infos = new List<KeyValuePair<string, string>>();
|
||||
|
||||
string[] pairs = mappings[Field.Infos].Split(';');
|
||||
foreach (string pair in pairs)
|
||||
{
|
||||
string[] split = pair.Split('=');
|
||||
Infos.Add(new KeyValuePair<string, string>(split[0], split[1]));
|
||||
}
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Logiqx
|
||||
|
||||
if (mappings.Keys.Contains(Field.Board))
|
||||
Board = mappings[Field.Board];
|
||||
|
||||
if (mappings.Keys.Contains(Field.RebuildTo))
|
||||
RebuildTo = mappings[Field.RebuildTo];
|
||||
|
||||
#endregion
|
||||
|
||||
#region Logiqx EmuArc
|
||||
|
||||
if (mappings.Keys.Contains(Field.TitleID))
|
||||
TitleID = mappings[Field.TitleID];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Developer))
|
||||
Developer = mappings[Field.Developer];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Genre))
|
||||
Genre = mappings[Field.Genre];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Subgenre))
|
||||
Subgenre = mappings[Field.Subgenre];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Ratings))
|
||||
Ratings = mappings[Field.Ratings];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Score))
|
||||
Score = mappings[Field.Score];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Enabled))
|
||||
Enabled = mappings[Field.Enabled];
|
||||
|
||||
if (mappings.Keys.Contains(Field.HasCrc))
|
||||
HasCrc = mappings[Field.HasCrc].AsYesNo();
|
||||
|
||||
if (mappings.Keys.Contains(Field.RelatedTo))
|
||||
RelatedTo = mappings[Field.RelatedTo];
|
||||
|
||||
#endregion
|
||||
|
||||
#region SoftwareList
|
||||
|
||||
if (mappings.Keys.Contains(Field.Supported))
|
||||
Supported = mappings[Field.Supported].AsYesNo();
|
||||
|
||||
#endregion
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Constructors
|
||||
|
||||
@@ -1,7 +1,9 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
using SabreTools.Library.Filtering;
|
||||
using Newtonsoft.Json;
|
||||
using SabreTools.Library.Tools;
|
||||
|
||||
namespace SabreTools.Library.DatItems
|
||||
{
|
||||
@@ -78,6 +80,29 @@ namespace SabreTools.Library.DatItems
|
||||
return fieldValue;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Set fields with given values
|
||||
/// </summary>
|
||||
/// <param name="mappings">Mappings dictionary</param>
|
||||
public override void SetFields(Dictionary<Field, string> mappings)
|
||||
{
|
||||
// Set base fields
|
||||
base.SetFields(mappings);
|
||||
|
||||
// Handle Release-specific fields
|
||||
if (mappings.Keys.Contains(Field.Region))
|
||||
Region = mappings[Field.Region];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Language))
|
||||
Language = mappings[Field.Language];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Date))
|
||||
Date = mappings[Field.Date];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Default))
|
||||
Default = mappings[Field.Default].AsYesNo();
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Constructors
|
||||
|
||||
@@ -1,4 +1,6 @@
|
||||
using System.Collections.Generic;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
|
||||
using SabreTools.Library.Data;
|
||||
using SabreTools.Library.DatFiles;
|
||||
@@ -236,6 +238,70 @@ namespace SabreTools.Library.DatItems
|
||||
return fieldValue;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Set fields with given values
|
||||
/// </summary>
|
||||
/// <param name="mappings">Mappings dictionary</param>
|
||||
public override void SetFields(Dictionary<Field, string> mappings)
|
||||
{
|
||||
// Set base fields
|
||||
base.SetFields(mappings);
|
||||
|
||||
// Handle Rom-specific fields
|
||||
if (mappings.Keys.Contains(Field.Bios))
|
||||
Bios = mappings[Field.Bios];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Size))
|
||||
{
|
||||
if (Int64.TryParse(mappings[Field.Size], out long size))
|
||||
Size = size;
|
||||
}
|
||||
|
||||
if (mappings.Keys.Contains(Field.CRC))
|
||||
CRC = mappings[Field.CRC];
|
||||
|
||||
if (mappings.Keys.Contains(Field.MD5))
|
||||
MD5 = mappings[Field.MD5];
|
||||
|
||||
#if NET_FRAMEWORK
|
||||
if (mappings.Keys.Contains(Field.RIPEMD160))
|
||||
RIPEMD160 = mappings[Field.RIPEMD160];
|
||||
#endif
|
||||
|
||||
if (mappings.Keys.Contains(Field.SHA1))
|
||||
SHA1 = mappings[Field.SHA1];
|
||||
|
||||
if (mappings.Keys.Contains(Field.SHA256))
|
||||
SHA256 = mappings[Field.SHA256];
|
||||
|
||||
if (mappings.Keys.Contains(Field.SHA384))
|
||||
SHA384 = mappings[Field.SHA384];
|
||||
|
||||
if (mappings.Keys.Contains(Field.SHA512))
|
||||
SHA512 = mappings[Field.SHA512];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Merge))
|
||||
MergeTag = mappings[Field.Merge];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Region))
|
||||
Region = mappings[Field.Region];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Offset))
|
||||
Offset = mappings[Field.Offset];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Date))
|
||||
Date = mappings[Field.Date];
|
||||
|
||||
if (mappings.Keys.Contains(Field.Status))
|
||||
ItemStatus = mappings[Field.Status].AsItemStatus();
|
||||
|
||||
if (mappings.Keys.Contains(Field.Optional))
|
||||
Optional = mappings[Field.Optional].AsYesNo();
|
||||
|
||||
if (mappings.Keys.Contains(Field.Inverted))
|
||||
Inverted = mappings[Field.Optional].AsYesNo();
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Constructors
|
||||
|
||||
Reference in New Issue
Block a user