Home | History | Annotate | Download | only in valarray.special
      1 //===----------------------------------------------------------------------===//
      2 //
      3 //                     The LLVM Compiler Infrastructure
      4 //
      5 // This file is dual licensed under the MIT and the University of Illinois Open
      6 // Source Licenses. See LICENSE.TXT for details.
      7 //
      8 //===----------------------------------------------------------------------===//
      9 
     10 // <valarray>
     11 
     12 // template<class T> class valarray;
     13 
     14 // template<class T>
     15 //   void
     16 //   swap(valarray<T>& x, valarray<T>& y);
     17 
     18 #include <valarray>
     19 #include <cassert>
     20 
     21 int main()
     22 {
     23     {
     24         typedef int T;
     25         T a1[] = {1, 2, 3, 4, 5};
     26         T a2[] = {6, 7, 8, 9, 10, 11, 12};
     27         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
     28         const unsigned N2 = sizeof(a2)/sizeof(a2[0]);
     29         std::valarray<T> v1(a1, N1);
     30         std::valarray<T> v2(a2, N2);
     31         std::valarray<T> v1_save = v1;
     32         std::valarray<T> v2_save = v2;
     33         swap(v1, v2);
     34         assert(v1.size() == v2_save.size());
     35         for (int i = 0; i < v1.size(); ++i)
     36             assert(v1[i] == v2_save[i]);
     37         assert(v2.size() == v1_save.size());
     38         for (int i = 0; i < v2.size(); ++i)
     39             assert(v2[i] == v1_save[i]);
     40     }
     41     {
     42         typedef int T;
     43         T a1[] = {1, 2, 3, 4, 5};
     44         const unsigned N1 = sizeof(a1)/sizeof(a1[0]);
     45         const unsigned N2 = 0;
     46         std::valarray<T> v1(a1, N1);
     47         std::valarray<T> v2;
     48         std::valarray<T> v1_save = v1;
     49         std::valarray<T> v2_save = v2;
     50         swap(v1, v2);
     51         assert(v1.size() == v2_save.size());
     52         for (int i = 0; i < v1.size(); ++i)
     53             assert(v1[i] == v2_save[i]);
     54         assert(v2.size() == v1_save.size());
     55         for (int i = 0; i < v2.size(); ++i)
     56             assert(v2[i] == v1_save[i]);
     57     }
     58     {
     59         typedef int T;
     60         T a2[] = {6, 7, 8, 9, 10, 11, 12};
     61         const unsigned N1 = 0;
     62         const unsigned N2 = sizeof(a2)/sizeof(a2[0]);
     63         std::valarray<T> v1;
     64         std::valarray<T> v2(a2, N2);
     65         std::valarray<T> v1_save = v1;
     66         std::valarray<T> v2_save = v2;
     67         swap(v1, v2);
     68         assert(v1.size() == v2_save.size());
     69         for (int i = 0; i < v1.size(); ++i)
     70             assert(v1[i] == v2_save[i]);
     71         assert(v2.size() == v1_save.size());
     72         for (int i = 0; i < v2.size(); ++i)
     73             assert(v2[i] == v1_save[i]);
     74     }
     75     {
     76         typedef int T;
     77         const unsigned N1 = 0;
     78         const unsigned N2 = 0;
     79         std::valarray<T> v1;
     80         std::valarray<T> v2;
     81         std::valarray<T> v1_save = v1;
     82         std::valarray<T> v2_save = v2;
     83         swap(v1, v2);
     84         assert(v1.size() == v2_save.size());
     85         for (int i = 0; i < v1.size(); ++i)
     86             assert(v1[i] == v2_save[i]);
     87         assert(v2.size() == v1_save.size());
     88         for (int i = 0; i < v2.size(); ++i)
     89             assert(v2[i] == v1_save[i]);
     90     }
     91 }
     92