blob: 5a6eca09b51ab632c65c5a42e680c86561eba9d4 [file] [log] [blame]
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001//===----------------------------------------------------------------------===//
2//
Howard Hinnantf5256e12010-05-11 21:36:01 +00003// The LLVM Compiler Infrastructure
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00004//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10// <valarray>
11
12// template<class T> class valarray;
13
14// valarray(initializer_list<value_type>);
15
16#include <valarray>
17#include <cassert>
18
19int main()
20{
Howard Hinnant73d21a42010-09-04 23:28:19 +000021#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000022 {
23 typedef int T;
24 T a[] = {1, 2, 3, 4, 5};
25 const unsigned N = sizeof(a)/sizeof(a[0]);
26 std::valarray<T> v = {1, 2, 3, 4, 5};
27 assert(v.size() == N);
28 for (int i = 0; i < N; ++i)
29 assert(v[i] == a[i]);
30 }
31 {
32 typedef double T;
33 T a[] = {1, 2, 3, 4, 5};
34 const unsigned N = sizeof(a)/sizeof(a[0]);
35 std::valarray<T> v = {1, 2, 3, 4, 5};
36 assert(v.size() == N);
37 for (int i = 0; i < N; ++i)
38 assert(v[i] == a[i]);
39 }
Howard Hinnant73d21a42010-09-04 23:28:19 +000040#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000041}