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 
931cbe0f2SLouis Dionne // UNSUPPORTED: c++03
10922940b6SEric Fiselier 
115a83710eSEric Fiselier // <set>
125a83710eSEric Fiselier 
135a83710eSEric Fiselier // class set
145a83710eSEric Fiselier 
155a83710eSEric Fiselier // pair<iterator, bool> insert(value_type&& v);
165a83710eSEric Fiselier 
175a83710eSEric Fiselier #include <set>
185a83710eSEric Fiselier #include <cassert>
195a83710eSEric Fiselier 
207fc6a556SMarshall Clow #include "test_macros.h"
21949389c3SMarshall Clow #include "MoveOnly.h"
225a83710eSEric Fiselier #include "min_allocator.h"
235a83710eSEric Fiselier 
main(int,char **)242df59c50SJF Bastien int main(int, char**)
255a83710eSEric Fiselier {
265a83710eSEric Fiselier     {
275a83710eSEric Fiselier         typedef std::set<MoveOnly> M;
285a83710eSEric Fiselier         typedef std::pair<M::iterator, bool> R;
295a83710eSEric Fiselier         M m;
305a83710eSEric Fiselier         R r = m.insert(M::value_type(2));
315a83710eSEric Fiselier         assert(r.second);
325a83710eSEric Fiselier         assert(r.first == m.begin());
335a83710eSEric Fiselier         assert(m.size() == 1);
345a83710eSEric Fiselier         assert(*r.first == 2);
355a83710eSEric Fiselier 
365a83710eSEric Fiselier         r = m.insert(M::value_type(1));
375a83710eSEric Fiselier         assert(r.second);
385a83710eSEric Fiselier         assert(r.first == m.begin());
395a83710eSEric Fiselier         assert(m.size() == 2);
405a83710eSEric Fiselier         assert(*r.first == 1);
415a83710eSEric Fiselier 
425a83710eSEric Fiselier         r = m.insert(M::value_type(3));
435a83710eSEric Fiselier         assert(r.second);
44*3b966c1fSArthur O'Dwyer         assert(r.first == std::prev(m.end()));
455a83710eSEric Fiselier         assert(m.size() == 3);
465a83710eSEric Fiselier         assert(*r.first == 3);
475a83710eSEric Fiselier 
485a83710eSEric Fiselier         r = m.insert(M::value_type(3));
495a83710eSEric Fiselier         assert(!r.second);
50*3b966c1fSArthur O'Dwyer         assert(r.first == std::prev(m.end()));
515a83710eSEric Fiselier         assert(m.size() == 3);
525a83710eSEric Fiselier         assert(*r.first == 3);
535a83710eSEric Fiselier     }
545a83710eSEric Fiselier     {
555a83710eSEric Fiselier         typedef std::set<MoveOnly, std::less<MoveOnly>, min_allocator<MoveOnly>> M;
565a83710eSEric Fiselier         typedef std::pair<M::iterator, bool> R;
575a83710eSEric Fiselier         M m;
585a83710eSEric Fiselier         R r = m.insert(M::value_type(2));
595a83710eSEric Fiselier         assert(r.second);
605a83710eSEric Fiselier         assert(r.first == m.begin());
615a83710eSEric Fiselier         assert(m.size() == 1);
625a83710eSEric Fiselier         assert(*r.first == 2);
635a83710eSEric Fiselier 
645a83710eSEric Fiselier         r = m.insert(M::value_type(1));
655a83710eSEric Fiselier         assert(r.second);
665a83710eSEric Fiselier         assert(r.first == m.begin());
675a83710eSEric Fiselier         assert(m.size() == 2);
685a83710eSEric Fiselier         assert(*r.first == 1);
695a83710eSEric Fiselier 
705a83710eSEric Fiselier         r = m.insert(M::value_type(3));
715a83710eSEric Fiselier         assert(r.second);
72*3b966c1fSArthur O'Dwyer         assert(r.first == std::prev(m.end()));
735a83710eSEric Fiselier         assert(m.size() == 3);
745a83710eSEric Fiselier         assert(*r.first == 3);
755a83710eSEric Fiselier 
765a83710eSEric Fiselier         r = m.insert(M::value_type(3));
775a83710eSEric Fiselier         assert(!r.second);
78*3b966c1fSArthur O'Dwyer         assert(r.first == std::prev(m.end()));
795a83710eSEric Fiselier         assert(m.size() == 3);
805a83710eSEric Fiselier         assert(*r.first == 3);
815a83710eSEric Fiselier     }
822df59c50SJF Bastien 
832df59c50SJF Bastien   return 0;
845a83710eSEric Fiselier }
85