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