Make tuple_element static_assert in pair if the index is out of range. Also, add a message to variant_alternative<> in the similar case (it already asserted). Add tests for this
git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@305196 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -653,6 +653,12 @@ template <class _T1, class _T2>
|
|||||||
class _LIBCPP_TEMPLATE_VIS tuple_size<pair<_T1, _T2> >
|
class _LIBCPP_TEMPLATE_VIS tuple_size<pair<_T1, _T2> >
|
||||||
: public integral_constant<size_t, 2> {};
|
: public integral_constant<size_t, 2> {};
|
||||||
|
|
||||||
|
template <size_t _Ip, class _T1, class _T2>
|
||||||
|
class _LIBCPP_TEMPLATE_VIS tuple_element<_Ip, pair<_T1, _T2> >
|
||||||
|
{
|
||||||
|
static_assert(_Ip < 2, "Index out of bounds in std::tuple_element<std::pair<T1, T2>>");
|
||||||
|
};
|
||||||
|
|
||||||
template <class _T1, class _T2>
|
template <class _T1, class _T2>
|
||||||
class _LIBCPP_TEMPLATE_VIS tuple_element<0, pair<_T1, _T2> >
|
class _LIBCPP_TEMPLATE_VIS tuple_element<0, pair<_T1, _T2> >
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -278,7 +278,7 @@ struct _LIBCPP_TEMPLATE_VIS variant_alternative<_Ip, const volatile _Tp>
|
|||||||
|
|
||||||
template <size_t _Ip, class... _Types>
|
template <size_t _Ip, class... _Types>
|
||||||
struct _LIBCPP_TEMPLATE_VIS variant_alternative<_Ip, variant<_Types...>> {
|
struct _LIBCPP_TEMPLATE_VIS variant_alternative<_Ip, variant<_Types...>> {
|
||||||
static_assert(_Ip < sizeof...(_Types));
|
static_assert(_Ip < sizeof...(_Types), "Index out of bounds in std::variant_alternative<>");
|
||||||
using type = __type_pack_element<_Ip, _Types...>;
|
using type = __type_pack_element<_Ip, _Types...>;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,25 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <utility>
|
||||||
|
|
||||||
|
// template <class T1, class T2> struct pair
|
||||||
|
|
||||||
|
// tuple_element<I, pair<T1, T2> >::type
|
||||||
|
|
||||||
|
#include <utility>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
{
|
||||||
|
typedef std::pair<int, double> P;
|
||||||
|
std::tuple_element<2, P>::type foo; // expected-note {{requested here}}
|
||||||
|
// expected-error@utility:* {{static_assert failed "Index out of bounds in std::tuple_element<std::pair<T1, T2>>"}}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,34 @@
|
|||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is dual licensed under the MIT and the University of Illinois Open
|
||||||
|
// Source Licenses. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
// <array>
|
||||||
|
|
||||||
|
// template <size_t I, class T> struct variant_alternative; // undefined
|
||||||
|
// template <size_t I, class T> struct variant_alternative<I, const T>;
|
||||||
|
// template <size_t I, class T> struct variant_alternative<I, volatile T>;
|
||||||
|
// template <size_t I, class T> struct variant_alternative<I, const volatile T>;
|
||||||
|
// template <size_t I, class T>
|
||||||
|
// using variant_alternative_t = typename variant_alternative<I, T>::type;
|
||||||
|
//
|
||||||
|
// template <size_t I, class... Types>
|
||||||
|
// struct variant_alternative<I, variant<Types...>>;
|
||||||
|
|
||||||
|
|
||||||
|
#include <variant>
|
||||||
|
#include <cassert>
|
||||||
|
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
{
|
||||||
|
typedef std::variant<int, double> T;
|
||||||
|
std::variant_alternative<2, T>::type foo; // expected-note {{requested here}}
|
||||||
|
// expected-error@variant:* {{static_assert failed "Index out of bounds in std::variant_alternative<>"}}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user