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 SabreTools.Library.Filtering;
|
||||||
using Newtonsoft.Json;
|
using Newtonsoft.Json;
|
||||||
|
using System.Linq;
|
||||||
|
using SabreTools.Library.Tools;
|
||||||
|
|
||||||
namespace SabreTools.Library.DatItems
|
namespace SabreTools.Library.DatItems
|
||||||
{
|
{
|
||||||
@@ -60,6 +62,23 @@ namespace SabreTools.Library.DatItems
|
|||||||
return fieldValue;
|
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
|
#endregion
|
||||||
|
|
||||||
#region Constructors
|
#region Constructors
|
||||||
|
|||||||
@@ -285,6 +285,65 @@ namespace SabreTools.Library.DatItems
|
|||||||
return fieldValue;
|
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
|
#endregion
|
||||||
|
|
||||||
#region Constructors
|
#region Constructors
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
using SabreTools.Library.DatFiles;
|
using SabreTools.Library.DatFiles;
|
||||||
using SabreTools.Library.FileTypes;
|
using SabreTools.Library.FileTypes;
|
||||||
@@ -194,6 +195,55 @@ namespace SabreTools.Library.DatItems
|
|||||||
return fieldValue;
|
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
|
#endregion
|
||||||
|
|
||||||
#region Constructors
|
#region Constructors
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ using System.Linq;
|
|||||||
|
|
||||||
using SabreTools.Library.Filtering;
|
using SabreTools.Library.Filtering;
|
||||||
using Newtonsoft.Json;
|
using Newtonsoft.Json;
|
||||||
|
using SabreTools.Library.Tools;
|
||||||
|
|
||||||
namespace SabreTools.Library.DatItems
|
namespace SabreTools.Library.DatItems
|
||||||
{
|
{
|
||||||
@@ -416,6 +417,164 @@ namespace SabreTools.Library.DatItems
|
|||||||
return fieldValue;
|
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
|
#endregion
|
||||||
|
|
||||||
#region Constructors
|
#region Constructors
|
||||||
|
|||||||
@@ -1,7 +1,9 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
|
||||||
using SabreTools.Library.Filtering;
|
using SabreTools.Library.Filtering;
|
||||||
using Newtonsoft.Json;
|
using Newtonsoft.Json;
|
||||||
|
using SabreTools.Library.Tools;
|
||||||
|
|
||||||
namespace SabreTools.Library.DatItems
|
namespace SabreTools.Library.DatItems
|
||||||
{
|
{
|
||||||
@@ -78,6 +80,29 @@ namespace SabreTools.Library.DatItems
|
|||||||
return fieldValue;
|
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
|
#endregion
|
||||||
|
|
||||||
#region Constructors
|
#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.Data;
|
||||||
using SabreTools.Library.DatFiles;
|
using SabreTools.Library.DatFiles;
|
||||||
@@ -236,6 +238,70 @@ namespace SabreTools.Library.DatItems
|
|||||||
return fieldValue;
|
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
|
#endregion
|
||||||
|
|
||||||
#region Constructors
|
#region Constructors
|
||||||
|
|||||||
Reference in New Issue
Block a user