1 // RUN: %clang_cc1 -fsyntax-only -verify -Wno-unused-value -std=c++20 %s
4 typedef decltype(sizeof(int)) size_t;
7 struct initializer_list
{
10 initializer_list(const E
*p
, size_t n
) : p(p
), n(n
) {}
13 // Classes to use to reproduce the exact scenario present in #62925.
14 template<class T
, class Y
>
20 template<class T
, class Y
>
23 map(std::initializer_list
<pair
<T
, Y
>>) {}
24 map(std::initializer_list
<pair
<T
, Y
>>, int a
) {}
29 // This is the almost the exact code that was in issue #62925.
30 void testOneLevelNesting() {
31 std::map mOk
= {std::pair
{5, 'a'}, {6, 'b'}, {7, 'c'}};
33 // Verify that narrowing conversion is disabled in the first level of nesting.
34 std::map mNarrow
= {std::pair
{5, 'a'}, {6.0f
, 'b'}, {7, 'c'}}; // expected-error {{type 'float' cannot be narrowed to 'int' in initializer list}} // expected-note {{insert an explicit cast to silence this issue}}
37 void testMultipleLevelNesting() {
38 std::map aOk
= {{std::pair
{5, 'c'}, {5, 'c'}}, 5};
40 // Verify that narrowing conversion is disabled when it is not in a nested
41 // in another std::initializer_list, but it happens in the most outer one.
42 std::map aNarrowNested
= {{std::pair
{5, 'c'}, {5.0f
, 'c'}}, 5}; // expected-error {{type 'float' cannot be narrowed to 'int' in initializer list}} // expected-note {{insert an explicit cast to silence this issue}}
44 // Verify that narrowing conversion is disabled in the first level of nesting.
45 std::map aNarrow
= {{std::pair
{5, 'c'}, {5, 'c'}}, 5.0f
}; // expected-error {{type 'float' cannot be narrowed to 'int' in initializer list}} // expected-note {{insert an explicit cast to silence this issue}}