// 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));
}
}
}
}