mirror of
https://github.com/claunia/SabreTools.git
synced 2025-12-16 19:14:27 +00:00
Wire up remaining OpenMSX machine fields
This commit is contained in:
@@ -623,6 +623,20 @@ namespace SabreTools.Library.DatFiles
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
case "genmsxid":
|
||||||
|
machine.GenMSXID = jtr.ReadAsString();
|
||||||
|
break;
|
||||||
|
case "system":
|
||||||
|
machine.System = jtr.ReadAsString();
|
||||||
|
break;
|
||||||
|
case "country":
|
||||||
|
machine.Country = jtr.ReadAsString();
|
||||||
|
break;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
case "supported":
|
case "supported":
|
||||||
@@ -1758,6 +1772,26 @@ namespace SabreTools.Library.DatFiles
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
if (!string.IsNullOrWhiteSpace(datItem.GetField(Field.GenMSXID, Header.ExcludeFields)))
|
||||||
|
{
|
||||||
|
jtw.WritePropertyName("genmsxid");
|
||||||
|
jtw.WriteValue(datItem.Machine.GenMSXID);
|
||||||
|
}
|
||||||
|
if (!string.IsNullOrWhiteSpace(datItem.GetField(Field.System, Header.ExcludeFields)))
|
||||||
|
{
|
||||||
|
jtw.WritePropertyName("system");
|
||||||
|
jtw.WriteValue(datItem.Machine.System);
|
||||||
|
}
|
||||||
|
if (!string.IsNullOrWhiteSpace(datItem.GetField(Field.Country, Header.ExcludeFields)))
|
||||||
|
{
|
||||||
|
jtw.WritePropertyName("country");
|
||||||
|
jtw.WriteValue(datItem.Machine.Country);
|
||||||
|
}
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
if (!Header.ExcludeFields.Contains(Field.Supported) && datItem.Machine.Supported != null)
|
if (!Header.ExcludeFields.Contains(Field.Supported) && datItem.Machine.Supported != null)
|
||||||
|
|||||||
@@ -135,13 +135,11 @@ namespace SabreTools.Library.DatFiles
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case "genmsxid":
|
case "genmsxid":
|
||||||
// string id = reader.ReadElementContentAsString();
|
machine.GenMSXID = reader.ReadElementContentAsString();
|
||||||
reader.Read();
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "system":
|
case "system":
|
||||||
// string system = reader.ReadElementContentAsString();
|
machine.System = reader.ReadElementContentAsString();
|
||||||
reader.Read();
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "company":
|
case "company":
|
||||||
@@ -153,8 +151,7 @@ namespace SabreTools.Library.DatFiles
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case "country":
|
case "country":
|
||||||
// string country = reader.ReadElementContentAsString();
|
machine.Country = reader.ReadElementContentAsString();
|
||||||
reader.Read();
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "dump":
|
case "dump":
|
||||||
@@ -631,11 +628,11 @@ namespace SabreTools.Library.DatFiles
|
|||||||
// Build the state based on excluded fields
|
// Build the state based on excluded fields
|
||||||
xtw.WriteStartElement("software");
|
xtw.WriteStartElement("software");
|
||||||
xtw.WriteElementString("title", datItem.GetField(Field.MachineName, Header.ExcludeFields));
|
xtw.WriteElementString("title", datItem.GetField(Field.MachineName, Header.ExcludeFields));
|
||||||
//xtw.WriteElementString("genmsxid", msxid);
|
xtw.WriteElementString("genmsxid", datItem.GetField(Field.GenMSXID, Header.ExcludeFields));
|
||||||
//xtw.WriteElementString("system", system));
|
xtw.WriteElementString("system", datItem.GetField(Field.System, Header.ExcludeFields));
|
||||||
xtw.WriteElementString("company", datItem.GetField(Field.Manufacturer, Header.ExcludeFields));
|
xtw.WriteElementString("company", datItem.GetField(Field.Manufacturer, Header.ExcludeFields));
|
||||||
xtw.WriteElementString("year", datItem.GetField(Field.Year, Header.ExcludeFields));
|
xtw.WriteElementString("year", datItem.GetField(Field.Year, Header.ExcludeFields));
|
||||||
//xtw.WriteElementString("country", country);
|
xtw.WriteElementString("country", datItem.GetField(Field.Country, Header.ExcludeFields));
|
||||||
|
|
||||||
xtw.Flush();
|
xtw.Flush();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -459,6 +459,22 @@ namespace SabreTools.Library.DatFiles
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
case "Machine.GenMSXID":
|
||||||
|
machine.GenMSXID = value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "Machine.System":
|
||||||
|
machine.System = value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "Machine.Country":
|
||||||
|
machine.Country = value;
|
||||||
|
break;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
case "Machine.Supported":
|
case "Machine.Supported":
|
||||||
@@ -1238,6 +1254,25 @@ namespace SabreTools.Library.DatFiles
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
case "genmsxid":
|
||||||
|
case "genmsx id":
|
||||||
|
case "genmsx-id":
|
||||||
|
case "gen msx id":
|
||||||
|
case "gen-msx-id":
|
||||||
|
return "Machine.GenMSXID";
|
||||||
|
|
||||||
|
case "msxsystem":
|
||||||
|
case "msx system":
|
||||||
|
case "msx-system":
|
||||||
|
return "Machine.System";
|
||||||
|
|
||||||
|
case "country":
|
||||||
|
return "Machine.Country";
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
case "supported":
|
case "supported":
|
||||||
|
|||||||
@@ -251,6 +251,11 @@ namespace SabreTools.Library.DatItems
|
|||||||
Field.HasCrc,
|
Field.HasCrc,
|
||||||
Field.RelatedTo,
|
Field.RelatedTo,
|
||||||
|
|
||||||
|
// OpenMSX
|
||||||
|
Field.GenMSXID,
|
||||||
|
Field.System,
|
||||||
|
Field.Country,
|
||||||
|
|
||||||
// SoftwareList
|
// SoftwareList
|
||||||
Field.Supported,
|
Field.Supported,
|
||||||
Field.SharedFeatures,
|
Field.SharedFeatures,
|
||||||
|
|||||||
@@ -87,6 +87,14 @@ namespace SabreTools.Library.DatItems
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
GenMSXID,
|
||||||
|
System,
|
||||||
|
Country,
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
Supported,
|
Supported,
|
||||||
|
|||||||
@@ -3,8 +3,8 @@ using System.Collections.Generic;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
|
||||||
using SabreTools.Library.Filtering;
|
using SabreTools.Library.Filtering;
|
||||||
using Newtonsoft.Json;
|
|
||||||
using SabreTools.Library.Tools;
|
using SabreTools.Library.Tools;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
|
||||||
namespace SabreTools.Library.DatItems
|
namespace SabreTools.Library.DatItems
|
||||||
{
|
{
|
||||||
@@ -245,6 +245,28 @@ namespace SabreTools.Library.DatItems
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX Fields
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Generation MSX ID
|
||||||
|
/// </summary>
|
||||||
|
[JsonProperty("genmsxid")]
|
||||||
|
public string GenMSXID { get; set; } = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// MSX System
|
||||||
|
/// </summary>
|
||||||
|
[JsonProperty("system")]
|
||||||
|
public string System { get; set; } = null;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Machine country of origin
|
||||||
|
/// </summary>
|
||||||
|
[JsonProperty("country")]
|
||||||
|
public string Country { get; set; } = null;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList Fields
|
#region SoftwareList Fields
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -412,6 +434,20 @@ namespace SabreTools.Library.DatItems
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
case Field.GenMSXID:
|
||||||
|
fieldValue = GenMSXID;
|
||||||
|
break;
|
||||||
|
case Field.System:
|
||||||
|
fieldValue = System;
|
||||||
|
break;
|
||||||
|
case Field.Country:
|
||||||
|
fieldValue = Country;
|
||||||
|
break;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
case Field.Supported:
|
case Field.Supported:
|
||||||
@@ -588,6 +624,19 @@ namespace SabreTools.Library.DatItems
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
if (mappings.Keys.Contains(Field.GenMSXID))
|
||||||
|
GenMSXID = mappings[Field.GenMSXID];
|
||||||
|
|
||||||
|
if (mappings.Keys.Contains(Field.System))
|
||||||
|
System = mappings[Field.System];
|
||||||
|
|
||||||
|
if (mappings.Keys.Contains(Field.Country))
|
||||||
|
Country = mappings[Field.Country];
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
if (mappings.Keys.Contains(Field.Supported))
|
if (mappings.Keys.Contains(Field.Supported))
|
||||||
@@ -710,6 +759,14 @@ namespace SabreTools.Library.DatItems
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
GenMSXID = this.GenMSXID,
|
||||||
|
System = this.System,
|
||||||
|
Country = this.Country,
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
Supported = this.Supported,
|
Supported = this.Supported,
|
||||||
@@ -976,6 +1033,28 @@ namespace SabreTools.Library.DatItems
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
// Filter on Generation MSX ID
|
||||||
|
if (filter.GenMSXID.MatchesPositiveSet(GenMSXID) == false)
|
||||||
|
return false;
|
||||||
|
if (filter.GenMSXID.MatchesNegativeSet(GenMSXID) == true)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Filter on system
|
||||||
|
if (filter.System.MatchesPositiveSet(System) == false)
|
||||||
|
return false;
|
||||||
|
if (filter.System.MatchesNegativeSet(System) == true)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Filter on country
|
||||||
|
if (filter.Country.MatchesPositiveSet(Country) == false)
|
||||||
|
return false;
|
||||||
|
if (filter.Country.MatchesNegativeSet(Country) == true)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
// Filter on supported
|
// Filter on supported
|
||||||
@@ -1115,6 +1194,19 @@ namespace SabreTools.Library.DatItems
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
if (fields.Contains(Field.GenMSXID))
|
||||||
|
GenMSXID = null;
|
||||||
|
|
||||||
|
if (fields.Contains(Field.System))
|
||||||
|
System = null;
|
||||||
|
|
||||||
|
if (fields.Contains(Field.Country))
|
||||||
|
Country = null;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
if (fields.Contains(Field.Supported))
|
if (fields.Contains(Field.Supported))
|
||||||
@@ -1266,6 +1358,19 @@ namespace SabreTools.Library.DatItems
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
if (fields.Contains(Field.GenMSXID))
|
||||||
|
GenMSXID = machine.GenMSXID;
|
||||||
|
|
||||||
|
if (fields.Contains(Field.System))
|
||||||
|
System = machine.System;
|
||||||
|
|
||||||
|
if (fields.Contains(Field.Country))
|
||||||
|
Country = machine.Country;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
if (fields.Contains(Field.Supported))
|
if (fields.Contains(Field.Supported))
|
||||||
|
|||||||
@@ -205,6 +205,25 @@ namespace SabreTools.Library.Filtering
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Include or exclude machine Generation MSX ID
|
||||||
|
/// </summary>
|
||||||
|
public FilterItem<string> GenMSXID { get; private set; } = new FilterItem<string>();
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Include or exclude machine system
|
||||||
|
/// </summary>
|
||||||
|
public FilterItem<string> System { get; private set; } = new FilterItem<string>();
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Include or exclude machine country
|
||||||
|
/// </summary>
|
||||||
|
public FilterItem<string> Country { get; private set; } = new FilterItem<string>();
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -762,6 +781,31 @@ namespace SabreTools.Library.Filtering
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
case Field.GenMSXID:
|
||||||
|
if (negate)
|
||||||
|
GenMSXID.NegativeSet.Add(value);
|
||||||
|
else
|
||||||
|
GenMSXID.PositiveSet.Add(value);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Field.System:
|
||||||
|
if (negate)
|
||||||
|
System.NegativeSet.Add(value);
|
||||||
|
else
|
||||||
|
System.PositiveSet.Add(value);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Field.Country:
|
||||||
|
if (negate)
|
||||||
|
Country.NegativeSet.Add(value);
|
||||||
|
else
|
||||||
|
Country.PositiveSet.Add(value);
|
||||||
|
break;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
case Field.Supported:
|
case Field.Supported:
|
||||||
|
|||||||
@@ -293,6 +293,26 @@ namespace SabreTools.Library.Tools
|
|||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
#region OpenMSX
|
||||||
|
|
||||||
|
case "genmsxid":
|
||||||
|
case "genmsx id":
|
||||||
|
case "genmsx-id":
|
||||||
|
case "gen msx id":
|
||||||
|
case "gen-msx-id":
|
||||||
|
return Field.GenMSXID;
|
||||||
|
|
||||||
|
case "system":
|
||||||
|
case "msxsystem":
|
||||||
|
case "msx system":
|
||||||
|
case "msx-system":
|
||||||
|
return Field.System;
|
||||||
|
|
||||||
|
case "country":
|
||||||
|
return Field.Country;
|
||||||
|
|
||||||
|
#endregion
|
||||||
|
|
||||||
#region SoftwareList
|
#region SoftwareList
|
||||||
|
|
||||||
case "supported":
|
case "supported":
|
||||||
|
|||||||
Reference in New Issue
Block a user