// 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 Application.Ringtoets.Storage.Create; using Application.Ringtoets.Storage.Create.Piping; using Application.Ringtoets.Storage.DbContext; using Application.Ringtoets.Storage.Exceptions; using Core.Common.Base.Geometry; using Ringtoets.Piping.Data; namespace Application.Ringtoets.Storage.Update.Piping { /// /// Extension methods for related to updating a . /// internal static class StochasticSoilModelUpdateExtensions { /// /// Updates a in the database based on the information of the /// . /// /// The model to update the database entity for. /// The object keeping track of update operations. /// The context to obtain the existing entity from. /// Thrown when either: /// /// is null /// is null /// /// When /// does not have a corresponding entity in the database. internal static void Update(this StochasticSoilModel model, PersistenceRegistry registry, IRingtoetsEntities context) { if (context == null) { throw new ArgumentNullException("context"); } if (registry == null) { throw new ArgumentNullException("registry"); } StochasticSoilModelEntity entity = model.GetCorrespondingEntity( context.StochasticSoilModelEntities, o => o.StochasticSoilModelEntityId); entity.Name = model.Name; entity.SegmentName = model.SegmentName; UpdateStochasticSoilProfiles(model, entity, registry, context); UpdateSoilModelSegment(model, entity); registry.Register(entity, model); } private static void UpdateStochasticSoilProfiles(StochasticSoilModel model, StochasticSoilModelEntity entity, PersistenceRegistry registry, IRingtoetsEntities context) { foreach (var stochasticSoilProfile in model.StochasticSoilProfiles) { if (stochasticSoilProfile.IsNew()) { entity.StochasticSoilProfileEntities.Add(stochasticSoilProfile.Create(registry)); } else { stochasticSoilProfile.Update(registry, context); } } } private static void UpdateSoilModelSegment(StochasticSoilModel model, StochasticSoilModelEntity entity) { if (HasChanges(entity.StochasticSoilModelSegmentPointEntities, model.Geometry)) { entity.StochasticSoilModelSegmentPointEntities.Clear(); UpdateSegmentPoints(model, entity); } } private static bool HasChanges(ICollection existingPointEntities, List geometry) { StochasticSoilModelSegmentPointEntity[] existingPoints = existingPointEntities.OrderBy(pe => pe.Order).ToArray(); if (existingPoints.Length != geometry.Count) { return true; } for (int i = 0; i < existingPoints.Length; i++) { Point2D existingPoint = new Point2D(existingPoints[i].X.ToNullAsNaN(), existingPoints[i].Y.ToNullAsNaN()); if (!Math2D.AreEqualPoints(existingPoint, geometry[i])) { return true; } } return false; } private static void UpdateSegmentPoints(StochasticSoilModel model, StochasticSoilModelEntity entity) { for (int i = 0; i < model.Geometry.Count; i++) { Point2D point = model.Geometry[i]; StochasticSoilModelSegmentPointEntity pointEntity = point.CreateStochasticSoilModelSegmentPointEntity(i); entity.StochasticSoilModelSegmentPointEntities.Add(pointEntity); } } } }