// 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.Globalization;
using System.Xml;
using Core.Common.Base.Data;
using Core.Common.IO.Exceptions;
using Ringtoets.Common.Data.Calculation;
using Ringtoets.Common.Data.Probabilistics;
using Ringtoets.Piping.Data;
using Ringtoets.Piping.IO.Schema;
using CoreCommonUtilsResources = Core.Common.Utils.Properties.Resources;
namespace Ringtoets.Piping.IO.Exporters
{
///
/// Writer for writing a piping configuration to XML.
///
internal static class PipingConfigurationWriter
{
///
/// Writes a piping configuration to a XML file.
///
/// The root calculation group containing the piping configuration to write.
/// The path to the target XML file.
/// Thrown when any parameter is null.
/// Thrown when unable to write to .
/// The itself will not be part of the written XML, only its children.
internal static void Write(CalculationGroup rootCalculationGroup, string filePath)
{
if (rootCalculationGroup == null)
{
throw new ArgumentNullException(nameof(rootCalculationGroup));
}
if (filePath == null)
{
throw new ArgumentNullException(nameof(filePath));
}
try
{
var settings = new XmlWriterSettings
{
Indent = true,
IndentChars = "\t"
};
using (XmlWriter writer = XmlWriter.Create(filePath, settings))
{
writer.WriteStartDocument();
writer.WriteStartElement(PipingConfigurationSchemaIdentifiers.RootElement);
WriteConfiguration(rootCalculationGroup, writer);
writer.WriteEndElement();
writer.WriteEndDocument();
}
}
catch (SystemException e)
{
throw new CriticalFileWriteException(string.Format(CoreCommonUtilsResources.Error_General_output_error_0, filePath), e);
}
}
private static void WriteConfiguration(CalculationGroup calculationGroup, XmlWriter writer)
{
foreach (ICalculationBase child in calculationGroup.Children)
{
var innerGroup = child as CalculationGroup;
if (innerGroup != null)
{
WriteCalculationGroup(innerGroup, writer);
}
var calculation = child as PipingCalculation;
if (calculation != null)
{
WriteCalculation(calculation, writer);
}
}
}
private static void WriteCalculationGroup(CalculationGroup calculationGroup, XmlWriter writer)
{
writer.WriteStartElement(PipingConfigurationSchemaIdentifiers.FolderElement);
writer.WriteAttributeString(PipingConfigurationSchemaIdentifiers.NameAttribute, calculationGroup.Name);
WriteConfiguration(calculationGroup, writer);
writer.WriteEndElement();
}
private static void WriteCalculation(PipingCalculation calculation, XmlWriter writer)
{
writer.WriteStartElement(PipingConfigurationSchemaIdentifiers.CalculationElement);
writer.WriteAttributeString(PipingConfigurationSchemaIdentifiers.NameAttribute, calculation.Name);
PipingInput calculationInputParameters = calculation.InputParameters;
if (calculationInputParameters.UseAssessmentLevelManualInput)
{
writer.WriteElementString(PipingConfigurationSchemaIdentifiers.AssessmentLevelElement,
ToStringInvariantCulture(calculationInputParameters.AssessmentLevel));
}
else if (calculationInputParameters.HydraulicBoundaryLocation != null)
{
writer.WriteElementString(PipingConfigurationSchemaIdentifiers.HydraulicBoundaryLocationElement,
calculationInputParameters.HydraulicBoundaryLocation.Name);
}
if (calculationInputParameters.SurfaceLine != null)
{
writer.WriteElementString(PipingConfigurationSchemaIdentifiers.SurfaceLineElement,
calculationInputParameters.SurfaceLine.Name);
writer.WriteElementString(PipingConfigurationSchemaIdentifiers.EntryPointElement,
ToStringInvariantCulture(calculationInputParameters.EntryPointL));
writer.WriteElementString(PipingConfigurationSchemaIdentifiers.ExitPointElement,
ToStringInvariantCulture(calculationInputParameters.ExitPointL));
}
if (calculationInputParameters.StochasticSoilModel != null)
{
writer.WriteElementString(PipingConfigurationSchemaIdentifiers.StochasticSoilModelElement,
calculationInputParameters.StochasticSoilModel.Name);
if (calculationInputParameters.StochasticSoilProfile?.SoilProfile != null)
{
writer.WriteElementString(PipingConfigurationSchemaIdentifiers.StochasticSoilProfileElement,
calculationInputParameters.StochasticSoilProfile.SoilProfile.Name);
}
}
WriteDistributions(calculationInputParameters, writer);
writer.WriteEndElement();
}
private static void WriteDistributions(PipingInput calculationInputParameters, XmlWriter writer)
{
writer.WriteStartElement(PipingConfigurationSchemaIdentifiers.StochastsElement);
WriteDistribution(calculationInputParameters.PhreaticLevelExit,
PipingConfigurationSchemaIdentifiers.PhreaticLevelExitStochastName, writer);
WriteDistribution(calculationInputParameters.DampingFactorExit,
PipingConfigurationSchemaIdentifiers.DampingFactorExitStochastName, writer);
writer.WriteEndElement();
}
private static void WriteDistribution(IDistribution distribution, string elementName, XmlWriter writer)
{
writer.WriteStartElement(PipingConfigurationSchemaIdentifiers.StochastElement);
writer.WriteAttributeString(PipingConfigurationSchemaIdentifiers.NameAttribute, elementName);
writer.WriteElementString(PipingConfigurationSchemaIdentifiers.MeanElement,
ToStringInvariantCulture(distribution.Mean));
writer.WriteElementString(PipingConfigurationSchemaIdentifiers.StandardDeviationElement,
ToStringInvariantCulture(distribution.StandardDeviation));
writer.WriteEndElement();
}
private static string ToStringInvariantCulture(RoundedDouble roundedDouble)
{
return roundedDouble.ToString(null, CultureInfo.InvariantCulture);
}
}
}