dust3d/thirdparty/cgal/CGAL-5.1/include/CGAL/Meshes/Double_map_container.h

88 lines
2.0 KiB
C++

// Copyright (c) 2004-2005 INRIA Sophia-Antipolis (France).
// All rights reserved.
//
// This file is part of CGAL (www.cgal.org)
//
// $URL: https://github.com/CGAL/cgal/blob/v5.1/Mesher_level/include/CGAL/Meshes/Double_map_container.h $
// $Id: Double_map_container.h 0779373 2020-03-26T13:31:46+01:00 Sébastien Loriot
// SPDX-License-Identifier: LGPL-3.0-or-later OR LicenseRef-Commercial
//
//
// Author(s) : Laurent RINEAU
#ifndef CGAL_MESHES_DOUBLE_MAP_CONTAINER_H
#define CGAL_MESHES_DOUBLE_MAP_CONTAINER_H
#include <set>
#include <iostream>
#include <CGAL/Double_map.h>
// backward compatibility
#ifdef CGAL_MESH_3_DEBUG_DOUBLE_MAP
# define CGAL_MESHES_DEBUG_DOUBLE_MAP CGAL_MESH_3_DEBUG_DOUBLE_MAP
#endif
namespace CGAL {
namespace Meshes {
template <typename Elt, class Quality>
class Double_map_container
{
public:
typedef Elt Element;
protected:
// --- protected datas ---
Double_map<Element, Quality> m;
public:
bool no_longer_element_to_refine_impl() const
{
return m.empty();
}
Element get_next_element_impl()
{
CGAL_assertion(!m.empty());
#if CGAL_MESHES_DEBUG_DOUBLE_MAP
std::cerr << "get_next_element_impl(" << &*(m.front()->second)
<< ")\n";
#endif
return m.front()->second;
}
void add_bad_element(const Element& e, const Quality& q)
{
#if CGAL_MESHES_DEBUG_DOUBLE_MAP
std::cerr << "add_bad_element(" << &*e << ")\n";
#endif
m.insert(e, q);
}
void pop_next_element_impl()
{
m.pop_front();
}
void remove_element(const Element& e)
{
#if CGAL_MESHES_DEBUG_DOUBLE_MAP
std::cerr << "remove_element(" << &*e << ")\n";
#endif
m.erase(e);
}
typename Double_map<Element, Quality>::size_type
size() const
{
return m.size();
}
}; // end Double_map_container
} // end namespace Meshes
} // end namespace CGAL
#endif // CGAL_MESHES_DOUBLE_MAP_CONTAINER_H