// 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 System.Collections.Generic; using System.Linq; using Core.Common.Base; using log4net; using Ringtoets.Common.Service; using Ringtoets.Piping.Data; using Ringtoets.Piping.Service; namespace Ringtoets.Piping.Plugin.FileImporter { /// /// Strategy for updating the current stochastic soil models with the imported stochastic soil models. /// public class StochasticSoilModelUpdateData : IStochasticSoilModelUpdateStrategy { private readonly ILog log = LogManager.GetLogger(typeof(StochasticSoilModelUpdateData)); private readonly PipingFailureMechanism failureMechanism; /// /// Creates a new instance of . /// /// The failure mechanism in which the models are updated. public StochasticSoilModelUpdateData(PipingFailureMechanism failureMechanism) { if (failureMechanism == null) { throw new ArgumentNullException(nameof(failureMechanism)); } this.failureMechanism = failureMechanism; } /// /// Updates the . /// Updates stochastic soil models in that are part of /// . /// Adds stochastic soil models that are not in , but are part of /// . /// Removes stochastic soil models that are in , but are not part /// of . /// /// The imported stochastic soil models. /// The file path from which the /// were imported. /// The current collection of . /// Thrown when /// contains multiple with the same , /// and also contains a with /// the same name. /// /// Thrown when any parameter is null. /// List of updated instances. public IEnumerable UpdateModelWithImportedData( IEnumerable readStochasticSoilModels, string sourceFilePath, StochasticSoilModelCollection targetCollection) { if (readStochasticSoilModels == null) { throw new ArgumentNullException(nameof(readStochasticSoilModels)); } if (targetCollection == null) { throw new ArgumentNullException(nameof(targetCollection)); } var removedModels = targetCollection.ToList(); var updatedOrAddedModels = new List(); var affectedObjects = new List { targetCollection }; foreach (var readModel in readStochasticSoilModels) { var existingModel = targetCollection.SingleOrDefault(existing => existing.Name.Equals(readModel.Name)); if (existingModel != null) { affectedObjects.AddRange(UpdateStochasticSoilModel(existingModel, readModel)); removedModels.Remove(existingModel); updatedOrAddedModels.Add(existingModel); } else { removedModels.Remove(readModel); updatedOrAddedModels.Add(readModel); } } foreach (var model in removedModels) { affectedObjects.AddRange(RemoveStochasticSoilModel(model)); } targetCollection.Clear(); targetCollection.AddRange(updatedOrAddedModels, sourceFilePath); return affectedObjects; } private IEnumerable RemoveStochasticSoilModel(StochasticSoilModel removedModel) { return PipingDataSynchronizationService.RemoveStochasticSoilModel(failureMechanism, removedModel); } private IEnumerable UpdateStochasticSoilModel(StochasticSoilModel existingModel, StochasticSoilModel readModel) { StochasticSoilModelProfileDifference difference = existingModel.Update(readModel); var affectedObjects = new List(); foreach (StochasticSoilProfile removedProfile in difference.RemovedProfiles) { affectedObjects.AddRange(PipingDataSynchronizationService.RemoveStochasticSoilProfileFromInput(failureMechanism, removedProfile)); } foreach (StochasticSoilProfile updatedProfile in difference.UpdatedProfiles) { IEnumerable pipingInputs = failureMechanism.Calculations .Cast() .Where(c => ReferenceEquals(c.InputParameters.StochasticSoilProfile, updatedProfile)); foreach (PipingCalculation calculation in pipingInputs) { affectedObjects.AddRange(RingtoetsCommonDataSynchronizationService.ClearCalculationOutput(calculation)); affectedObjects.Add(calculation.InputParameters); } } return affectedObjects; } } }