// RUN: %clang_cc1 -std=c++11 -fsyntax-only -verify %s struct one { char c[1]; }; struct two { char c[2]; }; namespace std { typedef decltype(sizeof(int)) size_t; // libc++'s implementation template <class _E> class initializer_list { const _E* __begin_; size_t __size_; initializer_list(const _E* __b, size_t __s) : __begin_(__b), __size_(__s) {} public: typedef _E value_type; typedef const _E& reference; typedef const _E& const_reference; typedef size_t size_type; typedef const _E* iterator; typedef const _E* const_iterator; initializer_list() : __begin_(nullptr), __size_(0) {} size_t size() const {return __size_;} const _E* begin() const {return __begin_;} const _E* end() const {return __begin_ + __size_;} }; } namespace integral { void initialization() { { const int a{}; static_assert(a == 0, ""); } { const int a = {}; static_assert(a == 0, ""); } { const int a{1}; static_assert(a == 1, ""); } { const int a = {1}; static_assert(a == 1, ""); } { const int a{1, 2}; } // expected-error {{excess elements}} { const int a = {1, 2}; } // expected-error {{excess elements}} // FIXME: Redundant warnings. { const short a{100000}; } // expected-error {{cannot be narrowed}} expected-note {{inserting an explicit cast}} expected-warning {{changes value}} { const short a = {100000}; } // expected-error {{cannot be narrowed}} expected-note {{inserting an explicit cast}} expected-warning {{changes value}} { if (const int a{1}) static_assert(a == 1, ""); } { if (const int a = {1}) static_assert(a == 1, ""); } } int direct_usage() { int ar[10]; (void) ar[{1}]; // expected-error {{array subscript is not an integer}} return {1}; } void inline_init() { auto v = int{1}; (void) new int{1}; } struct A { int i; A() : i{1} {} }; void function_call() { void takes_int(int); takes_int({1}); } void overloaded_call() { one overloaded(int); two overloaded(double); static_assert(sizeof(overloaded({0})) == sizeof(one), "bad overload"); static_assert(sizeof(overloaded({0.0})) == sizeof(two), "bad overload"); void ambiguous(int, double); // expected-note {{candidate}} void ambiguous(double, int); // expected-note {{candidate}} ambiguous({0}, {0}); // expected-error {{ambiguous}} void emptylist(int); void emptylist(int, int, int); emptylist({}); emptylist({}, {}, {}); } void edge_cases() { // FIXME: very poor error message int a({0}); // expected-error {{cannot initialize}} (void) int({0}); // expected-error {{functional-style cast}} new int({0}); // expected-error {{cannot initialize}} } void default_argument(int i = {}) { } struct DefaultArgument { void default_argument(int i = {}) { } }; } namespace PR12118 { void test() { one f(std::initializer_list<int>); two f(int); // to initializer_list is preferred static_assert(sizeof(f({0})) == sizeof(one), "bad overload"); } }