// Copyright (C) 2020-2023 Free Software Foundation, Inc.
//
// This file is part of the GNU ISO C++ Library. This library is free
// software; you can redistribute it and/or modify it under the
// terms of the GNU General Public License as published by the
// Free Software Foundation; either version 3, or (at your option)
// any later version.
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License along
// with this library; see the file COPYING3. If not see
// .
// { dg-options "-std=c++2a" }
// { dg-do compile { target c++2a } }
#include
#include
void
test01()
{
// PR libstdc++/96042
using V = std::ranges::iota_view;
// In strict -std=c++20 mode there is no integer wider than long long,
// so V's difference type is an integer-class type, [iterator.concept.winc].
// In practice this is either __int128 or __detail::__max_diff_type.
using D = std::ranges::range_difference_t;
// Ensure that numeric_limits is correctly specialized for the type.
using L = std::numeric_limits;
static_assert( L::is_specialized );
static_assert( L::is_signed );
static_assert( L::is_integer );
static_assert( L::is_exact );
static_assert( L::digits > std::numeric_limits::digits );
static_assert( L::digits10 == static_cast(L::digits * 0.30103) );
static_assert( L::min() == (D(1) << L::digits) );
static_assert( L::max() == ~L::min() );
static_assert( L::lowest() == L::min() );
}
#ifdef __SIZEOF_INT128__
void
test02()
{
// When the target supports __int128 it can be used in iota_view
// even in strict mode where !integral<__int128>.
using V = std::ranges::iota_view<__int128, __int128>;
using D = std::ranges::range_difference_t; // __detail::__max_diff_type
using L = std::numeric_limits;
static_assert( L::is_specialized );
static_assert( L::is_signed );
static_assert( L::is_integer );
static_assert( L::is_exact );
static_assert( L::digits > std::numeric_limits::digits );
static_assert( L::digits10 == static_cast(L::digits * 0.30103) );
static_assert( L::min() == (D(1) << L::digits) );
static_assert( L::max() == ~L::min() );
static_assert( L::lowest() == L::min() );
}
#endif