// 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.Collections.ObjectModel;
using System.Linq;
using Core.Common.Utils.Extensions;
using Ringtoets.StabilityPointStructures.Data;
using Ringtoets.Common.Data.Structures;
using Ringtoets.HydraRing.Data;
namespace Ringtoets.StabilityPointStructures.Service
{
///
/// Service for synchronizing stability point structures data.
///
public static class StabilityPointStructuresDataSynchronizationService
{
///
/// Clears the output for all calculations in the .
///
/// The
/// which contains the calculations.
/// An of calculations which are affected by
/// clearing the output.
/// Thrown when
/// is null.
public static IEnumerable> ClearAllCalculationOutput(StabilityPointStructuresFailureMechanism failureMechanism)
{
if (failureMechanism == null)
{
throw new ArgumentNullException("failureMechanism");
}
var affectedItems = failureMechanism.Calculations
.Cast>()
.Where(c => c.HasOutput)
.ToArray();
affectedItems.ForEachElementDo(item => item.ClearOutput());
return affectedItems;
}
///
/// Clears the and output for all the calculations
/// in the .
///
/// The
/// which contains the calculations.
/// An of calculations which are affected by
/// removing data.
/// Thrown when
/// is null.
public static IEnumerable> ClearAllCalculationOutputAndHydraulicBoundaryLocations(StabilityPointStructuresFailureMechanism failureMechanism)
{
if (failureMechanism == null)
{
throw new ArgumentNullException("failureMechanism");
}
var affectedItems = new Collection>();
foreach (var calculation in failureMechanism.Calculations.Cast>())
{
var calculationChanged = false;
if (calculation.HasOutput)
{
calculation.ClearOutput();
calculationChanged = true;
}
if (calculation.InputParameters.HydraulicBoundaryLocation != null)
{
ClearHydraulicBoundaryLocation(calculation);
calculationChanged = true;
}
if (calculationChanged)
{
affectedItems.Add(calculation);
}
}
return affectedItems;
}
private static void ClearHydraulicBoundaryLocation(StructuresCalculation calculation)
{
calculation.InputParameters.HydraulicBoundaryLocation = null;
}
}
}