// Copyright (c) 1997-2002 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 // Miguel Granados // Susan Hert // Lutz Kettner // Peter Hachenberger #ifndef CGAL_NEF_HALFFACET_H #define CGAL_NEF_HALFFACET_H #include #include #include #include #include #undef CGAL_NEF_DEBUG #define CGAL_NEF_DEBUG 83 #include namespace CGAL { template class Halffacet_base { typedef typename Refs::Mark Mark; typedef typename Refs::Plane_3 Plane_3; typedef typename Refs::Halffacet_handle Halffacet_handle; typedef typename Refs::Halffacet_const_handle Halffacet_const_handle; 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::Halffacet_cycle_iterator Halffacet_cycle_iterator; typedef typename Refs::Halffacet_cycle_const_iterator Halffacet_cycle_const_iterator; Plane_3 supporting_plane_; Mark mark_; Halffacet_handle twin_; Volume_handle volume_; Object_list boundary_entry_objects_; // SEdges, SLoops public: Halffacet_base() : supporting_plane_(), mark_() {} Halffacet_base(const Plane_3& h, Mark m) : supporting_plane_(h), mark_(m) {} ~Halffacet_base() { CGAL_NEF_TRACEN(" destroying Halffacet_base item "<<&*this); } Halffacet_base(const Halffacet_base& f) { supporting_plane_ = f.supporting_plane_; mark_ = f.mark_; twin_ = f.twin_; CGAL_NEF_TRACEN("VOLUME const"); volume_ = f.volume_; boundary_entry_objects_ = f.boundary_entry_objects_; } Halffacet_base& operator=(const Halffacet_base& f) { if (this == &f) return *this; supporting_plane_ = f.supporting_plane_; mark_ = f.mark_; twin_ = f.twin_; CGAL_NEF_TRACEN("VOLUME op="); volume_ = f.volume_; boundary_entry_objects_ = f.boundary_entry_objects_; return *this; } Mark& mark() { return mark_; } const Mark& mark() const { return mark_; } Halffacet_handle& twin() { return twin_; } Halffacet_const_handle twin() const { return twin_; } Plane_3& plane() { return supporting_plane_; } const Plane_3& plane() const { return supporting_plane_; } Volume_handle& incident_volume() { return volume_; } Volume_const_handle incident_volume() const { return volume_; } Object_list& boundary_entry_objects() { return boundary_entry_objects_; } const Object_list& boundary_entry_objects() const { return boundary_entry_objects_; } Halffacet_cycle_iterator facet_cycles_begin() { return boundary_entry_objects_.begin(); } Halffacet_cycle_iterator facet_cycles_end() { return boundary_entry_objects_.end(); } Halffacet_cycle_const_iterator facet_cycles_begin() const { return boundary_entry_objects_.begin(); } Halffacet_cycle_const_iterator facet_cycles_end() const { return boundary_entry_objects_.end(); } bool is_twin() const { return (&*twin_ < this); } bool is_valid( bool verb = false, int level = 0) const { Verbose_ostream verr(verb); verr << "begin CGAL::SNC_items<...>::Halffacet_base::is_valid( verb=true, " "level = " << level << "):" << std::endl; bool valid = (twin_ != NULL && twin_ != Halffacet_handle()); valid = valid && (volume_ != NULL && volume_ != Volume_handle()); valid = valid && (supporting_plane_.a() != 0 || supporting_plane_.b() != 0 || supporting_plane_.c() != 0); valid = valid && (!boundary_entry_objects_.empty()); verr << "end of CGAL::SNC_items<...>::Halffacet_base::is_valid(): structure is " << ( valid ? "valid." : "NOT VALID.") << std::endl; return valid; } }; // Halffacet_base } //namespace CGAL #endif //CGAL_NEF_HALFFACET_H