dust3d/thirdparty/cgal/CGAL-4.13/include/CGAL/hash_openmesh.h

177 lines
4.0 KiB
C
Raw Normal View History

// Copyright (c) 2016 GeometryFactory (France). 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 Lesser 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: LGPL-3.0+
//
//
// Author(s) : Andreas Fabri
#ifndef CGAL_HASH_OPENMESH_H
#define CGAL_HASH_OPENMESH_H
#include <OpenMesh/Core/Mesh/Handles.hh>
#include <CGAL/algorithm.h>
namespace CGAL { namespace internal {
template<typename Halfedge_handle>
class OMesh_edge {
public:
OMesh_edge() : halfedge_() {}
explicit OMesh_edge(const Halfedge_handle& h) : halfedge_(h) {}
Halfedge_handle halfedge() const { return halfedge_; }
bool is_valid() const { return halfedge_.is_valid(); }
bool
operator==(const OMesh_edge& other) const {
if(halfedge_ == other.halfedge_) {
return true;
} else if(halfedge_ != Halfedge_handle()) {
return opposite() == other.halfedge_;
} else {
return false;
}
}
bool operator<(const OMesh_edge& other) const
{
return this->idx() < other.idx();
}
bool
operator!=(const OMesh_edge& other) { return !(*this == other); }
Halfedge_handle
opposite() const { return Halfedge_handle((halfedge_.idx() & 1) ? halfedge_.idx()-1 : halfedge_.idx()+1); }
OMesh_edge
opposite_edge() const { return OMesh_edge(Halfedge_handle((halfedge_.idx() & 1) ? halfedge_.idx()-1 : halfedge_.idx()+1)); }
unsigned int idx() const { return halfedge_.idx() / 2; }
private:
Halfedge_handle halfedge_;
};
} } // CGAL::internal
#if OM_VERSION < 0x60200
namespace OpenMesh {
inline std::size_t hash_value(const BaseHandle& h) { return h.idx(); }
} // namespace OpenMesh
#endif
namespace OpenMesh {
inline std::size_t hash_value(const CGAL::internal::OMesh_edge<OpenMesh::HalfedgeHandle>& h) { return h.idx(); }
} // namespace OpenMesh
#ifndef OM_HAS_HASH
#include <functional>
namespace std {
#if defined(BOOST_MSVC)
# pragma warning(push)
# pragma warning(disable:4099) // For VC10 it is class hash
#endif
#ifndef CGAL_CFG_NO_STD_HASH
template <>
struct hash<OpenMesh::BaseHandle >
: public CGAL::cpp98::unary_function<OpenMesh::BaseHandle, std::size_t>
{
std::size_t operator()(const OpenMesh::BaseHandle& h) const
{
return h.idx();
}
};
template <>
struct hash<OpenMesh::VertexHandle >
: public CGAL::cpp98::unary_function<OpenMesh::VertexHandle, std::size_t>
{
std::size_t operator()(const OpenMesh::VertexHandle& h) const
{
return h.idx();
}
};
template <>
struct hash<OpenMesh::HalfedgeHandle >
: public CGAL::cpp98::unary_function<OpenMesh::HalfedgeHandle, std::size_t>
{
std::size_t operator()(const OpenMesh::HalfedgeHandle& h) const
{
return h.idx();
}
};
template <>
struct hash<OpenMesh::EdgeHandle >
: public CGAL::cpp98::unary_function<OpenMesh::EdgeHandle, std::size_t>
{
std::size_t operator()(const OpenMesh::EdgeHandle& h) const
{
return h.idx();
}
};
template <>
struct hash<CGAL::internal::OMesh_edge<OpenMesh::HalfedgeHandle> >
: public CGAL::cpp98::unary_function<OpenMesh::HalfedgeHandle, std::size_t>
{
std::size_t operator()(const CGAL::internal::OMesh_edge<OpenMesh::HalfedgeHandle>& h) const
{
return h.idx();
}
};
template <>
struct hash<OpenMesh::FaceHandle >
: public CGAL::cpp98::unary_function<OpenMesh::FaceHandle, std::size_t>
{
std::size_t operator()(const OpenMesh::FaceHandle& h) const
{
return h.idx();
}
};
#endif // CGAL_CFG_NO_STD_HASH
#if defined(BOOST_MSVC)
# pragma warning(pop)
#endif
} // namespace std
#endif // OM_HAS_HASH
#endif // CGAL_HASH_OPENMESH_H