// Copyright (c) 1997-2002 Max-Planck-Institute Saarbruecken (Germany). // All rights reserved. // // This file is part of CGAL (www.cgal.org). // // $URL: https://github.com/CGAL/cgal/blob/v5.1/Nef_3/include/CGAL/Nef_3/Volume.h $ // $Id: Volume.h 0779373 2020-03-26T13:31:46+01:00 Sébastien Loriot // SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-Commercial // // // Author(s) : Michael Seel // Miguel Granados // Susan Hert // Lutz Kettner // Peter Hachenberger #ifndef CGAL_NEF_VOLUME_H #define CGAL_NEF_VOLUME_H #include #include #include #include #include #undef CGAL_NEF_DEBUG #define CGAL_NEF_DEBUG 83 #include namespace CGAL { template class Volume_base { typedef typename Refs::Mark Mark; typedef typename Refs::Volume_handle Volume_handle; typedef typename Refs::Volume_const_handle Volume_const_handle; typedef typename Refs::Object_list Object_list; typedef typename Refs::Shell_entry_iterator Shell_entry_iterator; typedef typename Refs::Shell_entry_const_iterator Shell_entry_const_iterator; Mark mark_; Object_list shell_entry_objects_; // SFaces public: Volume_base() {} Volume_base(Mark m) : mark_(m) {} ~Volume_base() { CGAL_NEF_TRACEN(" destroying Volume_base item "<<&*this); } Volume_base(const Volume_base& v) { mark_ = v.mark_; shell_entry_objects_ = v.shell_entry_objects_; } Volume_base& operator=(const Volume_base& v) { if (this == &v) return *this; mark_ = v.mark_; shell_entry_objects_ = v.shell_entry_objects_; return *this; } Mark& mark() { return mark_; } const Mark& mark() const { return mark_; } Object_list& shell_entry_objects() { return shell_entry_objects_; } const Object_list& shell_entry_objects() const { return shell_entry_objects_; } Shell_entry_iterator shells_begin() { return shell_entry_objects_.begin(); } Shell_entry_iterator shells_end() { return shell_entry_objects_.end(); } Shell_entry_const_iterator shells_begin() const { return shell_entry_objects_.begin(); } Shell_entry_const_iterator shells_end() const { return shell_entry_objects_.end(); } bool is_valid( bool verb = false, int level = 0) const { Verbose_ostream verr(verb); verr << "begin CGAL::SNC_items<...>::Volume_base::is_valid( verb=true, " "level = " << level << "):" << std::endl; bool valid = (!shell_entry_objects_.empty()); verr << "end of CGAL::SNC_items<...>::Volume_base::is_valid(): structure is " << ( valid ? "valid." : "NOT VALID.") << std::endl; return valid; } }; // Volume_base } //namespace CGAL #endif //CGAL_NEF_VOLUME_H