using System.Xml.Serialization; using SabreTools.Core; using Newtonsoft.Json; namespace SabreTools.DatItems.Formats { /// /// Represents one part feature object /// [JsonObject("part_feature"), XmlRoot("part_feature")] public class PartFeature : DatItem { #region Fields /// /// Name of the item /// [JsonProperty("name")] [XmlElement("name")] public string Name { get; set; } /// /// PartFeature value /// [JsonProperty("value")] [XmlElement("value")] public string Value { get; set; } #endregion #region Accessors /// public override string GetName() => Name; /// public override void SetName(string name) => Name = name; #endregion #region Constructors /// /// Create a default, empty PartFeature object /// public PartFeature() { Name = string.Empty; ItemType = ItemType.PartFeature; } #endregion #region Cloning Methods public override object Clone() { return new PartFeature() { ItemType = this.ItemType, DupeType = this.DupeType, Machine = this.Machine.Clone() as Machine, Source = this.Source.Clone() as Source, Remove = this.Remove, Name = this.Name, Value = this.Value, }; } #endregion #region Comparision Methods public override bool Equals(DatItem other) { // If we don't have a sample, return false if (ItemType != other.ItemType) return false; // Otherwise, treat it as a PartFeature PartFeature newOther = other as PartFeature; // If the archive information matches return (Name == newOther.Name && Value == newOther.Value); } #endregion } }