dust3d/thirdparty/cgal/CGAL-5.1/include/CGAL/HalfedgeDS_halfedge_base.h

331 lines
13 KiB
C++

// Copyright (c) 1997
// Utrecht University (The Netherlands),
// ETH Zurich (Switzerland),
// INRIA Sophia-Antipolis (France),
// Max-Planck-Institute Saarbruecken (Germany),
// and Tel-Aviv University (Israel). All rights reserved.
//
// This file is part of CGAL (www.cgal.org)
//
// $URL: https://github.com/CGAL/cgal/blob/v5.1/HalfedgeDS/include/CGAL/HalfedgeDS_halfedge_base.h $
// $Id: HalfedgeDS_halfedge_base.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) : Lutz Kettner <kettner@mpi-sb.mpg.de>
#ifndef CGAL_HALFEDGEDS_HALFEDGE_BASE_H
#define CGAL_HALFEDGEDS_HALFEDGE_BASE_H 1
#include <CGAL/basic.h>
namespace CGAL {
template < class Refs, class TP, class TV, class TF>
struct HalfedgeDS_halfedge_base_base {
// Base_base will be used to access set_opposite(), which is
// made private in the normal halfedge bases. Since halfedges
// come always in pairs, managed by the HDS, the set_opposite()
// member function is protected from the user.
typedef Refs HalfedgeDS;
typedef HalfedgeDS_halfedge_base_base<Refs,TP,TV,TF> Base_base;
typedef TP Supports_halfedge_prev;
typedef TV Supports_halfedge_vertex;
typedef TF Supports_halfedge_face;
typedef typename Refs::Vertex_handle Vertex_handle;
typedef typename Refs::Vertex_const_handle Vertex_const_handle;
typedef typename Refs::Halfedge_handle Halfedge_handle;
typedef typename Refs::Halfedge_const_handle Halfedge_const_handle;
typedef typename Refs::Face_handle Face_handle;
typedef typename Refs::Face_const_handle Face_const_handle;
typedef typename Refs::Vertex Vertex;
typedef typename Refs::Face Face;
private:
Halfedge_handle opp;
Halfedge_handle nxt;
public:
Halfedge_handle opposite() { return opp;}
Halfedge_const_handle opposite() const { return opp;}
void set_opposite( Halfedge_handle h) { opp = h;}
Halfedge_handle next() { return nxt;}
Halfedge_const_handle next() const { return nxt;}
void set_next( Halfedge_handle h) { nxt = h;}
bool is_border() const { return false;}
// is always false as long as faces are not supported.
};
template < class Refs, class TP = Tag_true,
class TV = Tag_true,
class TF = Tag_true>
class HalfedgeDS_halfedge_base;
template < class Refs >
class HalfedgeDS_halfedge_base< Refs,
Tag_false, // prev
Tag_false, // vertex
Tag_false> // face
: public HalfedgeDS_halfedge_base_base<
Refs, Tag_false, Tag_false, Tag_false>
{
public:
typedef typename Refs::Halfedge_handle Halfedge_handle;
typedef HalfedgeDS_halfedge_base<Refs, Tag_false,Tag_false,Tag_false>
Base;
typedef HalfedgeDS_halfedge_base_base<Refs, Tag_false,Tag_false,Tag_false>
Base_base;
private:
void set_opposite( Halfedge_handle h) { Base_base::set_opposite(h);}
};
template < class Refs >
class HalfedgeDS_halfedge_base< Refs,
Tag_true, // prev
Tag_false, // vertex
Tag_false> // face
: public HalfedgeDS_halfedge_base_base<
Refs, Tag_true, Tag_false, Tag_false>
{
public:
typedef typename Refs::Halfedge_handle Halfedge_handle;
typedef typename Refs::Halfedge_const_handle Halfedge_const_handle;
typedef HalfedgeDS_halfedge_base<Refs, Tag_true,Tag_false,Tag_false>
Base;
typedef HalfedgeDS_halfedge_base_base<Refs, Tag_true,Tag_false,Tag_false>
Base_base;
private:
void set_opposite( Halfedge_handle h) { Base_base::set_opposite(h);}
Halfedge_handle prv;
public:
// the previous halfedge along the face.
Halfedge_handle prev() { return prv; }
Halfedge_const_handle prev() const { return prv; }
void set_prev( Halfedge_handle h) { prv = h; }
};
template < class Refs >
class HalfedgeDS_halfedge_base< Refs,
Tag_false, // prev
Tag_true, // vertex
Tag_false> // face
: public HalfedgeDS_halfedge_base_base<
Refs, Tag_false, Tag_true, Tag_false>
{
public:
typedef typename Refs::Halfedge_handle Halfedge_handle;
typedef typename Refs::Vertex_handle Vertex_handle;
typedef typename Refs::Vertex_const_handle Vertex_const_handle;
typedef HalfedgeDS_halfedge_base<Refs, Tag_false,Tag_true,Tag_false>
Base;
typedef HalfedgeDS_halfedge_base_base<Refs, Tag_false,Tag_true,Tag_false>
Base_base;
private:
void set_opposite( Halfedge_handle h) { Base_base::set_opposite(h);}
Vertex_handle v;
public:
// the incident vertex.
Vertex_handle vertex() { return v; }
Vertex_const_handle vertex() const { return v; }
void set_vertex( Vertex_handle w) { v = w; }
};
template < class Refs >
class HalfedgeDS_halfedge_base< Refs,
Tag_false, // prev
Tag_false, // vertex
Tag_true> // face
: public HalfedgeDS_halfedge_base_base<
Refs, Tag_false, Tag_false, Tag_true>
{
public:
typedef typename Refs::Halfedge_handle Halfedge_handle;
typedef typename Refs::Face_handle Face_handle;
typedef typename Refs::Face_const_handle Face_const_handle;
typedef HalfedgeDS_halfedge_base<Refs, Tag_false,Tag_false,Tag_true>
Base;
typedef HalfedgeDS_halfedge_base_base<Refs, Tag_false,Tag_false,Tag_true>
Base_base;
private:
void set_opposite( Halfedge_handle h) { Base_base::set_opposite(h);}
Face_handle f;
public:
// Explicit initialization of f to denote border halfedges
// is needed if Face_handle is a C style pointer.
HalfedgeDS_halfedge_base() : f( Face_handle()) {}
// the face to the left.
Face_handle face() { return f; }
Face_const_handle face() const { return f; }
void set_face( Face_handle g) { f = g; }
bool is_border() const { return f == Face_handle();}
// is true if `h' is a border halfedge.
};
template < class Refs >
class HalfedgeDS_halfedge_base< Refs,
Tag_true, // prev
Tag_true, // vertex
Tag_false> // face
: public HalfedgeDS_halfedge_base_base<
Refs, Tag_true, Tag_true, Tag_false>
{
public:
typedef typename Refs::Halfedge_handle Halfedge_handle;
typedef typename Refs::Halfedge_const_handle Halfedge_const_handle;
typedef typename Refs::Vertex_handle Vertex_handle;
typedef typename Refs::Vertex_const_handle Vertex_const_handle;
typedef HalfedgeDS_halfedge_base<Refs, Tag_true,Tag_true,Tag_false>
Base;
typedef HalfedgeDS_halfedge_base_base<Refs, Tag_true,Tag_true,Tag_false>
Base_base;
private:
void set_opposite( Halfedge_handle h) { Base_base::set_opposite(h);}
Halfedge_handle prv;
Vertex_handle v;
public:
// the previous halfedge along the face.
Halfedge_handle prev() { return prv; }
Halfedge_const_handle prev() const { return prv; }
void set_prev( Halfedge_handle h) { prv = h; }
// the incident vertex.
Vertex_handle vertex() { return v; }
Vertex_const_handle vertex() const { return v; }
void set_vertex( Vertex_handle w) { v = w; }
};
template < class Refs >
class HalfedgeDS_halfedge_base< Refs,
Tag_true, // prev
Tag_false, // vertex
Tag_true> // face
: public HalfedgeDS_halfedge_base_base<
Refs, Tag_true, Tag_false, Tag_true>
{
public:
typedef typename Refs::Halfedge_handle Halfedge_handle;
typedef typename Refs::Halfedge_const_handle Halfedge_const_handle;
typedef typename Refs::Face_handle Face_handle;
typedef typename Refs::Face_const_handle Face_const_handle;
typedef HalfedgeDS_halfedge_base<Refs, Tag_true,Tag_false,Tag_true>
Base;
typedef HalfedgeDS_halfedge_base_base<Refs, Tag_true,Tag_false,Tag_true>
Base_base;
private:
void set_opposite( Halfedge_handle h) { Base_base::set_opposite(h);}
Halfedge_handle prv;
Face_handle f;
public:
// Explicit initialization of f to denote border halfedges
// is needed if Face_handle is a C style pointer.
HalfedgeDS_halfedge_base() : f( Face_handle()) {}
// the previous halfedge along the face.
Halfedge_handle prev() { return prv; }
Halfedge_const_handle prev() const { return prv; }
void set_prev( Halfedge_handle h) { prv = h; }
// the face to the left.
Face_handle face() { return f; }
Face_const_handle face() const { return f; }
void set_face( Face_handle g) { f = g; }
bool is_border() const { return f == Face_handle();}
// is true if `h' is a border halfedge.
};
template < class Refs >
class HalfedgeDS_halfedge_base< Refs,
Tag_false, // prev
Tag_true, // vertex
Tag_true> // face
: public HalfedgeDS_halfedge_base_base<
Refs, Tag_false, Tag_true, Tag_true>
{
public:
typedef typename Refs::Halfedge_handle Halfedge_handle;
typedef typename Refs::Vertex_handle Vertex_handle;
typedef typename Refs::Vertex_const_handle Vertex_const_handle;
typedef typename Refs::Face_handle Face_handle;
typedef typename Refs::Face_const_handle Face_const_handle;
typedef HalfedgeDS_halfedge_base<Refs, Tag_false,Tag_true,Tag_true>
Base;
typedef HalfedgeDS_halfedge_base_base<Refs, Tag_false,Tag_true,Tag_true>
Base_base;
private:
void set_opposite( Halfedge_handle h) { Base_base::set_opposite(h);}
Vertex_handle v;
Face_handle f;
public:
// Explicit initialization of f to denote border halfedges
// is needed if Face_handle is a C style pointer.
HalfedgeDS_halfedge_base() : f( Face_handle()) {}
// the incident vertex.
Vertex_handle vertex() { return v; }
Vertex_const_handle vertex() const { return v; }
void set_vertex( Vertex_handle w) { v = w; }
// the face to the left.
Face_handle face() { return f; }
Face_const_handle face() const { return f; }
void set_face( Face_handle g) { f = g; }
bool is_border() const { return f == Face_handle();}
// is true if `h' is a border halfedge.
};
template < class Refs >
class HalfedgeDS_halfedge_base< Refs,
Tag_true, // prev
Tag_true, // vertex
Tag_true> // face
: public HalfedgeDS_halfedge_base_base<
Refs, Tag_true, Tag_true, Tag_true>
{
public:
typedef typename Refs::Halfedge_handle Halfedge_handle;
typedef typename Refs::Halfedge_const_handle Halfedge_const_handle;
typedef typename Refs::Vertex_handle Vertex_handle;
typedef typename Refs::Vertex_const_handle Vertex_const_handle;
typedef typename Refs::Face_handle Face_handle;
typedef typename Refs::Face_const_handle Face_const_handle;
typedef HalfedgeDS_halfedge_base<Refs, Tag_true,Tag_true,Tag_true>
Base;
typedef HalfedgeDS_halfedge_base_base<Refs, Tag_true,Tag_true,Tag_true>
Base_base;
private:
void set_opposite( Halfedge_handle h) { Base_base::set_opposite(h);}
Halfedge_handle prv;
Vertex_handle v;
Face_handle f;
public:
// Explicit initialization of f to denote border halfedges
// is needed if Face_handle is a C style pointer.
HalfedgeDS_halfedge_base() : f( Face_handle()) {}
// the previous halfedge along the face.
Halfedge_handle prev() { return prv; }
Halfedge_const_handle prev() const { return prv; }
void set_prev( Halfedge_handle h) { prv = h; }
// the incident vertex.
Vertex_handle vertex() { return v; }
Vertex_const_handle vertex() const { return v; }
void set_vertex( Vertex_handle w) { v = w; }
// the face to the left.
Face_handle face() { return f; }
Face_const_handle face() const { return f; }
void set_face( Face_handle g) { f = g; }
bool is_border() const { return f == Face_handle();}
// is true if `h' is a border halfedge.
};
} //namespace CGAL
#endif // CGAL_HALFEDGEDS_HALFEDGE_BASE_H //
// EOF //