mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Make setter make more sense
This commit is contained in:
@@ -60,46 +60,21 @@ namespace SabreTools.DatFiles.Formats
|
|||||||
svr.ReadNextLine();
|
svr.ReadNextLine();
|
||||||
|
|
||||||
// Create mapping dictionaries
|
// Create mapping dictionaries
|
||||||
var datHeaderMappings = new Dictionary<DatHeaderField, string>();
|
Setter setter = new Setter();
|
||||||
var machineMappings = new Dictionary<MachineField, string>();
|
setter.PopulateSettersFromList(svr.HeaderValues, svr.Line);
|
||||||
var datItemMappings = new Dictionary<DatItemField, string>();
|
|
||||||
|
|
||||||
// Now we loop through and get values for everything
|
|
||||||
for (int i = 0; i < svr.HeaderValues.Count; i++)
|
|
||||||
{
|
|
||||||
string value = svr.Line[i];
|
|
||||||
DatHeaderField dhf = svr.HeaderValues[i].AsDatHeaderField();
|
|
||||||
if (dhf != DatHeaderField.NULL)
|
|
||||||
{
|
|
||||||
datHeaderMappings[dhf] = value;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
MachineField mf = svr.HeaderValues[i].AsMachineField();
|
|
||||||
if (mf != MachineField.NULL)
|
|
||||||
{
|
|
||||||
machineMappings[mf] = value;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
DatItemField dif = svr.HeaderValues[i].AsDatItemField();
|
|
||||||
if (dif != DatItemField.NULL)
|
|
||||||
{
|
|
||||||
datItemMappings[dif] = value;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set DatHeader fields
|
// Set DatHeader fields
|
||||||
DatHeader header = new DatHeader();
|
DatHeader datHeader = new DatHeader();
|
||||||
header.SetFields(datHeaderMappings);
|
setter.SetFields(datHeader);
|
||||||
Header.ConditionalCopy(header);
|
Header.ConditionalCopy(datHeader);
|
||||||
|
|
||||||
// Set Machine and DatItem fields
|
// Set Machine and DatItem fields
|
||||||
if (datItemMappings.ContainsKey(DatItemField.Type))
|
if (setter.DatItemMappings.ContainsKey(DatItemField.Type))
|
||||||
{
|
{
|
||||||
DatItem datItem = DatItem.Create(datItemMappings[DatItemField.Type].AsItemType());
|
DatItem datItem = DatItem.Create(setter.DatItemMappings[DatItemField.Type].AsItemType());
|
||||||
Setter.SetFields(datItem, datItemMappings, machineMappings);
|
setter.SetFields(datItem);
|
||||||
|
datItem.Machine = new Machine();
|
||||||
|
setter.SetFields(datItem.Machine);
|
||||||
datItem.Source = new Source(indexId, filename);
|
datItem.Source = new Source(indexId, filename);
|
||||||
ParseAddHelper(datItem, statsOnly);
|
ParseAddHelper(datItem, statsOnly);
|
||||||
}
|
}
|
||||||
|
|||||||
1220
SabreTools.DatFiles/Setter.cs
Normal file
1220
SabreTools.DatFiles/Setter.cs
Normal file
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@@ -129,11 +129,11 @@ namespace SabreTools.Filtering
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
List<DatItem> datItems = datFile.Items[key];
|
List<DatItem> datItems = datFile.Items[key];
|
||||||
var mappings = machineMap[key];
|
Setter setter = new Setter { MachineMappings = machineMap[key] };
|
||||||
|
|
||||||
foreach (var datItem in datItems)
|
foreach (var datItem in datItems)
|
||||||
{
|
{
|
||||||
Setter.SetFields(datItem.Machine, mappings);
|
setter.SetFields(datItem.Machine);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -145,11 +145,11 @@ namespace SabreTools.Filtering
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
List<DatItem> datItems = datFile.Items[key];
|
List<DatItem> datItems = datFile.Items[key];
|
||||||
var mappings = datItemMap[key];
|
Setter setter = new Setter { DatItemMappings = datItemMap[key] };
|
||||||
|
|
||||||
foreach (var datItem in datItems)
|
foreach (var datItem in datItems)
|
||||||
{
|
{
|
||||||
Setter.SetFields(datItem, mappings, null);
|
setter.SetFields(datItem);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,10 +1,11 @@
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
|
||||||
using SabreTools.Core;
|
using SabreTools.Core;
|
||||||
|
using SabreTools.DatFiles;
|
||||||
using SabreTools.DatItems;
|
using SabreTools.DatItems;
|
||||||
using Xunit;
|
using Xunit;
|
||||||
|
|
||||||
namespace SabreTools.Test.DatItems
|
namespace SabreTools.Test.DatFiles
|
||||||
{
|
{
|
||||||
public class SetterTests
|
public class SetterTests
|
||||||
{
|
{
|
||||||
@@ -12,8 +13,11 @@ namespace SabreTools.Test.DatItems
|
|||||||
public void SetFieldsDatItemTest()
|
public void SetFieldsDatItemTest()
|
||||||
{
|
{
|
||||||
var datItem = CreateDatItem();
|
var datItem = CreateDatItem();
|
||||||
var mappings = new Dictionary<DatItemField, string> { [DatItemField.Name] = "bar" };
|
Setter setter = new Setter
|
||||||
Setter.SetFields(datItem, mappings, null);
|
{
|
||||||
|
DatItemMappings = new Dictionary<DatItemField, string> { [DatItemField.Name] = "bar" }
|
||||||
|
};
|
||||||
|
setter.SetFields(datItem);
|
||||||
Assert.Equal("bar", datItem.GetName());
|
Assert.Equal("bar", datItem.GetName());
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -21,8 +25,11 @@ namespace SabreTools.Test.DatItems
|
|||||||
public void SetFieldsMachineTest()
|
public void SetFieldsMachineTest()
|
||||||
{
|
{
|
||||||
var datItem = CreateDatItem();
|
var datItem = CreateDatItem();
|
||||||
var mappings = new Dictionary<MachineField, string> { [MachineField.Name] = "foo" };
|
Setter setter = new Setter
|
||||||
Setter.SetFields(datItem, null, mappings);
|
{
|
||||||
|
MachineMappings = new Dictionary<MachineField, string> { [MachineField.Name] = "foo" }
|
||||||
|
};
|
||||||
|
setter.SetFields(datItem.Machine);
|
||||||
Assert.Equal("foo", datItem.Machine.Name);
|
Assert.Equal("foo", datItem.Machine.Name);
|
||||||
}
|
}
|
||||||
|
|
||||||
Reference in New Issue
Block a user