15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier 
95a83710eSEric Fiselier // <valarray>
105a83710eSEric Fiselier 
115a83710eSEric Fiselier // template<class T> class valarray;
125a83710eSEric Fiselier 
135a83710eSEric Fiselier // valarray& operator=(const indirect_array<value_type>& ia);
145a83710eSEric Fiselier 
155a83710eSEric Fiselier #include <valarray>
165a83710eSEric Fiselier #include <cassert>
175a83710eSEric Fiselier 
18*7fc6a556SMarshall Clow #include "test_macros.h"
19*7fc6a556SMarshall Clow 
main(int,char **)202df59c50SJF Bastien int main(int, char**)
215a83710eSEric Fiselier {
225a83710eSEric Fiselier     int a[] = { 0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11,
235a83710eSEric Fiselier                12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23,
245a83710eSEric Fiselier                24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35,
255a83710eSEric Fiselier                36, 37, 38, 39, 40};
265a83710eSEric Fiselier     const std::size_t N1 = sizeof(a)/sizeof(a[0]);
275a83710eSEric Fiselier     std::size_t s[] = { 3,  4,  5,  7,  8,  9, 11, 12, 13, 15, 16, 17,
285a83710eSEric Fiselier                        22, 23, 24, 26, 27, 28, 30, 31, 32, 34, 35, 36};
295a83710eSEric Fiselier     const std::size_t S = sizeof(s)/sizeof(s[0]);
305a83710eSEric Fiselier     std::valarray<int> v1(a, N1);
315a83710eSEric Fiselier     std::valarray<std::size_t> ia(s, S);
325a83710eSEric Fiselier     std::valarray<int> v(24);
335a83710eSEric Fiselier     v = v1[ia];
345a83710eSEric Fiselier     assert(v.size() == 24);
355a83710eSEric Fiselier     assert(v[ 0] ==  3);
365a83710eSEric Fiselier     assert(v[ 1] ==  4);
375a83710eSEric Fiselier     assert(v[ 2] ==  5);
385a83710eSEric Fiselier     assert(v[ 3] ==  7);
395a83710eSEric Fiselier     assert(v[ 4] ==  8);
405a83710eSEric Fiselier     assert(v[ 5] ==  9);
415a83710eSEric Fiselier     assert(v[ 6] == 11);
425a83710eSEric Fiselier     assert(v[ 7] == 12);
435a83710eSEric Fiselier     assert(v[ 8] == 13);
445a83710eSEric Fiselier     assert(v[ 9] == 15);
455a83710eSEric Fiselier     assert(v[10] == 16);
465a83710eSEric Fiselier     assert(v[11] == 17);
475a83710eSEric Fiselier     assert(v[12] == 22);
485a83710eSEric Fiselier     assert(v[13] == 23);
495a83710eSEric Fiselier     assert(v[14] == 24);
505a83710eSEric Fiselier     assert(v[15] == 26);
515a83710eSEric Fiselier     assert(v[16] == 27);
525a83710eSEric Fiselier     assert(v[17] == 28);
535a83710eSEric Fiselier     assert(v[18] == 30);
545a83710eSEric Fiselier     assert(v[19] == 31);
555a83710eSEric Fiselier     assert(v[20] == 32);
565a83710eSEric Fiselier     assert(v[21] == 34);
575a83710eSEric Fiselier     assert(v[22] == 35);
585a83710eSEric Fiselier     assert(v[23] == 36);
592df59c50SJF Bastien 
602df59c50SJF Bastien   return 0;
615a83710eSEric Fiselier }
62