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
95a83710eSEric Fiselier // <deque>
105a83710eSEric Fiselier
115a83710eSEric Fiselier // iterator insert (const_iterator p, value_type&& v);
125a83710eSEric Fiselier
1331cbe0f2SLouis Dionne // UNSUPPORTED: c++03
14c45b673dSEric Fiselier
155a83710eSEric Fiselier #include <deque>
165a83710eSEric Fiselier #include <cassert>
17a11d322fSStephan T. Lavavej #include <cstddef>
185a83710eSEric Fiselier
197fc6a556SMarshall Clow #include "test_macros.h"
20949389c3SMarshall Clow #include "MoveOnly.h"
215a83710eSEric Fiselier #include "min_allocator.h"
225a83710eSEric Fiselier
235a83710eSEric Fiselier
245a83710eSEric Fiselier template <class C>
255a83710eSEric Fiselier C
make(int size,int start=0)265a83710eSEric Fiselier make(int size, int start = 0 )
275a83710eSEric Fiselier {
285a83710eSEric Fiselier const int b = 4096 / sizeof(int);
295a83710eSEric Fiselier int init = 0;
305a83710eSEric Fiselier if (start > 0)
315a83710eSEric Fiselier {
325a83710eSEric Fiselier init = (start+1) / b + ((start+1) % b != 0);
335a83710eSEric Fiselier init *= b;
345a83710eSEric Fiselier --init;
355a83710eSEric Fiselier }
365a83710eSEric Fiselier C c(init);
375a83710eSEric Fiselier for (int i = 0; i < init-start; ++i)
385a83710eSEric Fiselier c.pop_back();
395a83710eSEric Fiselier for (int i = 0; i < size; ++i)
405a83710eSEric Fiselier c.push_back(MoveOnly(i));
415a83710eSEric Fiselier for (int i = 0; i < start; ++i)
425a83710eSEric Fiselier c.pop_front();
435a83710eSEric Fiselier return c;
44861d0ea2SEric Fiselier }
455a83710eSEric Fiselier
465a83710eSEric Fiselier template <class C>
475a83710eSEric Fiselier void
test(int P,C & c1,int x)485a83710eSEric Fiselier test(int P, C& c1, int x)
495a83710eSEric Fiselier {
505a83710eSEric Fiselier typedef typename C::const_iterator CI;
515a83710eSEric Fiselier std::size_t c1_osize = c1.size();
525a83710eSEric Fiselier CI i = c1.insert(c1.begin() + P, MoveOnly(x));
535a83710eSEric Fiselier assert(i == c1.begin() + P);
545a83710eSEric Fiselier assert(c1.size() == c1_osize + 1);
55*f33d7493SArthur O'Dwyer assert(static_cast<std::size_t>(std::distance(c1.begin(), c1.end())) == c1.size());
565a83710eSEric Fiselier i = c1.begin();
5716bf4339SArthur O'Dwyer for (int j = 0; j < P; ++j, (void) ++i)
585a83710eSEric Fiselier assert(*i == MoveOnly(j));
595a83710eSEric Fiselier assert(*i == MoveOnly(x));
605a83710eSEric Fiselier ++i;
6116bf4339SArthur O'Dwyer for (int j = P; static_cast<std::size_t>(j) < c1_osize; ++j, (void) ++i)
625a83710eSEric Fiselier assert(*i == MoveOnly(j));
635a83710eSEric Fiselier }
645a83710eSEric Fiselier
655a83710eSEric Fiselier template <class C>
665a83710eSEric Fiselier void
testN(int start,int N)675a83710eSEric Fiselier testN(int start, int N)
685a83710eSEric Fiselier {
695a83710eSEric Fiselier for (int i = 0; i <= 3; ++i)
705a83710eSEric Fiselier {
715a83710eSEric Fiselier if (0 <= i && i <= N)
725a83710eSEric Fiselier {
735a83710eSEric Fiselier C c1 = make<C>(N, start);
745a83710eSEric Fiselier test(i, c1, -10);
755a83710eSEric Fiselier }
765a83710eSEric Fiselier }
775a83710eSEric Fiselier for (int i = N/2-1; i <= N/2+1; ++i)
785a83710eSEric Fiselier {
795a83710eSEric Fiselier if (0 <= i && i <= N)
805a83710eSEric Fiselier {
815a83710eSEric Fiselier C c1 = make<C>(N, start);
825a83710eSEric Fiselier test(i, c1, -10);
835a83710eSEric Fiselier }
845a83710eSEric Fiselier }
855a83710eSEric Fiselier for (int i = N - 3; i <= N; ++i)
865a83710eSEric Fiselier {
875a83710eSEric Fiselier if (0 <= i && i <= N)
885a83710eSEric Fiselier {
895a83710eSEric Fiselier C c1 = make<C>(N, start);
905a83710eSEric Fiselier test(i, c1, -10);
915a83710eSEric Fiselier }
925a83710eSEric Fiselier }
935a83710eSEric Fiselier }
945a83710eSEric Fiselier
main(int,char **)952df59c50SJF Bastien int main(int, char**)
965a83710eSEric Fiselier {
975a83710eSEric Fiselier {
985a83710eSEric Fiselier int rng[] = {0, 1, 2, 3, 1023, 1024, 1025, 2047, 2048, 2049};
995a83710eSEric Fiselier const int N = sizeof(rng)/sizeof(rng[0]);
1005a83710eSEric Fiselier for (int i = 0; i < N; ++i)
1015a83710eSEric Fiselier for (int j = 0; j < N; ++j)
1025a83710eSEric Fiselier testN<std::deque<MoveOnly> >(rng[i], rng[j]);
1035a83710eSEric Fiselier }
1045a83710eSEric Fiselier {
1055a83710eSEric Fiselier int rng[] = {0, 1, 2, 3, 1023, 1024, 1025, 2047, 2048, 2049};
1065a83710eSEric Fiselier const int N = sizeof(rng)/sizeof(rng[0]);
1075a83710eSEric Fiselier for (int i = 0; i < N; ++i)
1085a83710eSEric Fiselier for (int j = 0; j < N; ++j)
1095a83710eSEric Fiselier testN<std::deque<MoveOnly, min_allocator<MoveOnly>> >(rng[i], rng[j]);
1105a83710eSEric Fiselier }
1112df59c50SJF Bastien
1122df59c50SJF Bastien return 0;
1135a83710eSEric Fiselier }
114