mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Promote Display
This commit is contained in:
@@ -143,6 +143,12 @@ namespace SabreTools.Library.DatFiles
|
||||
[JsonIgnore]
|
||||
public long DiskCount { get; private set; } = 0;
|
||||
|
||||
/// <summary>
|
||||
/// Number of Display items
|
||||
/// </summary>
|
||||
[JsonIgnore]
|
||||
public long DisplayCount { get; private set; } = 0;
|
||||
|
||||
/// <summary>
|
||||
/// Number of Driver items
|
||||
/// </summary>
|
||||
@@ -578,6 +584,9 @@ namespace SabreTools.Library.DatFiles
|
||||
NodumpCount += ((item as Disk).ItemStatus == ItemStatus.Nodump ? 1 : 0);
|
||||
VerifiedCount += ((item as Disk).ItemStatus == ItemStatus.Verified ? 1 : 0);
|
||||
break;
|
||||
case ItemType.Display:
|
||||
DisplayCount++;
|
||||
break;
|
||||
case ItemType.Driver:
|
||||
DriverCount++;
|
||||
break;
|
||||
@@ -749,6 +758,9 @@ namespace SabreTools.Library.DatFiles
|
||||
NodumpCount -= ((item as Disk).ItemStatus == ItemStatus.Nodump ? 1 : 0);
|
||||
VerifiedCount -= ((item as Disk).ItemStatus == ItemStatus.Verified ? 1 : 0);
|
||||
break;
|
||||
case ItemType.Display:
|
||||
DisplayCount--;
|
||||
break;
|
||||
case ItemType.Driver:
|
||||
DriverCount--;
|
||||
break;
|
||||
|
||||
@@ -244,6 +244,9 @@ namespace SabreTools.Library.DatFiles
|
||||
case ItemType.Disk:
|
||||
datItem = datItemObj.ToObject<Disk>();
|
||||
break;
|
||||
case ItemType.Display:
|
||||
datItem = datItemObj.ToObject<Display>();
|
||||
break;
|
||||
case ItemType.Driver:
|
||||
datItem = datItemObj.ToObject<Driver>();
|
||||
break;
|
||||
|
||||
@@ -356,6 +356,34 @@ namespace SabreTools.Library.DatFiles
|
||||
reader.Read();
|
||||
break;
|
||||
|
||||
case "display":
|
||||
datItems.Add(new Display
|
||||
{
|
||||
Tag = reader.GetAttribute("tag"),
|
||||
DisplayType = reader.GetAttribute("type"),
|
||||
Rotate = reader.GetAttribute("rotate"),
|
||||
FlipX = reader.GetAttribute("flipx").AsYesNo(),
|
||||
Width = reader.GetAttribute("width"),
|
||||
Height = reader.GetAttribute("height"),
|
||||
Refresh = reader.GetAttribute("refresh"),
|
||||
PixClock = reader.GetAttribute("pixclock"),
|
||||
HTotal = reader.GetAttribute("htotal"),
|
||||
HBEnd = reader.GetAttribute("hbend"),
|
||||
HBStart = reader.GetAttribute("hbstart"),
|
||||
VTotal = reader.GetAttribute("vtotal"),
|
||||
VBEnd = reader.GetAttribute("vbend"),
|
||||
VBStart = reader.GetAttribute("vbstart"),
|
||||
|
||||
Source = new Source
|
||||
{
|
||||
Index = indexId,
|
||||
Name = filename,
|
||||
},
|
||||
});
|
||||
|
||||
reader.Read();
|
||||
break;
|
||||
|
||||
case "driver":
|
||||
datItems.Add(new Driver
|
||||
{
|
||||
@@ -521,32 +549,6 @@ namespace SabreTools.Library.DatFiles
|
||||
reader.Read();
|
||||
break;
|
||||
|
||||
case "display":
|
||||
var display = new Display();
|
||||
display.Tag = reader.GetAttribute("tag");
|
||||
display.Type = reader.GetAttribute("type");
|
||||
display.Rotate = reader.GetAttribute("rotate");
|
||||
display.FlipX = reader.GetAttribute("flipx").AsYesNo();
|
||||
display.Width = reader.GetAttribute("width");
|
||||
display.Height = reader.GetAttribute("height");
|
||||
display.Refresh = reader.GetAttribute("refresh");
|
||||
display.PixClock = reader.GetAttribute("pixclock");
|
||||
display.HTotal = reader.GetAttribute("htotal");
|
||||
display.HBEnd = reader.GetAttribute("hbend");
|
||||
display.HBStart = reader.GetAttribute("hbstart");
|
||||
display.VTotal = reader.GetAttribute("vtotal");
|
||||
display.VBEnd = reader.GetAttribute("vbend");
|
||||
display.VBStart = reader.GetAttribute("vbstart");
|
||||
|
||||
// Ensure the list exists
|
||||
if (machine.Displays == null)
|
||||
machine.Displays = new List<Display>();
|
||||
|
||||
machine.Displays.Add(display);
|
||||
|
||||
reader.Read();
|
||||
break;
|
||||
|
||||
case "input":
|
||||
var input = new Input();
|
||||
input.Service = reader.GetAttribute("service").AsYesNo();
|
||||
@@ -1253,28 +1255,6 @@ namespace SabreTools.Library.DatFiles
|
||||
xtw.WriteOptionalElementString("manufacturer", datItem.Machine.Manufacturer);
|
||||
|
||||
// TODO: These are all going away due to promotions
|
||||
if (datItem.Machine.Displays != null)
|
||||
{
|
||||
foreach (var display in datItem.Machine.Displays)
|
||||
{
|
||||
xtw.WriteStartElement("display");
|
||||
xtw.WriteOptionalAttributeString("tag", display.Tag);
|
||||
xtw.WriteOptionalAttributeString("type", display.Type);
|
||||
xtw.WriteOptionalAttributeString("rotate", display.Rotate);
|
||||
xtw.WriteOptionalAttributeString("flipx", display.FlipX.FromYesNo());
|
||||
xtw.WriteOptionalAttributeString("width", display.Width);
|
||||
xtw.WriteOptionalAttributeString("height", display.Height);
|
||||
xtw.WriteOptionalAttributeString("refresh", display.Refresh);
|
||||
xtw.WriteOptionalAttributeString("pixclock", display.PixClock);
|
||||
xtw.WriteOptionalAttributeString("htotal", display.HTotal);
|
||||
xtw.WriteOptionalAttributeString("hbend", display.HBEnd);
|
||||
xtw.WriteOptionalAttributeString("hstart", display.HBStart);
|
||||
xtw.WriteOptionalAttributeString("vtotal", display.VTotal);
|
||||
xtw.WriteOptionalAttributeString("vbend", display.VBEnd);
|
||||
xtw.WriteOptionalAttributeString("vbstart", display.VBStart);
|
||||
xtw.WriteEndElement();
|
||||
}
|
||||
}
|
||||
if (datItem.Machine.Inputs != null)
|
||||
{
|
||||
foreach (var input in datItem.Machine.Inputs)
|
||||
@@ -1557,6 +1537,26 @@ namespace SabreTools.Library.DatFiles
|
||||
xtw.WriteEndElement();
|
||||
break;
|
||||
|
||||
case ItemType.Display:
|
||||
var display = datItem as Display;
|
||||
xtw.WriteStartElement("display");
|
||||
xtw.WriteOptionalAttributeString("tag", display.Tag);
|
||||
xtw.WriteOptionalAttributeString("type", display.DisplayType);
|
||||
xtw.WriteOptionalAttributeString("rotate", display.Rotate);
|
||||
xtw.WriteOptionalAttributeString("flipx", display.FlipX.FromYesNo());
|
||||
xtw.WriteOptionalAttributeString("width", display.Width);
|
||||
xtw.WriteOptionalAttributeString("height", display.Height);
|
||||
xtw.WriteOptionalAttributeString("refresh", display.Refresh);
|
||||
xtw.WriteOptionalAttributeString("pixclock", display.PixClock);
|
||||
xtw.WriteOptionalAttributeString("htotal", display.HTotal);
|
||||
xtw.WriteOptionalAttributeString("hbend", display.HBEnd);
|
||||
xtw.WriteOptionalAttributeString("hstart", display.HBStart);
|
||||
xtw.WriteOptionalAttributeString("vtotal", display.VTotal);
|
||||
xtw.WriteOptionalAttributeString("vbend", display.VBEnd);
|
||||
xtw.WriteOptionalAttributeString("vbstart", display.VBStart);
|
||||
xtw.WriteEndElement();
|
||||
break;
|
||||
|
||||
case ItemType.Driver:
|
||||
var driver = datItem as Driver;
|
||||
xtw.WriteStartElement("driver");
|
||||
|
||||
@@ -1431,6 +1431,27 @@ namespace SabreTools.Library.DatFiles
|
||||
xtw.WriteEndElement();
|
||||
break;
|
||||
|
||||
case ItemType.Display:
|
||||
var display = datItem as Display;
|
||||
xtw.WriteStartElement("file");
|
||||
xtw.WriteAttributeString("type", "display");
|
||||
xtw.WriteOptionalAttributeString("tag", display.Tag);
|
||||
xtw.WriteOptionalAttributeString("type", display.DisplayType);
|
||||
xtw.WriteOptionalAttributeString("rotate", display.Rotate);
|
||||
xtw.WriteOptionalAttributeString("flipx", display.FlipX.FromYesNo());
|
||||
xtw.WriteOptionalAttributeString("width", display.Width);
|
||||
xtw.WriteOptionalAttributeString("height", display.Height);
|
||||
xtw.WriteOptionalAttributeString("refresh", display.Refresh);
|
||||
xtw.WriteOptionalAttributeString("pixclock", display.PixClock);
|
||||
xtw.WriteOptionalAttributeString("htotal", display.HTotal);
|
||||
xtw.WriteOptionalAttributeString("hbend", display.HBEnd);
|
||||
xtw.WriteOptionalAttributeString("hstart", display.HBStart);
|
||||
xtw.WriteOptionalAttributeString("vtotal", display.VTotal);
|
||||
xtw.WriteOptionalAttributeString("vbend", display.VBEnd);
|
||||
xtw.WriteOptionalAttributeString("vbstart", display.VBStart);
|
||||
xtw.WriteEndElement();
|
||||
break;
|
||||
|
||||
case ItemType.Driver:
|
||||
var driver = datItem as Driver;
|
||||
xtw.WriteStartElement("file");
|
||||
|
||||
@@ -5,6 +5,7 @@ using SabreTools.Library.DatItems;
|
||||
using SabreTools.Library.Filtering;
|
||||
using Newtonsoft.Json;
|
||||
using Newtonsoft.Json.Converters;
|
||||
using SabreTools.Library.Tools;
|
||||
|
||||
/// <summary>
|
||||
/// This holds all of the auxiliary types needed for proper parsing
|
||||
@@ -98,102 +99,6 @@ namespace SabreTools.Library.DatItems
|
||||
#endregion
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Represents one ListXML display
|
||||
/// </summary>
|
||||
/// TODO: Promote to DatItem level
|
||||
[JsonObject("display")]
|
||||
public class Display
|
||||
{
|
||||
#region Fields
|
||||
|
||||
/// <summary>
|
||||
/// Display tag
|
||||
/// </summary>
|
||||
[JsonProperty("tag", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Tag { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Display type
|
||||
/// </summary>
|
||||
[JsonProperty("type", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Type { get; set; } // TODO: (raster|vector|lcd|svg|unknown)
|
||||
|
||||
/// <summary>
|
||||
/// Display rotation
|
||||
/// </summary>
|
||||
[JsonProperty("rotate", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Rotate { get; set; } // TODO: (0|90|180|270) Int32?
|
||||
|
||||
/// <summary>
|
||||
/// Determines if display is flipped in the X-coordinates
|
||||
/// </summary>
|
||||
[JsonProperty("flipx", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public bool? FlipX { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Display width
|
||||
/// </summary>
|
||||
[JsonProperty("width", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Width { get; set; } // TODO: Int32?
|
||||
|
||||
/// <summary>
|
||||
/// Display height
|
||||
/// </summary>
|
||||
[JsonProperty("height", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Height { get; set; } // TODO: Int32?
|
||||
|
||||
/// <summary>
|
||||
/// Refresh rate
|
||||
/// </summary>
|
||||
[JsonProperty("refresh", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Refresh { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Pixel clock timer
|
||||
/// </summary>
|
||||
[JsonProperty("pixclock", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string PixClock { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Total horizontal lines
|
||||
/// </summary>
|
||||
[JsonProperty("htotal", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string HTotal { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Horizontal blank end
|
||||
/// </summary>
|
||||
[JsonProperty("hbend", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string HBEnd { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Horizontal blank start
|
||||
/// </summary>
|
||||
[JsonProperty("hbstart", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string HBStart { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Total vertical lines
|
||||
/// </summary>
|
||||
[JsonProperty("vtotal", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string VTotal { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Vertical blank end
|
||||
/// </summary>
|
||||
[JsonProperty("vbend", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string VBEnd { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Vertical blank start
|
||||
/// </summary>
|
||||
[JsonProperty("vbstart", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string VBStart { get; set; } // TODO: Int32? Float?
|
||||
|
||||
#endregion
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Represents one ListXML input
|
||||
/// </summary>
|
||||
|
||||
@@ -491,6 +491,9 @@ namespace SabreTools.Library.DatItems
|
||||
case ItemType.Disk:
|
||||
return new Disk();
|
||||
|
||||
case ItemType.Display:
|
||||
return new Display();
|
||||
|
||||
case ItemType.Driver:
|
||||
return new Driver();
|
||||
|
||||
@@ -548,6 +551,7 @@ namespace SabreTools.Library.DatItems
|
||||
ItemType.DeviceReference => new DeviceReference(),
|
||||
ItemType.DipSwitch => new DipSwitch(),
|
||||
ItemType.Disk => new Disk(),
|
||||
ItemType.Display => new Display(),
|
||||
ItemType.Driver => new Driver(),
|
||||
ItemType.Extension => new Extension(),
|
||||
ItemType.Feature => new Feature(),
|
||||
|
||||
473
SabreTools.Library/DatItems/Display.cs
Normal file
473
SabreTools.Library/DatItems/Display.cs
Normal file
@@ -0,0 +1,473 @@
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using SabreTools.Library.Filtering;
|
||||
using Newtonsoft.Json;
|
||||
using SabreTools.Library.Tools;
|
||||
|
||||
/// <summary>
|
||||
/// This holds all of the auxiliary types needed for proper parsing
|
||||
/// </summary>
|
||||
namespace SabreTools.Library.DatItems
|
||||
{
|
||||
/// <summary>
|
||||
/// Represents one machine display
|
||||
/// </summary>
|
||||
[JsonObject("display")]
|
||||
public class Display : DatItem
|
||||
{
|
||||
#region Fields
|
||||
|
||||
/// <summary>
|
||||
/// Display tag
|
||||
/// </summary>
|
||||
[JsonProperty("tag", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Tag { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Display type
|
||||
/// </summary>
|
||||
[JsonProperty("type", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string DisplayType { get; set; } // TODO: (raster|vector|lcd|svg|unknown)
|
||||
|
||||
/// <summary>
|
||||
/// Display rotation
|
||||
/// </summary>
|
||||
[JsonProperty("rotate", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Rotate { get; set; } // TODO: (0|90|180|270) Int32?
|
||||
|
||||
/// <summary>
|
||||
/// Determines if display is flipped in the X-coordinates
|
||||
/// </summary>
|
||||
[JsonProperty("flipx", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public bool? FlipX { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Display width
|
||||
/// </summary>
|
||||
[JsonProperty("width", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Width { get; set; } // TODO: Int32?
|
||||
|
||||
/// <summary>
|
||||
/// Display height
|
||||
/// </summary>
|
||||
[JsonProperty("height", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Height { get; set; } // TODO: Int32?
|
||||
|
||||
/// <summary>
|
||||
/// Refresh rate
|
||||
/// </summary>
|
||||
[JsonProperty("refresh", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string Refresh { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Pixel clock timer
|
||||
/// </summary>
|
||||
[JsonProperty("pixclock", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string PixClock { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Total horizontal lines
|
||||
/// </summary>
|
||||
[JsonProperty("htotal", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string HTotal { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Horizontal blank end
|
||||
/// </summary>
|
||||
[JsonProperty("hbend", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string HBEnd { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Horizontal blank start
|
||||
/// </summary>
|
||||
[JsonProperty("hbstart", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string HBStart { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Total vertical lines
|
||||
/// </summary>
|
||||
[JsonProperty("vtotal", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string VTotal { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Vertical blank end
|
||||
/// </summary>
|
||||
[JsonProperty("vbend", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string VBEnd { get; set; } // TODO: Int32? Float?
|
||||
|
||||
/// <summary>
|
||||
/// Vertical blank start
|
||||
/// </summary>
|
||||
[JsonProperty("vbstart", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public string VBStart { get; set; } // TODO: Int32? Float?
|
||||
|
||||
#endregion
|
||||
|
||||
#region Accessors
|
||||
|
||||
/// <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 Display-specific fields
|
||||
if (mappings.Keys.Contains(Field.DatItem_Tag))
|
||||
Tag = mappings[Field.DatItem_Tag];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_DisplayType))
|
||||
DisplayType = mappings[Field.DatItem_DisplayType];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_Rotate))
|
||||
Rotate = mappings[Field.DatItem_Rotate];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_FlipX))
|
||||
FlipX = mappings[Field.DatItem_FlipX].AsYesNo();
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_Width))
|
||||
Width = mappings[Field.DatItem_Width];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_Height))
|
||||
Height = mappings[Field.DatItem_Height];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_Refresh))
|
||||
Refresh = mappings[Field.DatItem_Refresh];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_PixClock))
|
||||
PixClock = mappings[Field.DatItem_PixClock];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_HTotal))
|
||||
HTotal = mappings[Field.DatItem_HTotal];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_HBEnd))
|
||||
HBEnd = mappings[Field.DatItem_HBEnd];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_HBStart))
|
||||
HBStart = mappings[Field.DatItem_HBStart];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_VTotal))
|
||||
VTotal = mappings[Field.DatItem_VTotal];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_VBEnd))
|
||||
VBEnd = mappings[Field.DatItem_VBEnd];
|
||||
|
||||
if (mappings.Keys.Contains(Field.DatItem_VBStart))
|
||||
VBStart = mappings[Field.DatItem_VBStart];
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Constructors
|
||||
|
||||
/// <summary>
|
||||
/// Create a default, empty Display object
|
||||
/// </summary>
|
||||
public Display()
|
||||
{
|
||||
ItemType = ItemType.Display;
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Cloning Methods
|
||||
|
||||
public override object Clone()
|
||||
{
|
||||
return new Display()
|
||||
{
|
||||
ItemType = this.ItemType,
|
||||
DupeType = this.DupeType,
|
||||
|
||||
AltName = this.AltName,
|
||||
AltTitle = this.AltTitle,
|
||||
|
||||
Original = this.Original,
|
||||
OpenMSXSubType = this.OpenMSXSubType,
|
||||
OpenMSXType = this.OpenMSXType,
|
||||
Remark = this.Remark,
|
||||
Boot = this.Boot,
|
||||
|
||||
Part = this.Part,
|
||||
Features = this.Features,
|
||||
AreaName = this.AreaName,
|
||||
AreaSize = this.AreaSize,
|
||||
AreaWidth = this.AreaWidth,
|
||||
AreaEndianness = this.AreaEndianness,
|
||||
Value = this.Value,
|
||||
LoadFlag = this.LoadFlag,
|
||||
|
||||
Machine = this.Machine.Clone() as Machine,
|
||||
Source = this.Source.Clone() as Source,
|
||||
Remove = this.Remove,
|
||||
|
||||
Tag = this.Tag,
|
||||
DisplayType = this.DisplayType,
|
||||
Rotate = this.Rotate,
|
||||
FlipX = this.FlipX,
|
||||
Width = this.Width,
|
||||
Height = this.Height,
|
||||
Refresh = this.Refresh,
|
||||
PixClock = this.PixClock,
|
||||
HTotal = this.HTotal,
|
||||
HBEnd = this.HBEnd,
|
||||
HBStart = this.HBStart,
|
||||
VTotal = this.VTotal,
|
||||
VBEnd = this.VBEnd,
|
||||
VBStart = this.VBStart,
|
||||
};
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Comparision Methods
|
||||
|
||||
public override bool Equals(DatItem other)
|
||||
{
|
||||
// If we don't have a Display, return false
|
||||
if (ItemType != other.ItemType)
|
||||
return false;
|
||||
|
||||
// Otherwise, treat it as a Display
|
||||
Display newOther = other as Display;
|
||||
|
||||
// If the Display information matches
|
||||
return (Tag == newOther.Tag
|
||||
&& DisplayType == newOther.DisplayType
|
||||
&& Rotate == newOther.Rotate
|
||||
&& FlipX == newOther.FlipX
|
||||
&& Width == newOther.Width
|
||||
&& Height == newOther.Height
|
||||
&& Refresh == newOther.Refresh
|
||||
&& PixClock == newOther.PixClock
|
||||
&& HTotal == newOther.HTotal
|
||||
&& HBEnd == newOther.HBEnd
|
||||
&& HBStart == newOther.HBStart
|
||||
&& VTotal == newOther.VTotal
|
||||
&& VBEnd == newOther.VBEnd
|
||||
&& VBStart == newOther.VBStart);
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Filtering
|
||||
|
||||
/// <summary>
|
||||
/// Check to see if a DatItem passes the filter
|
||||
/// </summary>
|
||||
/// <param name="filter">Filter to check against</param>
|
||||
/// <returns>True if the item passed the filter, false otherwise</returns>
|
||||
public override bool PassesFilter(Filter filter)
|
||||
{
|
||||
// Check common fields first
|
||||
if (!base.PassesFilter(filter))
|
||||
return false;
|
||||
|
||||
// Filter on tag
|
||||
if (filter.DatItem_Tag.MatchesPositiveSet(Tag) == false)
|
||||
return false;
|
||||
if (filter.DatItem_Tag.MatchesNegativeSet(Tag) == true)
|
||||
return false;
|
||||
|
||||
// Filter on display type
|
||||
if (filter.DatItem_DisplayType.MatchesPositiveSet(DisplayType) == false)
|
||||
return false;
|
||||
if (filter.DatItem_DisplayType.MatchesNegativeSet(DisplayType) == true)
|
||||
return false;
|
||||
|
||||
// Filter on rotation
|
||||
if (filter.DatItem_Rotate.MatchesPositiveSet(Rotate) == false)
|
||||
return false;
|
||||
if (filter.DatItem_Rotate.MatchesNegativeSet(Rotate) == true)
|
||||
return false;
|
||||
|
||||
// Filter on flipx
|
||||
if (filter.DatItem_FlipX.MatchesNeutral(null, FlipX) == false)
|
||||
return false;
|
||||
|
||||
// Filter on width
|
||||
if (filter.DatItem_Width.MatchesPositiveSet(Width) == false)
|
||||
return false;
|
||||
if (filter.DatItem_Width.MatchesNegativeSet(Width) == true)
|
||||
return false;
|
||||
|
||||
// Filter on height
|
||||
if (filter.DatItem_Height.MatchesPositiveSet(Height) == false)
|
||||
return false;
|
||||
if (filter.DatItem_Height.MatchesNegativeSet(Height) == true)
|
||||
return false;
|
||||
|
||||
// Filter on refresh
|
||||
if (filter.DatItem_Refresh.MatchesPositiveSet(Refresh) == false)
|
||||
return false;
|
||||
if (filter.DatItem_Refresh.MatchesNegativeSet(Refresh) == true)
|
||||
return false;
|
||||
|
||||
// Filter on pixclock
|
||||
if (filter.DatItem_PixClock.MatchesPositiveSet(PixClock) == false)
|
||||
return false;
|
||||
if (filter.DatItem_PixClock.MatchesNegativeSet(PixClock) == true)
|
||||
return false;
|
||||
|
||||
// Filter on htotal
|
||||
if (filter.DatItem_HTotal.MatchesPositiveSet(HTotal) == false)
|
||||
return false;
|
||||
if (filter.DatItem_HTotal.MatchesNegativeSet(HTotal) == true)
|
||||
return false;
|
||||
|
||||
// Filter on hbend
|
||||
if (filter.DatItem_HBEnd.MatchesPositiveSet(HBEnd) == false)
|
||||
return false;
|
||||
if (filter.DatItem_HBEnd.MatchesNegativeSet(HBEnd) == true)
|
||||
return false;
|
||||
|
||||
// Filter on hbstart
|
||||
if (filter.DatItem_HBStart.MatchesPositiveSet(HBStart) == false)
|
||||
return false;
|
||||
if (filter.DatItem_HBStart.MatchesNegativeSet(HBStart) == true)
|
||||
return false;
|
||||
|
||||
// Filter on vtotal
|
||||
if (filter.DatItem_VTotal.MatchesPositiveSet(VTotal) == false)
|
||||
return false;
|
||||
if (filter.DatItem_VTotal.MatchesNegativeSet(VTotal) == true)
|
||||
return false;
|
||||
|
||||
// Filter on vbend
|
||||
if (filter.DatItem_VBEnd.MatchesPositiveSet(VBEnd) == false)
|
||||
return false;
|
||||
if (filter.DatItem_VBEnd.MatchesNegativeSet(VBEnd) == true)
|
||||
return false;
|
||||
|
||||
// Filter on vbstart
|
||||
if (filter.DatItem_VBStart.MatchesPositiveSet(VBStart) == false)
|
||||
return false;
|
||||
if (filter.DatItem_VBStart.MatchesNegativeSet(VBStart) == true)
|
||||
return false;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Remove fields from the DatItem
|
||||
/// </summary>
|
||||
/// <param name="fields">List of Fields to remove</param>
|
||||
public override void RemoveFields(List<Field> fields)
|
||||
{
|
||||
// Remove common fields first
|
||||
base.RemoveFields(fields);
|
||||
|
||||
// Remove the fields
|
||||
if (fields.Contains(Field.DatItem_Tag))
|
||||
Tag = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_DisplayType))
|
||||
DisplayType = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_Rotate))
|
||||
Rotate = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_FlipX))
|
||||
FlipX = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_Width))
|
||||
Width = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_Height))
|
||||
Height = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_Refresh))
|
||||
Refresh = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_PixClock))
|
||||
PixClock = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_HTotal))
|
||||
HTotal = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_HBEnd))
|
||||
HBEnd = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_HBStart))
|
||||
HBStart = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_VTotal))
|
||||
VTotal = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_VBEnd))
|
||||
VBEnd = null;
|
||||
|
||||
if (fields.Contains(Field.DatItem_VBStart))
|
||||
VBStart = null;
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region Sorting and Merging
|
||||
|
||||
/// <summary>
|
||||
/// Replace fields from another item
|
||||
/// </summary>
|
||||
/// <param name="item">DatItem to pull new information from</param>
|
||||
/// <param name="fields">List of Fields representing what should be updated</param>
|
||||
public override void ReplaceFields(DatItem item, List<Field> fields)
|
||||
{
|
||||
// Replace common fields first
|
||||
base.ReplaceFields(item, fields);
|
||||
|
||||
// If we don't have a Display to replace from, ignore specific fields
|
||||
if (item.ItemType != ItemType.Display)
|
||||
return;
|
||||
|
||||
// Cast for easier access
|
||||
Display newItem = item as Display;
|
||||
|
||||
// Replace the fields
|
||||
if (fields.Contains(Field.DatItem_Tag))
|
||||
Tag = newItem.Tag;
|
||||
|
||||
if (fields.Contains(Field.DatItem_DisplayType))
|
||||
DisplayType = newItem.DisplayType;
|
||||
|
||||
if (fields.Contains(Field.DatItem_Rotate))
|
||||
Rotate = newItem.Rotate;
|
||||
|
||||
if (fields.Contains(Field.DatItem_FlipX))
|
||||
FlipX = newItem.FlipX;
|
||||
|
||||
if (fields.Contains(Field.DatItem_Width))
|
||||
Width = newItem.Width;
|
||||
|
||||
if (fields.Contains(Field.DatItem_Height))
|
||||
Height = newItem.Height;
|
||||
|
||||
if (fields.Contains(Field.DatItem_Refresh))
|
||||
Refresh = newItem.Refresh;
|
||||
|
||||
if (fields.Contains(Field.DatItem_PixClock))
|
||||
PixClock = newItem.PixClock;
|
||||
|
||||
if (fields.Contains(Field.DatItem_HTotal))
|
||||
HTotal = newItem.HTotal;
|
||||
|
||||
if (fields.Contains(Field.DatItem_HBEnd))
|
||||
HBEnd = newItem.HBEnd;
|
||||
|
||||
if (fields.Contains(Field.DatItem_HBStart))
|
||||
HBStart = newItem.HBStart;
|
||||
|
||||
if (fields.Contains(Field.DatItem_VTotal))
|
||||
VTotal = newItem.VTotal;
|
||||
|
||||
if (fields.Contains(Field.DatItem_VBEnd))
|
||||
VBEnd = newItem.VBEnd;
|
||||
|
||||
if (fields.Contains(Field.DatItem_VBStart))
|
||||
VBStart = newItem.VBStart;
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
@@ -186,23 +186,6 @@ namespace SabreTools.Library.DatItems
|
||||
Machine_SourceFile,
|
||||
Machine_Runnable,
|
||||
|
||||
// Displays
|
||||
Machine_Displays,
|
||||
Machine_Display_Tag,
|
||||
Machine_Display_Type,
|
||||
Machine_Display_Rotate,
|
||||
Machine_Display_FlipX,
|
||||
Machine_Display_Width,
|
||||
Machine_Display_Height,
|
||||
Machine_Display_Refresh,
|
||||
Machine_Display_PixClock,
|
||||
Machine_Display_HTotal,
|
||||
Machine_Display_HBEnd,
|
||||
Machine_Display_HBStart,
|
||||
Machine_Display_VTotal,
|
||||
Machine_Display_VBEnd,
|
||||
Machine_Display_VBStart,
|
||||
|
||||
// Inputs
|
||||
Machine_Inputs,
|
||||
Machine_Input_Service,
|
||||
@@ -409,6 +392,21 @@ namespace SabreTools.Library.DatItems
|
||||
DatItem_Value_Value,
|
||||
DatItem_Value_Default,
|
||||
|
||||
// Display
|
||||
DatItem_DisplayType,
|
||||
DatItem_Rotate,
|
||||
DatItem_FlipX,
|
||||
DatItem_Width,
|
||||
DatItem_Height,
|
||||
DatItem_Refresh,
|
||||
DatItem_PixClock,
|
||||
DatItem_HTotal,
|
||||
DatItem_HBEnd,
|
||||
DatItem_HBStart,
|
||||
DatItem_VTotal,
|
||||
DatItem_VBEnd,
|
||||
DatItem_VBStart,
|
||||
|
||||
// Driver
|
||||
DatItem_SupportStatus,
|
||||
DatItem_EmulationStatus,
|
||||
@@ -489,6 +487,7 @@ namespace SabreTools.Library.DatItems
|
||||
Device,
|
||||
DeviceReference,
|
||||
DipSwitch,
|
||||
Display,
|
||||
Driver,
|
||||
Extension,
|
||||
Feature,
|
||||
|
||||
@@ -152,12 +152,6 @@ namespace SabreTools.Library.DatItems
|
||||
[JsonProperty("runnable", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public Runnable Runnable { get; set; } = Runnable.NULL;
|
||||
|
||||
/// <summary>
|
||||
/// List of associated displays
|
||||
/// </summary>
|
||||
[JsonProperty("displays", DefaultValueHandling = DefaultValueHandling.Ignore)]
|
||||
public List<Display> Displays { get; set; } = null;
|
||||
|
||||
/// <summary>
|
||||
/// List of associated inputs
|
||||
/// </summary>
|
||||
@@ -366,23 +360,6 @@ namespace SabreTools.Library.DatItems
|
||||
if (mappings.Keys.Contains(Field.Machine_Runnable))
|
||||
Runnable = mappings[Field.Machine_Runnable].AsRunnable();
|
||||
|
||||
// TODO: Add Machine_DeviceReference*
|
||||
// TODO: Add Machine_Chip*
|
||||
// TODO: Add Machine_Display*
|
||||
// TODO: Add Machine_Sound*
|
||||
// TODO: Add Machine_Condition*
|
||||
// TODO: Add Machine_Input*
|
||||
// TODO: Add Machine_DipSwitch*
|
||||
// TODO: Add Machine_Configuration*
|
||||
// TODO: Add Machine_Port*
|
||||
// TODO: Add Machine_Adjuster*
|
||||
// TODO: Add Machine_Driver*
|
||||
// TODO: Add Machine_Feature*
|
||||
// TODO: Add Machine_Device*
|
||||
// TODO: Add Machine_Slot*
|
||||
// TODO: Add Machine_SoftwareList*
|
||||
// TODO: Add Machine_RamOption*
|
||||
|
||||
#endregion
|
||||
|
||||
#region Logiqx
|
||||
@@ -516,7 +493,6 @@ namespace SabreTools.Library.DatItems
|
||||
|
||||
SourceFile = this.SourceFile,
|
||||
Runnable = this.Runnable,
|
||||
Displays = this.Displays,
|
||||
Inputs = this.Inputs,
|
||||
|
||||
#endregion
|
||||
@@ -714,289 +690,6 @@ namespace SabreTools.Library.DatItems
|
||||
if (filter.Machine_Runnable.MatchesNegative(Runnable.NULL, Runnable) == true)
|
||||
return false;
|
||||
|
||||
#region Displays
|
||||
|
||||
// Machine_Displays
|
||||
if (filter.Machine_Displays.MatchesNeutral(null, Displays?.Any() ?? null) == false)
|
||||
return false;
|
||||
|
||||
// Machine_Display_Tag
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_Tag.MatchesPositiveSet(display?.Tag) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_Tag.MatchesNegativeSet(display?.Tag) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_Type
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_Type.MatchesPositiveSet(display?.Type) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_Type.MatchesNegativeSet(display?.Type) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_Rotate
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_Rotate.MatchesPositiveSet(display?.Rotate) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_Rotate.MatchesNegativeSet(display?.Rotate) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_FlipX
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyNeutral = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_FlipX.MatchesNeutral(null, display?.FlipX) != false)
|
||||
anyNeutral = true;
|
||||
}
|
||||
|
||||
if (!anyNeutral)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_Width
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_Width.MatchesPositiveSet(display?.Width) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_Width.MatchesNegativeSet(display?.Width) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_Height
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_Height.MatchesPositiveSet(display?.Height) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_Height.MatchesNegativeSet(display?.Height) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_Refresh
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_Refresh.MatchesPositiveSet(display?.Refresh) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_Refresh.MatchesNegativeSet(display?.Refresh) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_PixClock
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_PixClock.MatchesPositiveSet(display?.PixClock) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_PixClock.MatchesNegativeSet(display?.PixClock) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_HTotal
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_HTotal.MatchesPositiveSet(display?.HTotal) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_HTotal.MatchesNegativeSet(display?.HTotal) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_HBEnd
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_HBEnd.MatchesPositiveSet(display?.HBEnd) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_HBEnd.MatchesNegativeSet(display?.HBEnd) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_HBStart
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_HBStart.MatchesPositiveSet(display?.HBStart) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_HBStart.MatchesNegativeSet(display?.HBStart) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_VTotal
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_VTotal.MatchesPositiveSet(display?.VTotal) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_VTotal.MatchesNegativeSet(display?.VTotal) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_VBEnd
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_VBEnd.MatchesPositiveSet(display?.VBEnd) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_VBEnd.MatchesNegativeSet(display?.VBEnd) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
// Machine_Display_VBStart
|
||||
if (Displays?.Any() == true)
|
||||
{
|
||||
bool anyPositive = false;
|
||||
bool anyNegative = false;
|
||||
|
||||
foreach (var display in Displays)
|
||||
{
|
||||
if (filter.Machine_Display_VBStart.MatchesPositiveSet(display?.VBStart) != false)
|
||||
anyPositive = true;
|
||||
if (filter.Machine_Display_VBStart.MatchesNegativeSet(display?.VBStart) == true)
|
||||
anyNegative = true;
|
||||
}
|
||||
|
||||
if (!anyPositive)
|
||||
return false;
|
||||
if (anyNegative)
|
||||
return false;
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
// TODO: Inputs
|
||||
// TODO: Inputs.Controls
|
||||
|
||||
|
||||
@@ -42,8 +42,8 @@ namespace SabreTools.Library.DatItems
|
||||
base.SetFields(mappings);
|
||||
|
||||
// Handle Port-specific fields
|
||||
if (mappings.Keys.Contains(Field.DatItem_Name))
|
||||
Tag = mappings[Field.DatItem_Name];
|
||||
if (mappings.Keys.Contains(Field.DatItem_Tag))
|
||||
Tag = mappings[Field.DatItem_Tag];
|
||||
|
||||
// TODO: Handle DatItem_Analog*
|
||||
}
|
||||
|
||||
@@ -51,23 +51,6 @@ namespace SabreTools.Library.Filtering
|
||||
public FilterItem<string> Machine_SourceFile { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<Runnable> Machine_Runnable { get; private set; } = new FilterItem<Runnable>() { Positive = Runnable.NULL, Negative = Runnable.NULL };
|
||||
|
||||
// Displays
|
||||
public FilterItem<bool?> Machine_Displays { get; private set; } = new FilterItem<bool?>() { Neutral = null };
|
||||
public FilterItem<string> Machine_Display_Tag { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_Type { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_Rotate { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<bool?> Machine_Display_FlipX { get; private set; } = new FilterItem<bool?>() { Neutral = null };
|
||||
public FilterItem<string> Machine_Display_Width { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_Height { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_Refresh { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_PixClock { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_HTotal { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_HBEnd { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_HBStart { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_VTotal { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_VBEnd { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> Machine_Display_VBStart { get; private set; } = new FilterItem<string>();
|
||||
|
||||
// Inputs
|
||||
public FilterItem<bool?> Machine_Inputs { get; private set; } = new FilterItem<bool?>() { Neutral = null };
|
||||
public FilterItem<bool?> Machine_Input_Service { get; private set; } = new FilterItem<bool?>() { Neutral = null };
|
||||
@@ -274,6 +257,21 @@ namespace SabreTools.Library.Filtering
|
||||
public FilterItem<string> DatItem_Value_Value { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<bool?> DatItem_Value_Default { get; private set; } = new FilterItem<bool?>() { Neutral = null };
|
||||
|
||||
// Display
|
||||
public FilterItem<string> DatItem_DisplayType { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> DatItem_Rotate { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<bool?> DatItem_FlipX { get; private set; } = new FilterItem<bool?>() { Neutral = null };
|
||||
public FilterItem<string> DatItem_Width { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> DatItem_Height { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> DatItem_Refresh { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> DatItem_PixClock { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> DatItem_HTotal { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> DatItem_HBEnd { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> DatItem_HBStart { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> DatItem_VTotal { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> DatItem_VBEnd { get; private set; } = new FilterItem<string>();
|
||||
public FilterItem<string> DatItem_VBStart { get; private set; } = new FilterItem<string>();
|
||||
|
||||
// Driver
|
||||
public FilterItem<SupportStatus> DatItem_SupportStatus { get; private set; } = new FilterItem<SupportStatus>() { Positive = SupportStatus.NULL, Negative = SupportStatus.NULL };
|
||||
public FilterItem<SupportStatus> DatItem_EmulationStatus { get; private set; } = new FilterItem<SupportStatus>() { Positive = SupportStatus.NULL, Negative = SupportStatus.NULL };
|
||||
@@ -535,112 +533,6 @@ namespace SabreTools.Library.Filtering
|
||||
Machine_Runnable.Positive |= value.AsRunnable();
|
||||
break;
|
||||
|
||||
// Displays
|
||||
case Field.Machine_Displays:
|
||||
if (negate || value.Equals("false", StringComparison.OrdinalIgnoreCase))
|
||||
Machine_Displays.Neutral = false;
|
||||
else
|
||||
Machine_Displays.Neutral = true;
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_Tag:
|
||||
if (negate)
|
||||
Machine_Display_Tag.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_Tag.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_Type:
|
||||
if (negate)
|
||||
Machine_Display_Type.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_Type.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_Rotate:
|
||||
if (negate)
|
||||
Machine_Display_Rotate.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_Rotate.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_FlipX:
|
||||
if (negate || value.Equals("false", StringComparison.OrdinalIgnoreCase))
|
||||
Machine_Display_FlipX.Neutral = false;
|
||||
else
|
||||
Machine_Display_FlipX.Neutral = true;
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_Width:
|
||||
if (negate)
|
||||
Machine_Display_Width.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_Width.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_Height:
|
||||
if (negate)
|
||||
Machine_Display_Height.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_Height.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_Refresh:
|
||||
if (negate)
|
||||
Machine_Display_Refresh.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_Refresh.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_PixClock:
|
||||
if (negate)
|
||||
Machine_Display_PixClock.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_PixClock.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_HTotal:
|
||||
if (negate)
|
||||
Machine_Display_HTotal.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_HTotal.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_HBEnd:
|
||||
if (negate)
|
||||
Machine_Display_HBEnd.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_HBEnd.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_HBStart:
|
||||
if (negate)
|
||||
Machine_Display_HBStart.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_HBStart.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_VTotal:
|
||||
if (negate)
|
||||
Machine_Display_VTotal.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_VTotal.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_VBEnd:
|
||||
if (negate)
|
||||
Machine_Display_VBEnd.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_VBEnd.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.Machine_Display_VBStart:
|
||||
if (negate)
|
||||
Machine_Display_VBStart.NegativeSet.Add(value);
|
||||
else
|
||||
Machine_Display_VBStart.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
// Inputs
|
||||
case Field.Machine_Inputs:
|
||||
if (negate || value.Equals("false", StringComparison.OrdinalIgnoreCase))
|
||||
@@ -1601,6 +1493,98 @@ namespace SabreTools.Library.Filtering
|
||||
DatItem_Value_Default.Neutral = true;
|
||||
break;
|
||||
|
||||
// Display
|
||||
case Field.DatItem_DisplayType:
|
||||
if (negate)
|
||||
DatItem_DisplayType.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_DisplayType.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_Rotate:
|
||||
if (negate)
|
||||
DatItem_Rotate.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_Rotate.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_FlipX:
|
||||
if (negate || value.Equals("false", StringComparison.OrdinalIgnoreCase))
|
||||
DatItem_FlipX.Neutral = false;
|
||||
else
|
||||
DatItem_FlipX.Neutral = true;
|
||||
break;
|
||||
|
||||
case Field.DatItem_Width:
|
||||
if (negate)
|
||||
DatItem_Width.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_Width.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_Height:
|
||||
if (negate)
|
||||
DatItem_Height.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_Height.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_Refresh:
|
||||
if (negate)
|
||||
DatItem_Refresh.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_Refresh.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_PixClock:
|
||||
if (negate)
|
||||
DatItem_PixClock.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_PixClock.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_HTotal:
|
||||
if (negate)
|
||||
DatItem_HTotal.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_HTotal.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_HBEnd:
|
||||
if (negate)
|
||||
DatItem_HBEnd.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_HBEnd.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_HBStart:
|
||||
if (negate)
|
||||
DatItem_HBStart.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_HBStart.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_VTotal:
|
||||
if (negate)
|
||||
DatItem_VTotal.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_VTotal.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_VBEnd:
|
||||
if (negate)
|
||||
DatItem_VBEnd.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_VBEnd.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
case Field.DatItem_VBStart:
|
||||
if (negate)
|
||||
DatItem_VBStart.NegativeSet.Add(value);
|
||||
else
|
||||
DatItem_VBStart.PositiveSet.Add(value);
|
||||
break;
|
||||
|
||||
// Driver
|
||||
case Field.DatItem_SupportStatus:
|
||||
if (negate)
|
||||
|
||||
@@ -572,51 +572,6 @@ namespace SabreTools.Library.Tools
|
||||
case "runnable":
|
||||
return Field.Machine_Runnable;
|
||||
|
||||
case "displays":
|
||||
return Field.Machine_Displays;
|
||||
|
||||
case "display_tag":
|
||||
return Field.Machine_Display_Tag;
|
||||
|
||||
case "display_type":
|
||||
return Field.Machine_Display_Type;
|
||||
|
||||
case "display_rotate":
|
||||
return Field.Machine_Display_Rotate;
|
||||
|
||||
case "display_flipx":
|
||||
return Field.Machine_Display_FlipX;
|
||||
|
||||
case "display_width":
|
||||
return Field.Machine_Display_Width;
|
||||
|
||||
case "display_height":
|
||||
return Field.Machine_Display_Height;
|
||||
|
||||
case "display_refresh":
|
||||
return Field.Machine_Display_Refresh;
|
||||
|
||||
case "display_pixclock":
|
||||
return Field.Machine_Display_PixClock;
|
||||
|
||||
case "display_htotal":
|
||||
return Field.Machine_Display_HTotal;
|
||||
|
||||
case "display_hbend":
|
||||
return Field.Machine_Display_HBEnd;
|
||||
|
||||
case "display_hbstart":
|
||||
return Field.Machine_Display_HBStart;
|
||||
|
||||
case "display_vtotal":
|
||||
return Field.Machine_Display_VTotal;
|
||||
|
||||
case "display_vbend":
|
||||
return Field.Machine_Display_VBEnd;
|
||||
|
||||
case "display_vbstart":
|
||||
return Field.Machine_Display_VBStart;
|
||||
|
||||
case "inputs":
|
||||
return Field.Machine_Inputs;
|
||||
|
||||
@@ -1080,6 +1035,46 @@ namespace SabreTools.Library.Tools
|
||||
case "extension_name":
|
||||
return Field.DatItem_Extension_Name;
|
||||
|
||||
// Display
|
||||
case "displaytype":
|
||||
return Field.DatItem_DisplayType;
|
||||
|
||||
case "rotate":
|
||||
return Field.DatItem_Rotate;
|
||||
|
||||
case "flipx":
|
||||
return Field.DatItem_FlipX;
|
||||
|
||||
case "width":
|
||||
return Field.DatItem_Width;
|
||||
|
||||
case "height":
|
||||
return Field.DatItem_Height;
|
||||
|
||||
case "refresh":
|
||||
return Field.DatItem_Refresh;
|
||||
|
||||
case "pixclock":
|
||||
return Field.DatItem_PixClock;
|
||||
|
||||
case "htotal":
|
||||
return Field.DatItem_HTotal;
|
||||
|
||||
case "hbend":
|
||||
return Field.DatItem_HBEnd;
|
||||
|
||||
case "hbstart":
|
||||
return Field.DatItem_HBStart;
|
||||
|
||||
case "vtotal":
|
||||
return Field.DatItem_VTotal;
|
||||
|
||||
case "vbend":
|
||||
return Field.DatItem_VBEnd;
|
||||
|
||||
case "vbstart":
|
||||
return Field.DatItem_VBStart;
|
||||
|
||||
// Driver
|
||||
case "supportstatus":
|
||||
return Field.DatItem_SupportStatus;
|
||||
@@ -1670,6 +1665,8 @@ namespace SabreTools.Library.Tools
|
||||
return ItemType.DipSwitch;
|
||||
case "disk":
|
||||
return ItemType.Disk;
|
||||
case "display":
|
||||
return ItemType.Display;
|
||||
case "driver":
|
||||
return ItemType.Driver;
|
||||
case "extension":
|
||||
@@ -1714,6 +1711,7 @@ namespace SabreTools.Library.Tools
|
||||
"device_ref" => ItemType.DeviceReference,
|
||||
"dipswitch" => ItemType.DipSwitch,
|
||||
"disk" => ItemType.Disk,
|
||||
"display" => ItemType.Display,
|
||||
"driver" => ItemType.Driver,
|
||||
"extension" => ItemType.Extension,
|
||||
"feature" => ItemType.Feature,
|
||||
@@ -2293,6 +2291,8 @@ namespace SabreTools.Library.Tools
|
||||
return "dipswitch";
|
||||
case ItemType.Disk:
|
||||
return "disk";
|
||||
case ItemType.Display:
|
||||
return "display";
|
||||
case ItemType.Driver:
|
||||
return "driver";
|
||||
case ItemType.Extension:
|
||||
@@ -2337,6 +2337,7 @@ namespace SabreTools.Library.Tools
|
||||
ItemType.DeviceReference => "device_ref",
|
||||
ItemType.DipSwitch => "dipswitch",
|
||||
ItemType.Disk => "disk",
|
||||
ItemType.Display => "display",
|
||||
ItemType.Driver => "driver",
|
||||
ItemType.Extension => "extension",
|
||||
ItemType.Feature => "feature",
|
||||
|
||||
Reference in New Issue
Block a user