// Copyright (C) Stichting Deltares 2024. All rights reserved.
//
// This file is part of the Dam Engine.
//
// The Dam Engine is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero 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 Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero 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.Collections.Generic;
using System.Linq;
using Deltares.DamEngine.Data.General;
using Deltares.DamEngine.Data.General.PlLines;
namespace Deltares.DamEngine.Calculators.PlLinesCreator;
///
/// This class is responsible for creating a PL line where the coordinates are sorted on x.
/// No logic will be applied on how the PL is constructed. Just a simple data structure with an
/// insert method to insert new points.
///
internal class PlLineConstructor
{
readonly IDictionary line = new SortedDictionary();
///
/// Inserts the specified point.
///
/// The point will be inserted in the line based on the X value
/// The point.
public void Insert(PlLinePoint point)
{
if (line.ContainsKey(point.X))
{
line[point.X] = point;
}
else
{
line.Add(point.X, point);
}
}
///
/// Inserts the specified point.
///
/// The point will be inserted in the line based on the X value
/// The x.
/// The z.
public void Insert(double x, double z)
{
Insert(new PlLinePoint(x, z));
}
public double GetLastZ()
{
return line[line.Keys.Max()].Z;
}
///
/// Gets the PL line from the internal constructed line.
///
public PlLine CreatePlLine(PlLineType type)
{
var plLine = new PlLine
{
PlLineType = type
};
foreach (KeyValuePair kvp in line)
{
plLine.Points.Add(kvp.Value);
}
return plLine;
}
}