mirror of https://github.com/mosra/magnum.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
251 lines
9.5 KiB
251 lines
9.5 KiB
#ifndef Magnum_TypeTraits_h |
|
#define Magnum_TypeTraits_h |
|
/* |
|
Copyright © 2010, 2011, 2012 Vladimír Vondruš <mosra@centrum.cz> |
|
|
|
This file is part of Magnum. |
|
|
|
Magnum is free software: you can redistribute it and/or modify |
|
it under the terms of the GNU Lesser General Public License version 3 |
|
only, as published by the Free Software Foundation. |
|
|
|
Magnum 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 version 3 for more details. |
|
*/ |
|
|
|
/** @file /TypeTraits.h |
|
* @brief Enum Magnum::Type, class Magnum::TypeOf, Magnum::TypeInfo, Magnum::TypeTraits |
|
*/ |
|
|
|
#include "AbstractImage.h" |
|
|
|
namespace Magnum { |
|
|
|
/** |
|
@brief Traits class for plain OpenGL types |
|
|
|
@copydetails Math::MathTypeTraits |
|
|
|
Where it makes sense, this class extends Math::MathTypeTraits with |
|
OpenGL-specific traits. |
|
*/ |
|
#ifdef DOXYGEN_GENERATING_OUTPUT |
|
template<class T> struct TypeTraits: public Math::MathTypeTraits<T> { |
|
/** |
|
* @brief OpenGL plain type ID |
|
* |
|
* Returns e.g. Type::UnsignedInt for GLuint. |
|
*/ |
|
inline constexpr static Type type(); |
|
|
|
/** |
|
* @brief OpenGL type ID for indices |
|
* |
|
* Implemented only in types which can be used for vertex indices (all |
|
* unsigned types). This function is not present for types unusable for |
|
* vertex indices, like GLfloat or GLint. |
|
*/ |
|
inline constexpr static Type indexType(); |
|
|
|
/** |
|
* @brief OpenGL type ID for images |
|
* |
|
* Implemented only in types which can be used for image data, like |
|
* GLubyte. This function is not present for types unusable for image data, |
|
* like GLdouble and Matrix3. |
|
*/ |
|
inline constexpr static AbstractImage::ComponentType imageType(); |
|
|
|
/** |
|
* @brief Size of plain OpenGL type |
|
* |
|
* Returns sizeof(GLfloat) for GLfloat, but also sizeof(GLfloat) for |
|
* Vector3. See count(). |
|
*/ |
|
inline constexpr static size_t size(); |
|
|
|
/** |
|
* @brief Count of plain elements in this type |
|
* |
|
* Returns 1 for plain OpenGL types like GLint, but e.g. 3 for Vector3. |
|
*/ |
|
inline constexpr static size_t count(); |
|
}; |
|
#else |
|
template<class T> struct TypeTraits {}; |
|
#endif |
|
|
|
/** @brief OpenGL plain types */ |
|
enum class Type: GLenum { |
|
UnsignedByte = GL_UNSIGNED_BYTE, /**< Unsigned byte (char) */ |
|
Byte = GL_BYTE, /**< Byte (char) */ |
|
UnsignedShort = GL_UNSIGNED_SHORT, /**< Unsigned short */ |
|
Short = GL_SHORT, /**< Short */ |
|
UnsignedInt = GL_UNSIGNED_INT, /**< Unsigned int */ |
|
Int = GL_INT, /**< Int */ |
|
Float = GL_FLOAT /**< Float */ |
|
|
|
#ifndef MAGNUM_TARGET_GLES |
|
, |
|
/** |
|
* Double |
|
* @requires_gl |
|
*/ |
|
Double = GL_DOUBLE |
|
#endif |
|
}; |
|
|
|
/** |
|
@brief Class for converting Type enum values to types |
|
|
|
When you want to use TypeTraits on type specified only as enum value, you can |
|
use this class to convert it into type, for example these two statements |
|
are equivalent: |
|
@code |
|
type = TypeTraits<TypeOf<Type::UnsignedByte>::Type>::imageType(); |
|
type = TypeTraits<GLubyte>::imageType(); |
|
@endcode |
|
*/ |
|
template<Type T> class TypeOf { |
|
#ifdef DOXYGEN_GENERATING_OUTPUT |
|
typedef U Type; /**< @brief Type */ |
|
#endif |
|
}; |
|
|
|
/** |
|
@brief Functor for runtime information about given type |
|
|
|
TypeTraits alone allows to get information about given type only at compile |
|
time, this class alows to get some information also at runtime with tiny |
|
performance loss. |
|
*/ |
|
struct MAGNUM_EXPORT TypeInfo { |
|
/** |
|
* @brief Size of given type |
|
* |
|
* These two lines provide the same information, one at compile time, |
|
* one at runtime: |
|
* @code |
|
* size_t size = TypeTraits<TypeOf<Type::UnsignedByte>::size(); |
|
* size_t size = TypeInfo::sizeOf(Type::UnsignedByte); |
|
* @endcode |
|
*/ |
|
static size_t sizeOf(Type type); |
|
|
|
/** |
|
* @brief Whether the type is integral |
|
* @return true for (un)signed byte, short and integer, false otherwise. |
|
*/ |
|
static bool isIntegral(Type type); |
|
}; |
|
|
|
/** @todo Other texture types, referenced in glTexImage2D function manual */ |
|
/** @todo Using Vector3 for textures? */ |
|
|
|
#ifndef DOXYGEN_GENERATING_OUTPUT |
|
template<> struct TypeOf<Type::UnsignedByte> { typedef GLubyte Type; }; |
|
template<> struct TypeOf<Type::Byte> { typedef GLbyte Type; }; |
|
template<> struct TypeOf<Type::UnsignedShort> { typedef GLushort Type; }; |
|
template<> struct TypeOf<Type::Short> { typedef GLshort Type; }; |
|
template<> struct TypeOf<Type::UnsignedInt> { typedef GLuint Type; }; |
|
template<> struct TypeOf<Type::Int> { typedef GLint Type; }; |
|
template<> struct TypeOf<Type::Float> { typedef GLfloat Type; }; |
|
#ifndef MAGNUM_TARGET_GLES |
|
template<> struct TypeOf<Type::Double> { typedef GLdouble Type; }; |
|
#endif |
|
|
|
template<> struct TypeTraits<GLubyte>: public Math::MathTypeTraits<unsigned char> { |
|
inline constexpr static Type type() { return Type::UnsignedByte; } |
|
inline constexpr static Type indexType() { return Type::UnsignedByte; } |
|
inline constexpr static AbstractImage::ComponentType imageType() { return AbstractImage::ComponentType::UnsignedByte; } |
|
inline constexpr static size_t size() { return sizeof(GLubyte); } |
|
inline constexpr static size_t count() { return 1; } |
|
}; |
|
|
|
template<> struct TypeTraits<GLbyte>: public Math::MathTypeTraits<char> { |
|
inline constexpr static Type type() { return Type::Byte; } |
|
/* Can not be used for indices */ |
|
inline constexpr static AbstractImage::ComponentType imageType() { return AbstractImage::ComponentType::Byte; } |
|
inline constexpr static size_t size() { return sizeof(GLbyte); } |
|
inline constexpr static size_t count() { return 1; } |
|
}; |
|
|
|
template<> struct TypeTraits<GLushort>: public Math::MathTypeTraits<unsigned short> { |
|
inline constexpr static Type type() { return Type::UnsignedShort; } |
|
inline constexpr static Type indexType() { return Type::UnsignedShort; } |
|
inline constexpr static AbstractImage::ComponentType imageType() { return AbstractImage::ComponentType::UnsignedShort; } |
|
inline constexpr static size_t size() { return sizeof(GLushort); } |
|
inline constexpr static size_t count() { return 1; } |
|
}; |
|
|
|
template<> struct TypeTraits<GLshort>: public Math::MathTypeTraits<short> { |
|
inline constexpr static Type type() { return Type::Short; } |
|
/* Can not be used for indices */ |
|
inline constexpr static AbstractImage::ComponentType imageType() { return AbstractImage::ComponentType::Short; } |
|
inline constexpr static size_t size() { return sizeof(GLshort); } |
|
inline constexpr static size_t count() { return 1; } |
|
}; |
|
|
|
template<> struct TypeTraits<GLuint>: public Math::MathTypeTraits<unsigned int> { |
|
inline constexpr static Type type() { return Type::UnsignedInt; } |
|
inline constexpr static Type indexType() { return Type::UnsignedInt; } |
|
inline constexpr static AbstractImage::ComponentType imageType() { return AbstractImage::ComponentType::UnsignedInt; } |
|
inline constexpr static size_t size() { return sizeof(GLuint); } |
|
inline constexpr static size_t count() { return 1; } |
|
}; |
|
|
|
template<> struct TypeTraits<GLint>: public Math::MathTypeTraits<int> { |
|
inline constexpr static Type type() { return Type::Int; } |
|
/* Can not be used for indices */ |
|
inline constexpr static AbstractImage::ComponentType imageType() { return AbstractImage::ComponentType::Int; } |
|
inline constexpr static size_t size() { return sizeof(GLint); } |
|
inline constexpr static size_t count() { return 1; } |
|
}; |
|
|
|
template<> struct TypeTraits<GLfloat>: public Math::MathTypeTraits<float> { |
|
inline constexpr static Type type() { return Type::Float; } |
|
/* Can not be used for indices */ |
|
inline constexpr static AbstractImage::ComponentType imageType() { return AbstractImage::ComponentType::Float; } |
|
inline constexpr static size_t size() { return sizeof(GLfloat); } |
|
inline constexpr static size_t count() { return 1; } |
|
}; |
|
|
|
#ifndef MAGNUM_TARGET_GLES |
|
template<> struct TypeTraits<GLdouble>: public Math::MathTypeTraits<double> { |
|
inline constexpr static Type type() { return Type::Double; } |
|
/* Can not be used for indices */ |
|
/* Can not be used for images */ |
|
inline constexpr static size_t size() { return sizeof(GLdouble); } |
|
inline constexpr static size_t count() { return 1; } |
|
}; |
|
#endif |
|
|
|
template<class T, size_t vectorSize> struct TypeTraits<Math::Vector<vectorSize, T>> { |
|
inline constexpr static Type type() { return TypeTraits<T>::type(); } |
|
/* Can not be used for indices */ |
|
/* Can not be used for images */ |
|
inline constexpr static size_t size() { return sizeof(T); } |
|
inline constexpr static size_t count() { return vectorSize; } |
|
}; |
|
|
|
template<class T> struct TypeTraits<Math::Vector2<T>>: public TypeTraits<Math::Vector<2, T>> {}; |
|
template<class T> struct TypeTraits<Math::Vector3<T>>: public TypeTraits<Math::Vector<3, T>> {}; |
|
template<class T> struct TypeTraits<Math::Vector4<T>>: public TypeTraits<Math::Vector<4, T>> {}; |
|
|
|
template<class T, size_t matrixSize> struct TypeTraits<Math::Matrix<matrixSize, T>> { |
|
inline constexpr static Type type() { return TypeTraits<T>::type(); } |
|
/* Can not be used for indices */ |
|
/* Can not be used for images */ |
|
inline constexpr static size_t size() { return sizeof(T); } |
|
inline constexpr static size_t count() { return matrixSize*matrixSize; } |
|
}; |
|
|
|
template<class T> struct TypeTraits<Math::Matrix3<T>>: public TypeTraits<Math::Matrix<3, T>> {}; |
|
template<class T> struct TypeTraits<Math::Matrix4<T>>: public TypeTraits<Math::Matrix<4, T>> {}; |
|
#endif |
|
|
|
} |
|
|
|
#endif
|
|
|