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