diff --git a/glm/core/func_integer.inl b/glm/core/func_integer.inl index be294cc8..c5e6fe25 100644 --- a/glm/core/func_integer.inl +++ b/glm/core/func_integer.inl @@ -20,7 +20,7 @@ namespace glm { // uaddCarry template - GLM_FUNC_QUALIFIER genUType uaddCarry + inline genUType uaddCarry ( genUType const & x, genUType const & y, @@ -34,7 +34,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec2 uaddCarry + inline detail::tvec2 uaddCarry ( detail::tvec2 const & x, detail::tvec2 const & y, @@ -47,7 +47,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec3 uaddCarry + inline detail::tvec3 uaddCarry ( detail::tvec3 const & x, detail::tvec3 const & y, @@ -61,7 +61,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec4 uaddCarry + inline detail::tvec4 uaddCarry ( detail::tvec4 const & x, detail::tvec4 const & y, @@ -77,7 +77,7 @@ namespace glm // usubBorrow template - GLM_FUNC_QUALIFIER genUType usubBorrow + inline genUType usubBorrow ( genUType const & x, genUType const & y, @@ -92,7 +92,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec2 usubBorrow + inline detail::tvec2 usubBorrow ( detail::tvec2 const & x, detail::tvec2 const & y, @@ -105,7 +105,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec3 usubBorrow + inline detail::tvec3 usubBorrow ( detail::tvec3 const & x, detail::tvec3 const & y, @@ -119,7 +119,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec4 usubBorrow + inline detail::tvec4 usubBorrow ( detail::tvec4 const & x, detail::tvec4 const & y, @@ -135,7 +135,7 @@ namespace glm // umulExtended template - GLM_FUNC_QUALIFIER void umulExtended + inline void umulExtended ( genUType const & x, genUType const & y, @@ -151,7 +151,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec2 umulExtended + inline detail::tvec2 umulExtended ( detail::tvec2 const & x, detail::tvec2 const & y, @@ -165,7 +165,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec3 umulExtended + inline detail::tvec3 umulExtended ( detail::tvec3 const & x, detail::tvec3 const & y, @@ -180,7 +180,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec4 umulExtended + inline detail::tvec4 umulExtended ( detail::tvec4 const & x, detail::tvec4 const & y, @@ -213,7 +213,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec2 imulExtended + inline detail::tvec2 imulExtended ( detail::tvec2 const & x, detail::tvec2 const & y, @@ -227,7 +227,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec3 imulExtended + inline detail::tvec3 imulExtended ( detail::tvec3 const & x, detail::tvec3 const & y, @@ -242,7 +242,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec4 imulExtended + inline detail::tvec4 imulExtended ( detail::tvec4 const & x, detail::tvec4 const & y, @@ -258,40 +258,30 @@ namespace glm } // bitfieldExtract - template - GLM_FUNC_QUALIFIER genIUType bitfieldExtract + template + genIUType bitfieldExtract ( genIUType const & Value, - sizeType const & Offset, - sizeType const & Bits + int const & Offset, + int const & Bits ) { -/* GLM_STATIC_ASSERT(std::numeric_limits::is_integer, "'bitfieldExtract' only accept integer values"); - assert(Offset + Bits <= (sizeof(genIUType) << 3)); + assert(Offset + Bits <= sizeof(genIUType)); - genIUType Result(0); + genIUType Result = 0; if(std::numeric_limits::is_signed) - Result |= (genIUType(1) << (sizeof(genIUType) * genIUType(8) - genIUType(1))) & (genIUType(1) << (Offset + Bits - genIUType(1))); + Result |= (1 << (sizeof(genIUType) * 8 - 1)) & (1 << (Offset + Bits - 1)); - genIUType Mask(0); + genIUType Mask = 0; for(int Bit = Offset; Bit < Bits; ++Bit) - Mask |= (genIUType(1) << Bit); + Mask |= (1 << Bit); return Result | ((Mask & Value) >> Offset); -*/ - sizeType GenSize = sizeof(genIUType) << sizeType(3); - - assert(Offset + Bits <= GenSize); - - genIUType ShiftLeft = Bits ? Value << (GenSize - (Bits + Offset)) : genIUType(0); - genIUType ShiftBack = ShiftLeft >> genIUType(GenSize - Bits); - - return ShiftBack; } template - GLM_FUNC_QUALIFIER detail::tvec2 bitfieldExtract + inline detail::tvec2 bitfieldExtract ( detail::tvec2 const & Value, int const & Offset, @@ -304,7 +294,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec3 bitfieldExtract + inline detail::tvec3 bitfieldExtract ( detail::tvec3 const & Value, int const & Offset, @@ -318,7 +308,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec4 bitfieldExtract + inline detail::tvec4 bitfieldExtract ( detail::tvec4 const & Value, int const & Offset, @@ -334,7 +324,7 @@ namespace glm // bitfieldInsert template - GLM_FUNC_QUALIFIER genIUType bitfieldInsert + inline genIUType bitfieldInsert ( genIUType const & Base, genIUType const & Insert, @@ -350,13 +340,13 @@ namespace glm genIUType Mask = 0; for(int Bit = Offset; Bit < Offset + Bits; ++Bit) - Mask |= (genIUType(1) << Bit); + Mask |= (1 << Bit); return (Base & ~Mask) | (Insert & Mask); } template - GLM_FUNC_QUALIFIER detail::tvec2 bitfieldInsert + inline detail::tvec2 bitfieldInsert ( detail::tvec2 const & Base, detail::tvec2 const & Insert, @@ -370,7 +360,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec3 bitfieldInsert + inline detail::tvec3 bitfieldInsert ( detail::tvec3 const & Base, detail::tvec3 const & Insert, @@ -385,7 +375,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec4 bitfieldInsert + inline detail::tvec4 bitfieldInsert ( detail::tvec4 const & Base, detail::tvec4 const & Insert, @@ -402,19 +392,19 @@ namespace glm // bitfieldReverse template - GLM_FUNC_QUALIFIER genIUType bitfieldReverse(genIUType const & Value) + inline genIUType bitfieldReverse(genIUType const & Value) { GLM_STATIC_ASSERT(std::numeric_limits::is_integer, "'bitfieldReverse' only accept integer values"); genIUType Result = 0; for(std::size_t i = 0; i < sizeof(genIUType) * std::size_t(8); ++i) - if(Value & (genIUType(1) << genIUType(i))) - Result |= (genIUType(1) << (genIUType(sizeof(genIUType)) * genIUType(8)) - genIUType(1) - genIUType(i)); + if(Value & (1 << i)) + Result |= (genIUType(1) << (sizeof(genIUType) * std::size_t(8)) - genIUType(1) - i); return Result; } template - GLM_FUNC_QUALIFIER detail::tvec2 bitfieldReverse + inline detail::tvec2 bitfieldReverse ( detail::tvec2 const & value ) @@ -425,7 +415,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec3 bitfieldReverse + inline detail::tvec3 bitfieldReverse ( detail::tvec3 const & value ) @@ -437,7 +427,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec4 bitfieldReverse + inline detail::tvec4 bitfieldReverse ( detail::tvec4 const & value ) @@ -458,14 +448,14 @@ namespace glm int Count = 0; for(std::size_t i = 0; i < sizeof(genIUType) * std::size_t(8); ++i) { - if(Value & (genIUType(1) << i)) + if(Value & (1 << i)) ++Count; } return Count; } template - GLM_FUNC_QUALIFIER detail::tvec2 bitCount + inline detail::tvec2 bitCount ( detail::tvec2 const & value ) @@ -476,7 +466,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec3 bitCount + inline detail::tvec3 bitCount ( detail::tvec3 const & value ) @@ -488,7 +478,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec4 bitCount + inline detail::tvec4 bitCount ( detail::tvec4 const & value ) @@ -502,7 +492,7 @@ namespace glm // findLSB template - GLM_FUNC_QUALIFIER int findLSB + inline int findLSB ( genIUType const & Value ) @@ -517,7 +507,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec2 findLSB + inline detail::tvec2 findLSB ( detail::tvec2 const & value ) @@ -528,7 +518,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec3 findLSB + inline detail::tvec3 findLSB ( detail::tvec3 const & value ) @@ -540,7 +530,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec4 findLSB + inline detail::tvec4 findLSB ( detail::tvec4 const & value ) @@ -554,7 +544,7 @@ namespace glm // findMSB template - GLM_FUNC_QUALIFIER int findMSB + inline int findMSB ( genIUType const & Value ) @@ -569,7 +559,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec2 findMSB + inline detail::tvec2 findMSB ( detail::tvec2 const & value ) @@ -580,7 +570,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec3 findMSB + inline detail::tvec3 findMSB ( detail::tvec3 const & value ) @@ -592,7 +582,7 @@ namespace glm } template - GLM_FUNC_QUALIFIER detail::tvec4 findMSB + inline detail::tvec4 findMSB ( detail::tvec4 const & value )