// Copyright (c) 1997-2000 Max-Planck-Institute Saarbruecken (Germany). // All rights reserved. // // This file is part of CGAL (www.cgal.org). // 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. // // Licensees holding a valid commercial license may use this file in // accordance with the commercial license agreement provided with the software. // // This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE // WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. // // $URL$ // $Id$ // SPDX-License-Identifier: GPL-3.0+ // // // Author(s) : Michael Seel #ifndef CGAL_NEF_2_OBJECT_INDEX_H #define CGAL_NEF_2_OBJECT_INDEX_H #include #include #include #include #include namespace CGAL { template class Object_index { char _prefix; CGAL::Unique_hash_map _index; public: Object_index() : _prefix('\0'), _index(-1) {} Object_index(I first, I beyond, char c=' ') : _prefix(c), _index(-1) { for(int i=0 ; first!=beyond; ++i,++first) _index[first]=i; } int operator[](const I& it) const { return _index[it]; } int& operator[](const I& it) { return _index[it]; } void index(I first, I beyond, char c=' ') { _prefix=c; for(int i=0 ; first!=beyond; ++i,++first) _index[first]=i; } std::string operator()(const I& it, bool verbose=true) const { if (verbose && _index[it]==-1) return "nil"; if (verbose && _index[it]==-2) return "end"; std::ostringstream os; if (verbose) os << _prefix; os << _index[it]; return os.str(); } }; } //namespace CGAL #endif //CGAL_NEF_2_OBJECT_INDEX_H