// Copyright (C) Stichting Deltares 2016. 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 Application.Ringtoets.Storage.DbContext; using Ringtoets.Common.Data.Calculation; using Ringtoets.Common.Data.FailureMechanism; using Ringtoets.GrassCoverErosionInwards.Data; using Ringtoets.Integration.Data.StandAlone; using Ringtoets.Piping.Data; namespace Application.Ringtoets.Storage.Read { /// /// This class defines extension methods for read operations for a based on the /// . /// internal static class FailureMechanismEntityReadExtensions { /// /// Read the and use the information to construct a . /// /// The to create for. /// The object keeping track of read operations. /// A new . /// Thrown when is null. internal static PipingFailureMechanism ReadAsPipingFailureMechanism(this FailureMechanismEntity entity, ReadConversionCollector collector) { if (collector == null) { throw new ArgumentNullException("collector"); } var failureMechanism = new PipingFailureMechanism { StorageId = entity.FailureMechanismEntityId, IsRelevant = entity.IsRelevant == 1 }; foreach (var stochasticSoilModelEntity in entity.StochasticSoilModelEntities) { failureMechanism.StochasticSoilModels.Add(stochasticSoilModelEntity.Read(collector)); } foreach (SurfaceLineEntity surfaceLineEntity in entity.SurfaceLineEntities) { failureMechanism.SurfaceLines.Add(surfaceLineEntity.Read(collector)); } entity.ReadFailureMechanismSections(failureMechanism); ReadRootCalculationGroup(entity.CalculationGroupEntity, failureMechanism.CalculationsGroup, collector); return failureMechanism; } private static void ReadRootCalculationGroup(CalculationGroupEntity rootCalculationGroupEntity, CalculationGroup targetRootCalculationGroup, ReadConversionCollector collector) { var rootCalculationGroup = rootCalculationGroupEntity.Read(collector); targetRootCalculationGroup.StorageId = rootCalculationGroup.StorageId; foreach (ICalculationBase calculationBase in rootCalculationGroup.Children) { targetRootCalculationGroup.Children.Add(calculationBase); } } /// /// Read the and use the information to construct a . /// /// A new . internal static GrassCoverErosionInwardsFailureMechanism ReadAsGrassCoverErosionInwardsFailureMechanism(this FailureMechanismEntity entity) { var failureMechanism = new GrassCoverErosionInwardsFailureMechanism { StorageId = entity.FailureMechanismEntityId, IsRelevant = entity.IsRelevant == 1 }; entity.ReadFailureMechanismSections(failureMechanism); return failureMechanism; } /// /// Read the and use the information to construct a . /// /// A new . internal static MacrostabilityInwardsFailureMechanism ReadAsMacroStabilityInwardsFailureMechanism(this FailureMechanismEntity entity) { var failureMechanism = new MacrostabilityInwardsFailureMechanism() { StorageId = entity.FailureMechanismEntityId, IsRelevant = entity.IsRelevant == 1 }; entity.ReadFailureMechanismSections(failureMechanism); return failureMechanism; } private static void ReadFailureMechanismSections(this FailureMechanismEntity entity, IFailureMechanism failureMechanism) { foreach (var failureMechanismSectionEntity in entity.FailureMechanismSectionEntities) { failureMechanism.AddSection(failureMechanismSectionEntity.Read()); } } } }