// 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.Base; using Ringtoets.Common.Data.Calculation; using Ringtoets.Common.Data.Hydraulics; using Ringtoets.Common.Service; using Ringtoets.GrassCoverErosionOutwards.Data; using Ringtoets.Revetment.Data; namespace Ringtoets.GrassCoverErosionOutwards.Service { /// /// Service for synchronizing grass cover erosion outwards data. /// public static class GrassCoverErosionOutwardsDataSynchronizationService { /// /// Clears the output of the given . /// /// The /// to clear the output for. /// Thrown when /// is null. /// All objects that have been changed. public static IEnumerable ClearWaveConditionsCalculationOutput(GrassCoverErosionOutwardsWaveConditionsCalculation calculation) { if (calculation == null) { throw new ArgumentNullException(nameof(calculation)); } if (calculation.HasOutput) { calculation.ClearOutput(); return new[] { calculation }; } return Enumerable.Empty(); } /// /// Clears the and output for all the wave conditions calculations /// in the . /// /// The /// which contains the calculations. /// An of objects which are affected by removal of data. /// Thrown when /// is null. public static IEnumerable ClearAllWaveConditionsCalculationOutputAndHydraulicBoundaryLocations( GrassCoverErosionOutwardsFailureMechanism failureMechanism) { if (failureMechanism == null) { throw new ArgumentNullException(nameof(failureMechanism)); } var affectedItems = new List(); foreach (GrassCoverErosionOutwardsWaveConditionsCalculation calculation in failureMechanism.Calculations.Cast()) { affectedItems.AddRange(ClearWaveConditionsCalculationOutput(calculation) .Concat(ClearHydraulicBoundaryLocation(calculation.InputParameters))); } return affectedItems; } /// /// Clears the output for all calculations in the . /// /// The /// which contains the calculations. /// An of calculations which are affected by /// clearing the output. /// Thrown when /// is null. public static IEnumerable ClearAllWaveConditionsCalculationOutput( GrassCoverErosionOutwardsFailureMechanism failureMechanism) { if (failureMechanism == null) { throw new ArgumentNullException(nameof(failureMechanism)); } return failureMechanism.Calculations .Cast() .SelectMany(ClearWaveConditionsCalculationOutput) .ToArray(); } /// /// Clears all data dependent, either directly or indirectly, on the parent reference line. /// /// The failure mechanism to be cleared. /// The results of the clear action. /// Thrown when /// is null. public static ClearResults ClearReferenceLineDependentData(GrassCoverErosionOutwardsFailureMechanism failureMechanism) { if (failureMechanism == null) { throw new ArgumentNullException(nameof(failureMechanism)); } var changedObjects = new List(); object[] removedObjects = failureMechanism.Sections.OfType() .Concat(failureMechanism.SectionResults) .Concat(failureMechanism.WaveConditionsCalculationGroup.GetAllChildrenRecursive()) .Concat(failureMechanism.ForeshoreProfiles) .ToArray(); failureMechanism.ClearAllSections(); changedObjects.Add(failureMechanism); changedObjects.Add(failureMechanism.SectionResults); failureMechanism.WaveConditionsCalculationGroup.Children.Clear(); changedObjects.Add(failureMechanism.WaveConditionsCalculationGroup); failureMechanism.ForeshoreProfiles.Clear(); changedObjects.Add(failureMechanism.ForeshoreProfiles); return new ClearResults(changedObjects, removedObjects); } private static IEnumerable ClearHydraulicBoundaryLocation(WaveConditionsInput input) { if (input.HydraulicBoundaryLocation != null) { input.HydraulicBoundaryLocation = null; return new[] { input }; } return Enumerable.Empty(); } } }