// 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;
}
}
}