DatItems don't know about filtering

This commit is contained in:
Matt Nadareski
2020-12-13 21:47:42 -08:00
parent 67bfe0dae9
commit 3fcec263e0
40 changed files with 1325 additions and 1458 deletions

View File

@@ -4,7 +4,6 @@ using System.Xml.Serialization;
using SabreTools.Core;
using SabreTools.Core.Tools;
using SabreTools.Filtering;
using Newtonsoft.Json;
using Newtonsoft.Json.Converters;
@@ -210,58 +209,6 @@ namespace SabreTools.DatItems
#region Filtering
/// <inheritdoc/>
public override bool PassesFilter(Cleaner cleaner, bool sub = false)
{
// Check common fields first
if (!base.PassesFilter(cleaner, sub))
return false;
// Filter on device type
if (cleaner.DatItemFilter.DeviceType.MatchesPositive(DeviceType.NULL, DeviceType) == false)
return false;
if (cleaner.DatItemFilter.DeviceType.MatchesNegative(DeviceType.NULL, DeviceType) == true)
return false;
// Filter on tag
if (!Filter.PassStringFilter(cleaner.DatItemFilter.Tag, Tag))
return false;
// Filter on fixed image
if (!Filter.PassStringFilter(cleaner.DatItemFilter.FixedImage, FixedImage))
return false;
// Filter on mandatory
if (!Filter.PassLongFilter(cleaner.DatItemFilter.Mandatory, Mandatory))
return false;
// Filter on interface
if (!Filter.PassStringFilter(cleaner.DatItemFilter.Interface, Interface))
return false;
// Filter on individual instances
if (InstancesSpecified)
{
foreach (Instance instance in Instances)
{
if (!instance.PassesFilter(cleaner, true))
return false;
}
}
// Filter on individual extensions
if (ExtensionsSpecified)
{
foreach (Extension extension in Extensions)
{
if (!extension.PassesFilter(cleaner, true))
return false;
}
}
return true;
}
/// <inheritdoc/>
public override void RemoveFields(
List<DatItemField> datItemFields,