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 // void swap(valarray& v);
145a83710eSEric Fiselier
155a83710eSEric Fiselier #include <valarray>
165a83710eSEric Fiselier #include <cassert>
17e898b484SStephan T. Lavavej #include <cstddef>
185a83710eSEric Fiselier
19*7fc6a556SMarshall Clow #include "test_macros.h"
20*7fc6a556SMarshall Clow
main(int,char **)212df59c50SJF Bastien int main(int, char**)
225a83710eSEric Fiselier {
235a83710eSEric Fiselier {
245a83710eSEric Fiselier typedef int T;
255a83710eSEric Fiselier T a1[] = {1, 2, 3, 4, 5};
265a83710eSEric Fiselier T a2[] = {6, 7, 8, 9, 10, 11, 12};
275a83710eSEric Fiselier const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
285a83710eSEric Fiselier const unsigned N2 = sizeof(a2)/sizeof(a2[0]);
295a83710eSEric Fiselier std::valarray<T> v1(a1, N1);
305a83710eSEric Fiselier std::valarray<T> v2(a2, N2);
315a83710eSEric Fiselier std::valarray<T> v1_save = v1;
325a83710eSEric Fiselier std::valarray<T> v2_save = v2;
335a83710eSEric Fiselier v1.swap(v2);
345a83710eSEric Fiselier assert(v1.size() == v2_save.size());
35e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v1.size(); ++i)
365a83710eSEric Fiselier assert(v1[i] == v2_save[i]);
375a83710eSEric Fiselier assert(v2.size() == v1_save.size());
38e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v2.size(); ++i)
395a83710eSEric Fiselier assert(v2[i] == v1_save[i]);
405a83710eSEric Fiselier }
415a83710eSEric Fiselier {
425a83710eSEric Fiselier typedef int T;
435a83710eSEric Fiselier T a1[] = {1, 2, 3, 4, 5};
445a83710eSEric Fiselier const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
455a83710eSEric Fiselier std::valarray<T> v1(a1, N1);
465a83710eSEric Fiselier std::valarray<T> v2;
475a83710eSEric Fiselier std::valarray<T> v1_save = v1;
485a83710eSEric Fiselier std::valarray<T> v2_save = v2;
495a83710eSEric Fiselier v1.swap(v2);
505a83710eSEric Fiselier assert(v1.size() == v2_save.size());
51e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v1.size(); ++i)
525a83710eSEric Fiselier assert(v1[i] == v2_save[i]);
535a83710eSEric Fiselier assert(v2.size() == v1_save.size());
54e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v2.size(); ++i)
555a83710eSEric Fiselier assert(v2[i] == v1_save[i]);
565a83710eSEric Fiselier }
575a83710eSEric Fiselier {
585a83710eSEric Fiselier typedef int T;
595a83710eSEric Fiselier T a2[] = {6, 7, 8, 9, 10, 11, 12};
605a83710eSEric Fiselier const unsigned N2 = sizeof(a2)/sizeof(a2[0]);
615a83710eSEric Fiselier std::valarray<T> v1;
625a83710eSEric Fiselier std::valarray<T> v2(a2, N2);
635a83710eSEric Fiselier std::valarray<T> v1_save = v1;
645a83710eSEric Fiselier std::valarray<T> v2_save = v2;
655a83710eSEric Fiselier v1.swap(v2);
665a83710eSEric Fiselier assert(v1.size() == v2_save.size());
67e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v1.size(); ++i)
685a83710eSEric Fiselier assert(v1[i] == v2_save[i]);
695a83710eSEric Fiselier assert(v2.size() == v1_save.size());
70e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v2.size(); ++i)
715a83710eSEric Fiselier assert(v2[i] == v1_save[i]);
725a83710eSEric Fiselier }
735a83710eSEric Fiselier {
745a83710eSEric Fiselier typedef int T;
755a83710eSEric Fiselier std::valarray<T> v1;
765a83710eSEric Fiselier std::valarray<T> v2;
775a83710eSEric Fiselier std::valarray<T> v1_save = v1;
785a83710eSEric Fiselier std::valarray<T> v2_save = v2;
795a83710eSEric Fiselier v1.swap(v2);
805a83710eSEric Fiselier assert(v1.size() == v2_save.size());
81e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v1.size(); ++i)
825a83710eSEric Fiselier assert(v1[i] == v2_save[i]);
835a83710eSEric Fiselier assert(v2.size() == v1_save.size());
84e898b484SStephan T. Lavavej for (std::size_t i = 0; i < v2.size(); ++i)
855a83710eSEric Fiselier assert(v2[i] == v1_save[i]);
865a83710eSEric Fiselier }
872df59c50SJF Bastien
882df59c50SJF Bastien return 0;
895a83710eSEric Fiselier }
90