// RUN: %clang_cc1 -std=c++2c -fexperimental-new-constant-interpreter -verify=expected,both %s // RUN: %clang_cc1 -std=c++2c -verify=ref,both %s /// This used to cause problems because the heap-allocated array /// is initialized by an ImplicitValueInitExpr of incomplete array type. inline namespace { template < class _Tp > using __add_lvalue_reference_t = __add_lvalue_reference(_Tp); template < class _Tp > using __remove_extent_t = __remove_extent(_Tp); } inline namespace { template < class > class unique_ptr; template < class _Tp > struct unique_ptr< _Tp[] > { _Tp *__ptr_; template < class _Tag, class _Ptr> constexpr unique_ptr(_Tag, _Ptr __ptr, unsigned) : __ptr_(__ptr){} constexpr ~unique_ptr() { delete[] __ptr_; } constexpr __add_lvalue_reference_t< _Tp > operator[](decltype(sizeof(int)) __i) { return __ptr_[__i]; }}; constexpr unique_ptr< int[] > make_unique(decltype(sizeof(int)) __n) { return unique_ptr< int[] >(int(), new __remove_extent_t< int>[__n](), __n); }} constexpr bool test() { auto p1 = make_unique(5); (p1[0] == 0); // both-warning {{expression result unused}} return true; } static_assert(test());