https://gitlab.opengeosys.org/ogs/ogs.git
Revision 5fb81f1b5734b20769b5a8accccf6a4ef93a1aba authored by Tao_You on 11 November 2023, 10:23:52 UTC, committed by Tao_You on 11 November 2023, 10:23:52 UTC
Timeloop: Bind processes

See merge request ogs/ogs!4724
2 parent s 94d1231 + 49cf561
Raw File
Tip revision: 5fb81f1b5734b20769b5a8accccf6a4ef93a1aba authored by Tao_You on 11 November 2023, 10:23:52 UTC
Merge branch 'timeloop_local_solution' into 'master'
Tip revision: 5fb81f1
PolygonWithSegmentMarker.cpp
/**
 * \file
 * \copyright
 * Copyright (c) 2012-2023, OpenGeoSys Community (http://www.opengeosys.org)
 *            Distributed under a Modified BSD License.
 *              See accompanying file LICENSE.txt or
 *              http://www.opengeosys.org/project/license
 */

#include "PolygonWithSegmentMarker.h"

namespace GeoLib
{
PolygonWithSegmentMarker::PolygonWithSegmentMarker(
    GeoLib::Polyline const& polyline)
    : GeoLib::Polygon(polyline, true),
      _marker(polyline.getNumberOfPoints(), false)
{
}

void PolygonWithSegmentMarker::markSegment(std::size_t seg_num, bool mark_val)
{
    _marker[seg_num] = mark_val;
}

bool PolygonWithSegmentMarker::isSegmentMarked(std::size_t seg_num) const
{
    return _marker[seg_num];
}

bool PolygonWithSegmentMarker::addPoint(std::size_t pnt_id)
{
    if (Polyline::addPoint(pnt_id))
    {
        _marker.push_back(false);
        return true;
    }
    return false;
}

bool PolygonWithSegmentMarker::insertPoint(std::size_t pos, std::size_t pnt_id)
{
    if (Polyline::insertPoint(pos, pnt_id))
    {
        _marker.insert(_marker.begin() + pos, _marker[pos]);
        return true;
    }
    return false;
}

}  // namespace GeoLib
back to top