/// <summary> /// Returns true if self and the provided entity have the same Id values /// and the Ids are not of the default Id value /// </summary> protected bool HasSameNonDefaultIdAs(PlanningResponse compareTo) { return(!this.IsTransient() && !compareTo.IsTransient() && this.PlanningResponseKey.Equals(compareTo.PlanningResponseKey)); }
/// <summary> /// Copies the current object to a new instance /// </summary> /// <param name="deep">Copy members that refer to objects external to this class (not dependent)</param> /// <param name="copiedObjects">Objects that should be reused</param> /// <param name="asNew">Copy the current object as a new one, ready to be persisted, along all its members.</param> /// <param name="reuseNestedObjects">If asNew is true, this flag if set, forces the reuse of all external objects.</param> /// <param name="copy">Optional - An existing [PlanningResponse] instance to use as the destination.</param> /// <returns>A copy of the object</returns> public virtual PlanningResponse Copy(bool deep = false, Hashtable copiedObjects = null, bool asNew = false, bool reuseNestedObjects = false, PlanningResponse copy = null) { if (copiedObjects == null) { copiedObjects = new Hashtable(); } if (copy == null && copiedObjects.Contains(this)) { return((PlanningResponse)copiedObjects[this]); } copy = copy ?? new PlanningResponse(); if (!asNew) { copy.TransientId = this.TransientId; copy.PlanningResponseKey = this.PlanningResponseKey; } copy.SessionIdentifier = this.SessionIdentifier; if (!copiedObjects.Contains(this)) { copiedObjects.Add(this, copy); } copy.solutions = new List <GetSolutionDetailsResponse>(); if (deep && this.solutions != null) { foreach (var __item in this.solutions) { if (!copiedObjects.Contains(__item)) { if (asNew && reuseNestedObjects) { copy.AddSolutions(__item); } else { copy.AddSolutions(__item.Copy(deep, copiedObjects, asNew)); } } else { copy.AddSolutions((GetSolutionDetailsResponse)copiedObjects[__item]); } } } copy.errors = new List <Error>(); if (deep && this.errors != null) { foreach (var __item in this.errors) { if (!copiedObjects.Contains(__item)) { if (asNew && reuseNestedObjects) { copy.AddErrors(__item); } else { copy.AddErrors(__item.Copy(deep, copiedObjects, asNew)); } } else { copy.AddErrors((Error)copiedObjects[__item]); } } } return(copy); }