// 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 Ringtoets.Common.Data.DikeProfiles;
using Ringtoets.Common.Data.UpdateDataStrategies;
using Ringtoets.Common.IO.FileImporters;
using Ringtoets.Common.Service;
using Ringtoets.GrassCoverErosionInwards.Data;
using Ringtoets.GrassCoverErosionInwards.Service;
using Ringtoets.GrassCoverErosionInwards.Util;
namespace Ringtoets.GrassCoverErosionInwards.Plugin.FileImporters
{
///
/// An for updating
/// dike profiles based on imported data.
///
public class GrassCoverErosionInwardsDikeProfileUpdateDataStrategy
: UpdateDataStrategyBase,
IDikeProfileUpdateDataStrategy
{
///
/// Creates a new instance of .
///
/// The failure mechanism in which the dike profiles are updated.
/// Thrown when
/// is null.
public GrassCoverErosionInwardsDikeProfileUpdateDataStrategy(GrassCoverErosionInwardsFailureMechanism failureMechanism)
: base(failureMechanism, failureMechanism?.DikeProfiles, new DikeProfileIdEqualityComparer()) {}
public IEnumerable UpdateDikeProfilesWithImportedData(IEnumerable importedDataCollection, string sourceFilePath)
{
return UpdateTargetCollectionData(importedDataCollection, sourceFilePath);
}
protected override IEnumerable RemoveObjectAndDependentData(DikeProfile removedObject)
{
return GrassCoverErosionInwardsDataSynchronizationService.RemoveDikeProfile(
removedObject,
FailureMechanism.Calculations.Cast(),
FailureMechanism.DikeProfiles,
FailureMechanism.SectionResults);
}
private IEnumerable GetAffectedCalculationsWithDikeProfile(DikeProfile objectToUpdate)
{
IEnumerable affectedCalculations =
FailureMechanism.Calculations
.Cast()
.Where(calc => ReferenceEquals(objectToUpdate, calc.InputParameters.DikeProfile));
return affectedCalculations;
}
///
/// Class for comparing the only by ID.
///
private class DikeProfileIdEqualityComparer : IEqualityComparer
{
public bool Equals(DikeProfile x, DikeProfile y)
{
return x.Id == y.Id;
}
public int GetHashCode(DikeProfile obj)
{
return obj.Id.GetHashCode();
}
}
#region Update logic
protected override IEnumerable UpdateObjectAndDependentData(DikeProfile objectToUpdate, DikeProfile objectToUpdateFrom)
{
objectToUpdate.CopyProperties(objectToUpdateFrom);
var affectedObjects = new List();
affectedObjects.AddRange(UpdateDikeDependentData(objectToUpdate));
return affectedObjects;
}
private IEnumerable UpdateDikeDependentData(DikeProfile objectToUpdate)
{
var affectedObjects = new List();
foreach (GrassCoverErosionInwardsCalculation calculation in GetAffectedCalculationsWithDikeProfile(objectToUpdate))
{
affectedObjects.Add(calculation.InputParameters);
affectedObjects.AddRange(RingtoetsCommonDataSynchronizationService.ClearCalculationOutput(calculation));
if (!objectToUpdate.ForeshoreGeometry.Any())
{
calculation.InputParameters.UseForeshore = false;
}
}
affectedObjects.AddRange(GrassCoverErosionInwardsHelper.UpdateCalculationToSectionResultAssignments(
FailureMechanism.SectionResults,
FailureMechanism.Calculations.Cast()));
return affectedObjects;
}
#endregion
}
}