// 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 #include #include // 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 class Double_map_container { public: typedef Elt Element; protected: // --- protected datas --- Double_map 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::size_type size() const { return m.size(); } }; // end Double_map_container } // end namespace Meshes } // end namespace CGAL #endif // CGAL_MESHES_DOUBLE_MAP_CONTAINER_H