cstdint.hpp on MSVC inconsitency ?
data:image/s3,"s3://crabby-images/89590/89590d82cbe9918869d50d06c72e3afad4a31b25" alt=""
In cstdint.hpp, the logic is that , if sizeof(long) == 4 then int32_t = long elseif sizeof(int) == 4 then int32_t = int. However, boost::detail::int_least_helper assumes sizeof(long) > sizeof(int). The consequence is that int_t<32>::fast is not the same as int32_t on MSVC while MSVC always garantee that int == long. Is there any rationale we missed or should I try to fix that as it currently prevent nT2 from compiling on MSVC . Regards
data:image/s3,"s3://crabby-images/438b1/438b1aa61e01a6b75d80ee70a25bc94e4862b16a" alt=""
In cstdint.hpp, the logic is that , if sizeof(long) == 4 then int32_t = long elseif sizeof(int) == 4 then int32_t = int. However, boost::detail::int_least_helper assumes sizeof(long) > sizeof(int).
The consequence is that int_t<32>::fast is not the same as int32_t on MSVC while MSVC always garantee that int == long.
Is there any rationale we missed or should I try to fix that as it currently prevent nT2 from compiling on MSVC .
I've switched the logic around in Trunk, as it certainly makes sense to do so. However note that in the strictest sense the int#_t typedef's are "unmentionable" types and no assumptions should really be made as to what the underlying type really is. Cheers, John.
participants (2)
-
joel falcou
-
John Maddock