1*a8cf78c7SLouis Dionne //===---------------------------------------------------------------------===//
2*a8cf78c7SLouis Dionne //
3*a8cf78c7SLouis Dionne // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*a8cf78c7SLouis Dionne // See https://llvm.org/LICENSE.txt for license information.
5*a8cf78c7SLouis Dionne // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*a8cf78c7SLouis Dionne //
7*a8cf78c7SLouis Dionne //===---------------------------------------------------------------------===//
8*a8cf78c7SLouis Dionne // UNSUPPORTED: c++03, c++11, c++14, c++17
9*a8cf78c7SLouis Dionne 
10*a8cf78c7SLouis Dionne // <span>
11*a8cf78c7SLouis Dionne 
12*a8cf78c7SLouis Dionne // template <class It, class End>
13*a8cf78c7SLouis Dionne // constexpr explicit(Extent != dynamic_extent) span(It first, End last);
14*a8cf78c7SLouis Dionne // Requires: [first, last) shall be a valid range.
15*a8cf78c7SLouis Dionne //   If Extent is not equal to dynamic_extent, then last - first shall be equal to Extent.
16*a8cf78c7SLouis Dionne //
17*a8cf78c7SLouis Dionne 
18*a8cf78c7SLouis Dionne #include <span>
19*a8cf78c7SLouis Dionne #include <iterator>
20*a8cf78c7SLouis Dionne 
21*a8cf78c7SLouis Dionne 
22*a8cf78c7SLouis Dionne template<class T, size_t Extent>
createImplicitSpan(T * first,T * last)23*a8cf78c7SLouis Dionne std::span<T, Extent> createImplicitSpan(T* first, T* last) {
24*a8cf78c7SLouis Dionne     return {first, last}; // expected-error {{chosen constructor is explicit in copy-initialization}}
25*a8cf78c7SLouis Dionne }
26*a8cf78c7SLouis Dionne 
main(int,char **)27*a8cf78c7SLouis Dionne int main(int, char**) {
28*a8cf78c7SLouis Dionne   // explicit constructor necessary
29*a8cf78c7SLouis Dionne   int arr[] = {1, 2, 3};
30*a8cf78c7SLouis Dionne   createImplicitSpan<int, 1>(std::begin(arr), std::end(arr));
31*a8cf78c7SLouis Dionne 
32*a8cf78c7SLouis Dionne   return 0;
33*a8cf78c7SLouis Dionne }
34