// Copyright (C) Stichting Deltares 2017. All rights reserved. // // This file is part of Ringtoets. // // Ringtoets is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . // // All names, logos, and references to "Deltares" are registered trademarks of // Stichting Deltares and remain full property of Stichting Deltares at all times. // All rights reserved. using System; using System.Collections.Generic; using System.Linq; using Core.Common.Utils.Extensions; using Ringtoets.Common.Data.Properties; namespace Ringtoets.Common.Data.IllustrationPoints { /// /// A node with attached illustration point data that is part of a tree. Multiple /// nodes form the tree structure describing how the illustration points are related. /// public class IllustrationPointNode : ICloneable { /// /// Creates a new instance of . /// /// The illustration point data that is attached /// to this node. /// Thrown when /// is null. public IllustrationPointNode(IllustrationPointBase data) { if (data == null) { throw new ArgumentNullException(nameof(data)); } Data = data; Children = Enumerable.Empty(); } /// /// Gets the attached illustration point data to this node. /// public IllustrationPointBase Data { get; private set; } /// /// Gets the attached child nodes of this node. /// public IEnumerable Children { get; private set; } /// /// Sets the children to this node. /// /// The children that are attached to this node. /// Thrown when: /// /// does not contain 0 or 2 elements; /// the children have duplicate names; /// they have different stochasts than the node itself. /// /// public void SetChildren(IllustrationPointNode[] children) { if (children == null) { throw new ArgumentNullException(nameof(children)); } int nrOfChildren = children.Length; if (nrOfChildren != 0 && nrOfChildren != 2) { throw new ArgumentException(Resources.IllustrationPointNode_SetChildren_Node_must_have_zero_or_two_child_nodes, nameof(children)); } var faultTreeData = Data as FaultTreeIllustrationPoint; if (faultTreeData != null) { ValidateChildNames(children); ValidateChildStochasts(faultTreeData, children); } Children = children; } public object Clone() { var clone = (IllustrationPointNode) MemberwiseClone(); clone.Data = (IllustrationPointBase) Data.Clone(); clone.Children = Children.Select(c => (IllustrationPointNode) c.Clone()).ToArray(); return clone; } /// /// Validates a by checking for duplicate names in child nodes. /// /// The collection of to be validated. /// Thrown when contains child nodes with /// duplicate names. private static void ValidateChildNames(IEnumerable children) { if (children.HasDuplicates(c => c.Data.Name)) { throw new ArgumentException(string.Format(Resources.IllustrationPointNode_ValidateChildNames_Child_names_not_unique)); } } /// /// Validates a by comparing the stochasts in child nodes with its /// own stochasts. /// /// The to be validated. /// The collection of to be validated. /// Thrown when contains stochasts that /// are not in 's stochasts. private static void ValidateChildStochasts(FaultTreeIllustrationPoint data, IEnumerable children) { List stochastNames = children.SelectMany(c => c.GetStochastNames()).ToList(); if (data.GetStochastNames().Intersect(stochastNames).Count() != stochastNames.Distinct().Count()) { throw new ArgumentException(string.Format(Resources.Child_stochasts_not_same_as_parent_stochasts)); } } } }