blob: e24a930b7c4e88a9d3b16e71fb2cf7a6f32431e3 [file] [log] [blame]
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00001//===----------------------------------------------------------------------===//
2//
Howard Hinnantf5256e12010-05-11 21:36:01 +00003// The LLVM Compiler Infrastructure
Howard Hinnantbc8d3f92010-05-11 19:42:16 +00004//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10// <set>
11
12// class set
13
14// set(initializer_list<value_type> il, const key_compare& comp = key_compare());
15
16#include <set>
17#include <cassert>
18#include "../../../test_compare.h"
19
20int main()
21{
Howard Hinnant73d21a42010-09-04 23:28:19 +000022#ifndef _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000023 typedef test_compare<std::less<int> > Cmp;
24 typedef std::set<int, Cmp> C;
25 typedef C::value_type V;
26 C m({1, 2, 3, 4, 5, 6}, Cmp(10));
27 assert(m.size() == 6);
28 assert(distance(m.begin(), m.end()) == 6);
29 C::const_iterator i = m.cbegin();
30 assert(*i == V(1));
31 assert(*++i == V(2));
32 assert(*++i == V(3));
33 assert(*++i == V(4));
34 assert(*++i == V(5));
35 assert(*++i == V(6));
36 assert(m.key_comp() == Cmp(10));
Howard Hinnant73d21a42010-09-04 23:28:19 +000037#endif // _LIBCPP_HAS_NO_RVALUE_REFERENCES
Howard Hinnantbc8d3f92010-05-11 19:42:16 +000038}