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 Bastienint 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