// 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 Core.Common.Utils; using Ringtoets.Common.Data.UpdateDataStrategies; using Ringtoets.Piping.Data; using Ringtoets.Piping.IO.Exceptions; using Ringtoets.Piping.IO.Importers; using Ringtoets.Piping.Plugin.Properties; using Ringtoets.Piping.Primitives; using Ringtoets.Piping.Service; namespace Ringtoets.Piping.Plugin.FileImporter { /// /// An for updating stochastic soil models based on imported data. /// public class StochasticSoilModelUpdateDataStrategy : UpdateDataStrategyBase, IStochasticSoilModelUpdateModelStrategy { /// /// Creates a new instance of . /// /// The failure mechanism in which the models are updated. /// Thrown when is null. public StochasticSoilModelUpdateDataStrategy(PipingFailureMechanism failureMechanism) : base(failureMechanism, new SoilModelNameEqualityComparer()) {} public IEnumerable UpdateModelWithImportedData(StochasticSoilModelCollection targetCollection, IEnumerable readStochasticSoilModels, string sourceFilePath) { try { return UpdateTargetCollectionData(targetCollection, readStochasticSoilModels, sourceFilePath); } catch (ArgumentNullException) { throw; } catch (ArgumentException e) { throw new StochasticSoilModelUpdateException(e.Message, e); } catch (InvalidOperationException e) { string message = Resources.StochasticSoilModelUpdateDataStrategy_UpdateModelWithImportedData_Update_of_StochasticSoilModel_failed; throw new StochasticSoilModelUpdateException(message, e); } } /// /// Class for comparing by just the name. /// private class SoilModelNameEqualityComparer : IEqualityComparer { public bool Equals(StochasticSoilModel x, StochasticSoilModel y) { return x.Name == y.Name; } public int GetHashCode(StochasticSoilModel obj) { return obj.Name.GetHashCode(); } } #region Update Data Functions protected override IEnumerable UpdateObjectAndDependentData(StochasticSoilModel soilModelToUpdate, StochasticSoilModel soilModelToUpdateFrom) { var affectedObjects = new List(); affectedObjects.AddRange(UpdateStochasticSoilModel(soilModelToUpdate, soilModelToUpdateFrom)); return affectedObjects; } private IEnumerable UpdateStochasticSoilModel(StochasticSoilModel modelToUpdate, StochasticSoilModel modelToUpdateFrom) { Dictionary oldProfiles = modelToUpdate .StochasticSoilProfiles .ToDictionary(ssp => ssp, ssp => ssp.SoilProfile, new ReferenceEqualityComparer()); StochasticSoilModelProfileDifference difference = modelToUpdate.Update(modelToUpdateFrom); var affectedObjects = new List { modelToUpdate }; foreach (StochasticSoilProfile removedProfile in difference.RemovedProfiles) { affectedObjects.AddRange(PipingDataSynchronizationService.RemoveStochasticSoilProfileFromInput(failureMechanism, removedProfile)); } foreach (StochasticSoilProfile updatedProfile in difference.UpdatedProfiles) { if (!oldProfiles[updatedProfile].Equals(updatedProfile.SoilProfile)) { affectedObjects.AddRange(PipingDataSynchronizationService.ClearStochasticSoilProfileDependentData(failureMechanism, updatedProfile)); } affectedObjects.Add(updatedProfile); } return affectedObjects; } #endregion #region Remove Data Functions protected override IEnumerable RemoveObjectAndDependentData(StochasticSoilModel removedModel) { return PipingDataSynchronizationService.RemoveStochasticSoilModel(failureMechanism, removedModel); } #endregion } }