// 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 Core.Common.Utils; using Ringtoets.Common.Data.UpdateDataStrategies; using Ringtoets.Common.IO.SoilProfile; using Ringtoets.MacroStabilityInwards.Data; using Ringtoets.MacroStabilityInwards.Data.SoilProfile; using Ringtoets.MacroStabilityInwards.Service; namespace Ringtoets.MacroStabilityInwards.Plugin.FileImporter { /// /// An for updating stochastic soil models based on imported data. /// public class MacroStabilityInwardsStochasticSoilModelUpdateDataStrategy : UpdateDataStrategyBase, IStochasticSoilModelUpdateModelStrategy { /// /// Creates a new instance of . /// /// The failure mechanism in which the models are updated. /// Thrown when is null. public MacroStabilityInwardsStochasticSoilModelUpdateDataStrategy(MacroStabilityInwardsFailureMechanism failureMechanism) : base(failureMechanism, failureMechanism?.StochasticSoilModels, new SoilModelNameEqualityComparer()) {} public IEnumerable UpdateModelWithImportedData(IEnumerable stochasticSoilModels, string sourceFilePath) { return UpdateTargetCollectionData(stochasticSoilModels, sourceFilePath); } #region Remove Data Functions protected override IEnumerable RemoveObjectAndDependentData(MacroStabilityInwardsStochasticSoilModel removedModel) { return MacroStabilityInwardsDataSynchronizationService.RemoveStochasticSoilModel(FailureMechanism, removedModel); } #endregion /// /// Class for comparing by just the name. /// private class SoilModelNameEqualityComparer : IEqualityComparer { public bool Equals(MacroStabilityInwardsStochasticSoilModel x, MacroStabilityInwardsStochasticSoilModel y) { return x.Name == y.Name; } public int GetHashCode(MacroStabilityInwardsStochasticSoilModel obj) { return obj.Name.GetHashCode(); } } #region Update Data Functions protected override IEnumerable UpdateObjectAndDependentData(MacroStabilityInwardsStochasticSoilModel soilModelToUpdate, MacroStabilityInwardsStochasticSoilModel soilModelToUpdateFrom) { return UpdateStochasticSoilModel(soilModelToUpdate, soilModelToUpdateFrom); } private IEnumerable UpdateStochasticSoilModel(MacroStabilityInwardsStochasticSoilModel modelToUpdate, MacroStabilityInwardsStochasticSoilModel modelToUpdateFrom) { Dictionary oldProfiles = modelToUpdate .StochasticSoilProfiles .ToDictionary(ssp => ssp, ssp => ssp.SoilProfile, new ReferenceEqualityComparer()); MacroStabilityInwardsStochasticSoilModelProfileDifference difference = modelToUpdate.Update(modelToUpdateFrom); var affectedObjects = new List(); foreach (MacroStabilityInwardsStochasticSoilProfile removedProfile in difference.RemovedProfiles) { affectedObjects.AddRange(MacroStabilityInwardsDataSynchronizationService.RemoveStochasticSoilProfileFromInput(FailureMechanism, removedProfile)); } foreach (MacroStabilityInwardsStochasticSoilProfile updatedProfile in difference.UpdatedProfiles) { if (!oldProfiles[updatedProfile].Equals(updatedProfile.SoilProfile)) { affectedObjects.AddRange(MacroStabilityInwardsDataSynchronizationService.ClearStochasticSoilProfileDependentData(FailureMechanism, updatedProfile)); } affectedObjects.Add(updatedProfile); } return affectedObjects; } #endregion } }