Correct get_int_t to get_uint_t.

Add get_sint_t.
This commit is contained in:
Nekotekina 2019-07-26 19:00:56 +03:00
parent 997e3046e3
commit ec2db8edbc
3 changed files with 39 additions and 32 deletions

View File

@ -412,10 +412,10 @@ std::size_t cfmt_append(Dst& out, const Char* fmt, Src&& src)
}
const u64 mask =
ctx.type == 1 ? u64{std::numeric_limits<get_int_t<1>>::max()} :
ctx.type == 2 ? u64{std::numeric_limits<get_int_t<2>>::max()} :
ctx.type == 4 ? u64{std::numeric_limits<get_int_t<4>>::max()} :
u64{std::numeric_limits<get_int_t<8>>::max()};
ctx.type == 1 ? 0xff :
ctx.type == 2 ? 0xffff :
ctx.type == 4 ? 0xffff'ffffu :
0xffff'ffff'ffff'ffffu;
// Trunc sign-extended signed types
const u64 val = src.template get<u64>(ctx.args) & mask;
@ -469,10 +469,10 @@ std::size_t cfmt_append(Dst& out, const Char* fmt, Src&& src)
}
const u64 mask =
ctx.type == 1 ? u64{std::numeric_limits<get_int_t<1>>::max()} :
ctx.type == 2 ? u64{std::numeric_limits<get_int_t<2>>::max()} :
ctx.type == 4 ? u64{std::numeric_limits<get_int_t<4>>::max()} :
u64{std::numeric_limits<get_int_t<8>>::max()};
ctx.type == 1 ? 0xff :
ctx.type == 2 ? 0xffff :
ctx.type == 4 ? 0xffff'ffffu :
0xffff'ffff'ffff'ffffu;
// Trunc sign-extended signed types
const u64 val = src.template get<u64>(ctx.args) & mask;
@ -533,10 +533,10 @@ std::size_t cfmt_append(Dst& out, const Char* fmt, Src&& src)
}
const u64 mask =
ctx.type == 1 ? u64{std::numeric_limits<get_int_t<1>>::max()} :
ctx.type == 2 ? u64{std::numeric_limits<get_int_t<2>>::max()} :
ctx.type == 4 ? u64{std::numeric_limits<get_int_t<4>>::max()} :
u64{std::numeric_limits<get_int_t<8>>::max()};
ctx.type == 1 ? 0xff :
ctx.type == 2 ? 0xffff :
ctx.type == 4 ? 0xffff'ffffu :
0xffff'ffff'ffff'ffffu;
// Trunc sign-extended signed types
const u64 val = src.template get<u64>(ctx.args) & mask;

View File

@ -131,38 +131,45 @@ using steady_clock = std::conditional<
std::chrono::high_resolution_clock::is_steady,
std::chrono::high_resolution_clock, std::chrono::steady_clock>::type;
// Get unsigned integral type from type size
template<size_t N>
// Get integral type from type size
template <std::size_t N>
struct get_int_impl
{
};
template<>
template <>
struct get_int_impl<sizeof(u8)>
{
using type = u8;
using utype = u8;
using stype = s8;
};
template<>
template <>
struct get_int_impl<sizeof(u16)>
{
using type = u16;
using utype = u16;
using stype = s16;
};
template<>
template <>
struct get_int_impl<sizeof(u32)>
{
using type = u32;
using utype = u32;
using stype = s32;
};
template<>
template <>
struct get_int_impl<sizeof(u64)>
{
using type = u64;
using utype = u64;
using stype = s64;
};
template <size_t N>
using get_int_t = typename get_int_impl<N>::type;
template <std::size_t N>
using get_uint_t = typename get_int_impl<N>::utype;
template <std::size_t N>
using get_sint_t = typename get_int_impl<N>::stype;
namespace gsl
{

View File

@ -68,7 +68,7 @@ struct registers_decoder
{};
// Use the smallest type by default
template<u32 I, u32 N, typename T = get_int_t<std::max<size_t>(static_cast<size_t>((UINTMAX_C(1) << ::ceil2(N)) / CHAR_BIT), 1)>>
template <u32 I, u32 N, typename T = get_uint_t<std::max<size_t>(static_cast<size_t>((UINTMAX_C(1) << ::ceil2(N)) / CHAR_BIT), 1)>>
static constexpr inline T bf_decoder(const u32& bits)
{
return static_cast<T>(bf_t<u32, I, N>::extract(bits));
@ -2320,7 +2320,7 @@ struct registers_decoder<NV4097_SET_STENCIL_OP_FAIL>
{
private:
u32 value;
public:
decoded_type(u32 value) : value(value) {}
@ -2508,7 +2508,7 @@ struct registers_decoder<NV4097_SET_STENCIL_FUNC_MASK>
public:
decoded_type(u32 value) : value(value) {}
u8 stencil_func_mask() const
u8 stencil_func_mask() const
{
return bf_decoder<0, 8>(value);
}
@ -2531,7 +2531,7 @@ struct registers_decoder<NV4097_SET_BACK_STENCIL_FUNC_MASK>
public:
decoded_type(u32 value) : value(value) {}
u8 back_stencil_func_mask() const
u8 back_stencil_func_mask() const
{
return bf_decoder<0, 8>(value);
}
@ -2556,7 +2556,7 @@ struct registers_decoder<NV4097_SET_ALPHA_REF>
u8 alpha_ref() const
{
return bf_decoder<0, 8>(value);
return bf_decoder<0, 8>(value);
}
};
@ -2914,7 +2914,7 @@ struct registers_decoder<NV4097_SET_BLEND_FUNC_SFACTOR>
{
private:
u32 value;
u16 src_blend_rgb_raw() const
{
return bf_decoder<0, 16>(value);
@ -2952,7 +2952,7 @@ struct registers_decoder<NV4097_SET_BLEND_FUNC_DFACTOR>
{
private:
u32 value;
u16 dst_blend_rgb_raw() const
{
return bf_decoder<0, 16>(value);
@ -3814,7 +3814,7 @@ struct registers_decoder<NV3089_IMAGE_IN>
{
return bf_decoder<16, 16, u32>(value);
}
public:
decoded_type(u32 value) : value(value) {}