using System.Xml.Serialization; using Newtonsoft.Json; using SabreTools.Core; namespace SabreTools.DatItems.Formats { /// /// Represents one ListXML slotoption /// [JsonObject("slotoption"), XmlRoot("slotoption")] public class SlotOption : DatItem { #region Fields /// /// Slot option name /// [JsonProperty("name"), XmlElement("name")] public string Name { get; set; } /// /// Referenced device name /// [JsonProperty("devname"), XmlElement("devname")] public string DeviceName { get; set; } /// /// Determines if this slot option is default or not /// [JsonProperty("default", DefaultValueHandling = DefaultValueHandling.Ignore), XmlElement("default")] public bool? Default { get; set; } [JsonIgnore] public bool DefaultSpecified { get { return Default != null; } } #endregion #region Accessors /// public override string GetName() => Name; /// public override void SetName(string name) => Name = name; #endregion #region Constructors /// /// Create a default, empty SlotOption object /// public SlotOption() { Name = string.Empty; ItemType = ItemType.SlotOption; } #endregion #region Cloning Methods /// public override object Clone() { return new SlotOption() { ItemType = this.ItemType, DupeType = this.DupeType, Machine = this.Machine.Clone() as Machine, Source = this.Source.Clone() as Source, Remove = this.Remove, Name = this.Name, DeviceName = this.DeviceName, Default = this.Default, }; } #endregion #region Comparision Methods /// public override bool Equals(DatItem other) { // If we don't have a SlotOption, return false if (ItemType != other.ItemType) return false; // Otherwise, treat it as a SlotOption SlotOption newOther = other as SlotOption; // If the SlotOption information matches return (Name == newOther.Name && DeviceName == newOther.DeviceName && Default == newOther.Default); } #endregion } }