mirror of
https://github.com/g-truc/glm.git
synced 2024-11-22 17:04:35 +00:00
Added missing genType check for bitCount and bitfieldReverse #893
This commit is contained in:
parent
bfa028ed13
commit
f4b3fc7733
@ -260,6 +260,8 @@ namespace detail
|
|||||||
template<typename genIUType>
|
template<typename genIUType>
|
||||||
GLM_FUNC_QUALIFIER genIUType bitfieldInsert(genIUType const& Base, genIUType const& Insert, int Offset, int Bits)
|
GLM_FUNC_QUALIFIER genIUType bitfieldInsert(genIUType const& Base, genIUType const& Insert, int Offset, int Bits)
|
||||||
{
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<genIUType>::is_integer, "'bitfieldInsert' only accept integer values");
|
||||||
|
|
||||||
return bitfieldInsert(vec<1, genIUType>(Base), vec<1, genIUType>(Insert), Offset, Bits).x;
|
return bitfieldInsert(vec<1, genIUType>(Base), vec<1, genIUType>(Insert), Offset, Bits).x;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -273,15 +275,19 @@ namespace detail
|
|||||||
}
|
}
|
||||||
|
|
||||||
// bitfieldReverse
|
// bitfieldReverse
|
||||||
template<typename genType>
|
template<typename genIUType>
|
||||||
GLM_FUNC_QUALIFIER genType bitfieldReverse(genType x)
|
GLM_FUNC_QUALIFIER genIUType bitfieldReverse(genIUType x)
|
||||||
{
|
{
|
||||||
return bitfieldReverse(glm::vec<1, genType, glm::defaultp>(x)).x;
|
GLM_STATIC_ASSERT(std::numeric_limits<genIUType>::is_integer, "'bitfieldReverse' only accept integer values");
|
||||||
|
|
||||||
|
return bitfieldReverse(glm::vec<1, genIUType, glm::defaultp>(x)).x;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<length_t L, typename T, qualifier Q>
|
template<length_t L, typename T, qualifier Q>
|
||||||
GLM_FUNC_QUALIFIER vec<L, T, Q> bitfieldReverse(vec<L, T, Q> const& v)
|
GLM_FUNC_QUALIFIER vec<L, T, Q> bitfieldReverse(vec<L, T, Q> const& v)
|
||||||
{
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_integer, "'bitfieldReverse' only accept integer values");
|
||||||
|
|
||||||
vec<L, T, Q> x(v);
|
vec<L, T, Q> x(v);
|
||||||
x = detail::compute_bitfieldReverseStep<L, T, Q, detail::is_aligned<Q>::value, sizeof(T) * 8>= 2>::call(x, static_cast<T>(0x5555555555555555ull), static_cast<T>( 1));
|
x = detail::compute_bitfieldReverseStep<L, T, Q, detail::is_aligned<Q>::value, sizeof(T) * 8>= 2>::call(x, static_cast<T>(0x5555555555555555ull), static_cast<T>( 1));
|
||||||
x = detail::compute_bitfieldReverseStep<L, T, Q, detail::is_aligned<Q>::value, sizeof(T) * 8>= 4>::call(x, static_cast<T>(0x3333333333333333ull), static_cast<T>( 2));
|
x = detail::compute_bitfieldReverseStep<L, T, Q, detail::is_aligned<Q>::value, sizeof(T) * 8>= 4>::call(x, static_cast<T>(0x3333333333333333ull), static_cast<T>( 2));
|
||||||
@ -293,15 +299,19 @@ namespace detail
|
|||||||
}
|
}
|
||||||
|
|
||||||
// bitCount
|
// bitCount
|
||||||
template<typename genType>
|
template<typename genIUType>
|
||||||
GLM_FUNC_QUALIFIER int bitCount(genType x)
|
GLM_FUNC_QUALIFIER int bitCount(genIUType x)
|
||||||
{
|
{
|
||||||
return bitCount(glm::vec<1, genType, glm::defaultp>(x)).x;
|
GLM_STATIC_ASSERT(std::numeric_limits<genIUType>::is_integer, "'bitCount' only accept integer values");
|
||||||
|
|
||||||
|
return bitCount(glm::vec<1, genIUType, glm::defaultp>(x)).x;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<length_t L, typename T, qualifier Q>
|
template<length_t L, typename T, qualifier Q>
|
||||||
GLM_FUNC_QUALIFIER vec<L, int, Q> bitCount(vec<L, T, Q> const& v)
|
GLM_FUNC_QUALIFIER vec<L, int, Q> bitCount(vec<L, T, Q> const& v)
|
||||||
{
|
{
|
||||||
|
GLM_STATIC_ASSERT(std::numeric_limits<T>::is_integer, "'bitCount' only accept integer values");
|
||||||
|
|
||||||
# if GLM_COMPILER & GLM_COMPILER_VC
|
# if GLM_COMPILER & GLM_COMPILER_VC
|
||||||
# pragma warning(push)
|
# pragma warning(push)
|
||||||
# pragma warning(disable : 4310) //cast truncates constant value
|
# pragma warning(disable : 4310) //cast truncates constant value
|
||||||
|
Loading…
Reference in New Issue
Block a user