/*===========================================================================*\
* *
* OpenMesh *
* Copyright (C) 2001-2013 by Computer Graphics Group, RWTH Aachen *
* www.openmesh.org *
* *
*---------------------------------------------------------------------------*
* This file is part of OpenMesh. *
* *
* OpenMesh is free software: 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 with the *
* following exceptions: *
* *
* If other files instantiate templates or use macros *
* or inline functions from this file, or you compile this file and *
* link it with other files to produce an executable, this file does *
* not by itself cause the resulting executable to be covered by the *
* GNU Lesser General Public License. This exception does not however *
* invalidate any other reasons why the executable file might be *
* covered by the GNU Lesser General Public License. *
* *
* OpenMesh is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU Lesser General Public License for more details. *
* *
* You should have received a copy of the GNU LesserGeneral Public *
* License along with OpenMesh. If not, *
* see . *
* *
\*===========================================================================*/
/*===========================================================================*\
* *
* $Revision$ *
* $Date$ *
* *
\*===========================================================================*/
#ifndef OPENMESH_MESH_ITEMS_HH
#define OPENMESH_MESH_ITEMS_HH
//== INCLUDES =================================================================
#include
#include
#include
#include
//== NAMESPACES ===============================================================
namespace OpenMesh {
//== CLASS DEFINITION =========================================================
/// Definition of the mesh entities (items).
template
struct FinalMeshItemsT
{
//--- build Refs structure ---
#ifndef DOXY_IGNORE_THIS
struct Refs
{
typedef typename Traits::Point Point;
typedef typename vector_traits::value_type Scalar;
typedef typename Traits::Normal Normal;
typedef typename Traits::Color Color;
typedef typename Traits::TexCoord1D TexCoord1D;
typedef typename Traits::TexCoord2D TexCoord2D;
typedef typename Traits::TexCoord3D TexCoord3D;
typedef typename Traits::TextureIndex TextureIndex;
typedef OpenMesh::VertexHandle VertexHandle;
typedef OpenMesh::FaceHandle FaceHandle;
typedef OpenMesh::EdgeHandle EdgeHandle;
typedef OpenMesh::HalfedgeHandle HalfedgeHandle;
};
#endif
//--- export Refs types ---
typedef typename Refs::Point Point;
typedef typename Refs::Scalar Scalar;
typedef typename Refs::Normal Normal;
typedef typename Refs::Color Color;
typedef typename Refs::TexCoord1D TexCoord1D;
typedef typename Refs::TexCoord2D TexCoord2D;
typedef typename Refs::TexCoord3D TexCoord3D;
typedef typename Refs::TextureIndex TextureIndex;
//--- get attribute bits from Traits ---
enum Attribs
{
VAttribs = Traits::VertexAttributes,
HAttribs = Traits::HalfedgeAttributes,
EAttribs = Traits::EdgeAttributes,
FAttribs = Traits::FaceAttributes
};
//--- merge internal items with traits items ---
/*
typedef typename GenProg::IF<
(bool)(HAttribs & Attributes::PrevHalfedge),
typename InternalItems::Halfedge_with_prev,
typename InternalItems::Halfedge_without_prev
>::Result InternalHalfedge;
*/
//typedef typename InternalItems::Vertex InternalVertex;
//typedef typename InternalItems::template Edge InternalEdge;
//typedef typename InternalItems::template Face InternalFace;
class ITraits
{};
typedef typename Traits::template VertexT VertexData;
typedef typename Traits::template HalfedgeT HalfedgeData;
typedef typename Traits::template EdgeT EdgeData;
typedef typename Traits::template FaceT FaceData;
};
#ifndef DOXY_IGNORE_THIS
namespace {
namespace TM {
template struct TypeEquality;
template struct TypeEquality {};
template struct ItemsEquality {
TypeEquality te1;
TypeEquality te2;
TypeEquality te3;
TypeEquality te4;
TypeEquality te5;
TypeEquality te6;
TypeEquality te7;
TypeEquality te8;
};
} /* namespace TM */
} /* anonymous namespace */
#endif
/**
* @brief Cast a mesh with different but identical traits into each other.
*
* Note that there exists a syntactically more convenient global method
* mesh_cast().
*
* Example:
* @code{.cpp}
* struct Traits1 : public OpenMesh::DefaultTraits {
* typedef Vec3d Point;
* }
* struct Traits2 : public OpenMesh::DefaultTraits {
* typedef Vec3d Point;
* }
* struct Traits3 : public OpenMesh::DefaultTraits {
* typedef Vec3f Point;
* }
*
* TriMesh_ArrayKernelT a;
* TriMesh_ArrayKernelT &b = MeshCast&, TriMesh_ArrayKernelT&>::cast(a); // OK
* TriMesh_ArrayKernelT &c = MeshCast&, TriMesh_ArrayKernelT&>::cast(a); // ERROR
* @endcode
*
* @see mesh_cast()
*
* @param rhs
* @return
*/
template struct MeshCast;
template
struct MeshCast {
static LhsMeshT &cast(RhsMeshT &rhs) {
(void)sizeof(TM::ItemsEquality);
(void)sizeof(TM::TypeEquality);
return reinterpret_cast(rhs);
}
};
template
struct MeshCast {
static const LhsMeshT &cast(const RhsMeshT &rhs) {
(void)sizeof(TM::ItemsEquality);
(void)sizeof(TM::TypeEquality);
return reinterpret_cast(rhs);
}
};
template
struct MeshCast {
static LhsMeshT *cast(RhsMeshT *rhs) {
(void)sizeof(TM::ItemsEquality);
(void)sizeof(TM::TypeEquality);
return reinterpret_cast(rhs);
}
};
template
struct MeshCast {
static const LhsMeshT *cast(const RhsMeshT *rhs) {
(void)sizeof(TM::ItemsEquality);
(void)sizeof(TM::TypeEquality);
return reinterpret_cast(rhs);
}
};
//=============================================================================
} // namespace OpenMesh
//=============================================================================
#endif // OPENMESH_MESH_ITEMS_HH defined
//=============================================================================