Home | History | Annotate | Download | only in map.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 // <map>
     11 
     12 // class map
     13 
     14 // void swap(map& m);
     15 
     16 #include <map>
     17 #include <cassert>
     18 
     19 #include "min_allocator.h"
     20 
     21 int main()
     22 {
     23     typedef std::pair<const int, double> V;
     24     {
     25     typedef std::map<int, double> M;
     26     {
     27         M m1;
     28         M m2;
     29         M m1_save = m1;
     30         M m2_save = m2;
     31         m1.swap(m2);
     32         assert(m1 == m2_save);
     33         assert(m2 == m1_save);
     34     }
     35     {
     36         V ar2[] =
     37         {
     38             V(5, 5),
     39             V(6, 6),
     40             V(7, 7),
     41             V(8, 8),
     42             V(9, 9),
     43             V(10, 10),
     44             V(11, 11),
     45             V(12, 12)
     46         };
     47         M m1;
     48         M m2(ar2, ar2+sizeof(ar2)/sizeof(ar2[0]));
     49         M m1_save = m1;
     50         M m2_save = m2;
     51         m1.swap(m2);
     52         assert(m1 == m2_save);
     53         assert(m2 == m1_save);
     54     }
     55     {
     56         V ar1[] =
     57         {
     58             V(1, 1),
     59             V(2, 2),
     60             V(3, 3),
     61             V(4, 4)
     62         };
     63         M m1(ar1, ar1+sizeof(ar1)/sizeof(ar1[0]));
     64         M m2;
     65         M m1_save = m1;
     66         M m2_save = m2;
     67         m1.swap(m2);
     68         assert(m1 == m2_save);
     69         assert(m2 == m1_save);
     70     }
     71     {
     72         V ar1[] =
     73         {
     74             V(1, 1),
     75             V(2, 2),
     76             V(3, 3),
     77             V(4, 4)
     78         };
     79         V ar2[] =
     80         {
     81             V(5, 5),
     82             V(6, 6),
     83             V(7, 7),
     84             V(8, 8),
     85             V(9, 9),
     86             V(10, 10),
     87             V(11, 11),
     88             V(12, 12)
     89         };
     90         M m1(ar1, ar1+sizeof(ar1)/sizeof(ar1[0]));
     91         M m2(ar2, ar2+sizeof(ar2)/sizeof(ar2[0]));
     92         M m1_save = m1;
     93         M m2_save = m2;
     94         m1.swap(m2);
     95         assert(m1 == m2_save);
     96         assert(m2 == m1_save);
     97     }
     98     }
     99 #if __cplusplus >= 201103L
    100     {
    101     typedef std::map<int, double, std::less<int>, min_allocator<V>> M;
    102     {
    103         M m1;
    104         M m2;
    105         M m1_save = m1;
    106         M m2_save = m2;
    107         m1.swap(m2);
    108         assert(m1 == m2_save);
    109         assert(m2 == m1_save);
    110     }
    111     {
    112         V ar2[] =
    113         {
    114             V(5, 5),
    115             V(6, 6),
    116             V(7, 7),
    117             V(8, 8),
    118             V(9, 9),
    119             V(10, 10),
    120             V(11, 11),
    121             V(12, 12)
    122         };
    123         M m1;
    124         M m2(ar2, ar2+sizeof(ar2)/sizeof(ar2[0]));
    125         M m1_save = m1;
    126         M m2_save = m2;
    127         m1.swap(m2);
    128         assert(m1 == m2_save);
    129         assert(m2 == m1_save);
    130     }
    131     {
    132         V ar1[] =
    133         {
    134             V(1, 1),
    135             V(2, 2),
    136             V(3, 3),
    137             V(4, 4)
    138         };
    139         M m1(ar1, ar1+sizeof(ar1)/sizeof(ar1[0]));
    140         M m2;
    141         M m1_save = m1;
    142         M m2_save = m2;
    143         m1.swap(m2);
    144         assert(m1 == m2_save);
    145         assert(m2 == m1_save);
    146     }
    147     {
    148         V ar1[] =
    149         {
    150             V(1, 1),
    151             V(2, 2),
    152             V(3, 3),
    153             V(4, 4)
    154         };
    155         V ar2[] =
    156         {
    157             V(5, 5),
    158             V(6, 6),
    159             V(7, 7),
    160             V(8, 8),
    161             V(9, 9),
    162             V(10, 10),
    163             V(11, 11),
    164             V(12, 12)
    165         };
    166         M m1(ar1, ar1+sizeof(ar1)/sizeof(ar1[0]));
    167         M m2(ar2, ar2+sizeof(ar2)/sizeof(ar2[0]));
    168         M m1_save = m1;
    169         M m2_save = m2;
    170         m1.swap(m2);
    171         assert(m1 == m2_save);
    172         assert(m2 == m1_save);
    173     }
    174     }
    175 #endif
    176 }
    177