📄 shalfloop.h
字号:
// Copyright (c) 1997-2002 Max-Planck-Institute Saarbruecken (Germany).// All rights reserved.//// This file is part of CGAL (www.cgal.org); you may redistribute it under// the terms of the Q Public License version 1.0.// See the file LICENSE.QPL distributed with CGAL.//// 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: svn+ssh://hachenb@scm.gforge.inria.fr/svn/cgal/branches/Filtered_Nef/Nef_3/include/CGAL/Nef_3/SHalfloop.h $// $Id: SHalfloop.h 35450 2006-12-06 10:43:20Z hachenb $// //// Author(s) : Michael Seel <seel@mpi-sb.mpg.de>// Miguel Granados <granados@mpi-sb.mpg.de>// Susan Hert <hert@mpi-sb.mpg.de>// Lutz Kettner <kettner@mpi-sb.mpg.de>// Peter Hachenberger <hachenberger@mpi-sb.mpg.de>#ifndef CGAL_NEF_SHALFLOOP_H#define CGAL_NEF_SHALFLOOP_H#include <string>#include <sstream>#include <CGAL/IO/Verbose_ostream.h>#include <CGAL/Nef_3/SNC_iteration.h>#undef CGAL_NEF_DEBUG#define CGAL_NEF_DEBUG 83#include <CGAL/Nef_2/debug.h>CGAL_BEGIN_NAMESPACEtemplate <typename Refs> class SHalfloop_base { typedef void* GenPtr; typedef typename Refs::Mark Mark; typedef typename Refs::Sphere_circle Sphere_circle; typedef typename Refs::SHalfloop_handle SHalfloop_handle; typedef typename Refs::SHalfloop_const_handle SHalfloop_const_handle; typedef typename Refs::SFace_handle SFace_handle; typedef typename Refs::SFace_const_handle SFace_const_handle; typedef typename Refs::Halffacet_handle Halffacet_handle; typedef typename Refs::Halffacet_const_handle Halffacet_const_handle; SHalfloop_handle twin_; SFace_handle incident_sface_; Halffacet_handle facet_; GenPtr info_; // temporary needed: Mark mark_; Sphere_circle circle_; public: SHalfloop_base() : twin_(), incident_sface_(), facet_(), info_(), mark_(), circle_() {} ~SHalfloop_base() { CGAL_NEF_TRACEN(" destroying SHalfloop_base item "<<&*this); } SHalfloop_base(const SHalfloop_base<Refs>& l) { twin_ = l.twin_; incident_sface_ = l.incident_sface_; facet_ = l.facet_; info_ = 0; mark_ = l.mark_; circle_ = l.circle_; } SHalfloop_base<Refs>& operator=(const SHalfloop_base<Refs>& l) { twin_ = l.twin_; incident_sface_ = l.incident_sface_; facet_ = l.facet_; info_ = 0; mark_ = l.mark_; circle_ = l.circle_; return *this; } Mark& mark() { return mark_;} const Mark& mark() const { return mark_; } SHalfloop_handle& twin() { return twin_; } SHalfloop_const_handle twin() const { return twin_; } Sphere_circle& circle() { return circle_; } const Sphere_circle& circle() const { return circle_; } SFace_handle& incident_sface() { return incident_sface_; } SFace_const_handle incident_sface() const { return incident_sface_; } Halffacet_handle& facet() { return facet_; } Halffacet_const_handle facet() const { return facet_; } GenPtr& info() { return info_; } const GenPtr& info() const { return info_; } public: std::string debug() const { std::stringstream os; set_pretty_mode(os); os<<"sl [ "<<circle_<<" ] "; return os.str(); } 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<...>::SHalfloop_base::is_valid( verb=true, " "level = " << level << "):" << std::endl; bool valid = (twin_ != SHalfloop_handle() && twin_ != NULL); valid = valid && (incident_sface_ != SFace_handle() && incident_sface_ != NULL); valid = valid && (facet_ != Halffacet_handle() && facet_ != NULL); valid = valid && (circle_.d() == 0); valid = valid && (circle_.a() != 0 || circle_.b() != 0 || circle_.c() !=0); verr << "end of CGAL::SNC_items<...>::SHalfloop_base::is_valid(): structure is " << ( valid ? "valid." : "NOT VALID.") << std::endl; return valid; }}; // SHalfloop_baseCGAL_END_NAMESPACE#endif //CGAL_NEF_SHALFLOOP_H
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -