diff options
author | Jonathan Wakely <jwakely@redhat.com> | 2024-01-20 21:09:28 +0000 |
---|---|---|
committer | Jonathan Wakely <jwakely@redhat.com> | 2024-01-31 09:42:38 +0000 |
commit | 86302e1a76a4af29b4de401685d3822f3eb96899 (patch) | |
tree | e62efdecdecbb51e693054117cf0bc9cb4071b7a | |
parent | 924137b9012cee5603482242de08fbf0b2030f6a (diff) | |
download | gcc-86302e1a76a4af29b4de401685d3822f3eb96899.zip gcc-86302e1a76a4af29b4de401685d3822f3eb96899.tar.gz gcc-86302e1a76a4af29b4de401685d3822f3eb96899.tar.bz2 |
libstdc++: Fix -Wshift-count-overflow warning in std::bitset
This shift only happens if the unsigned long long type is wider than
unsigned long but the compiler warns when it sees the shift, without
caring if it's reachable.
Use the preprocessor to compare the sizes and just reuse _M_to_ulong()
if sizeof(long) == sizeof(long long).
libstdc++-v3/ChangeLog:
* include/std/bitset (_Base_bitset::_M_do_to_ullong): Avoid
-Wshift-count-overflow warning.
-rw-r--r-- | libstdc++-v3/include/std/bitset | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/libstdc++-v3/include/std/bitset b/libstdc++-v3/include/std/bitset index c169269..3243c64 100644 --- a/libstdc++-v3/include/std/bitset +++ b/libstdc++-v3/include/std/bitset @@ -320,17 +320,18 @@ _GLIBCXX_BEGIN_NAMESPACE_CONTAINER _GLIBCXX14_CONSTEXPR unsigned long long _Base_bitset<_Nw>::_M_do_to_ullong() const { - const bool __dw = sizeof(unsigned long long) > sizeof(unsigned long); - for (size_t __i = 1 + __dw; __i < _Nw; ++__i) +#if __SIZEOF_LONG_LONG__ == __SIZEOF_LONG__ + return _M_do_to_ulong(); +#else + for (size_t __i = 2; __i < _Nw; ++__i) if (_M_w[__i]) __throw_overflow_error(__N("_Base_bitset::_M_do_to_ullong")); - if (__dw) - return _M_w[0] + (static_cast<unsigned long long>(_M_w[1]) + return _M_w[0] + (static_cast<unsigned long long>(_M_w[1]) << _GLIBCXX_BITSET_BITS_PER_WORD); - return _M_w[0]; - } #endif + } +#endif // C++11 template<size_t _Nw> _GLIBCXX14_CONSTEXPR size_t |