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, const value_type& v);
125a83710eSEric Fiselier 
135a83710eSEric Fiselier #include <deque>
145a83710eSEric Fiselier #include <cassert>
15a11d322fSStephan T. Lavavej #include <cstddef>
165a83710eSEric Fiselier 
17c45b673dSEric Fiselier #include "test_macros.h"
185a83710eSEric Fiselier #include "min_allocator.h"
195a83710eSEric Fiselier 
205a83710eSEric Fiselier template <class C>
215a83710eSEric Fiselier C
make(int size,int start=0)225a83710eSEric Fiselier make(int size, int start = 0 )
235a83710eSEric Fiselier {
245a83710eSEric Fiselier     const int b = 4096 / sizeof(int);
255a83710eSEric Fiselier     int init = 0;
265a83710eSEric Fiselier     if (start > 0)
275a83710eSEric Fiselier     {
285a83710eSEric Fiselier         init = (start+1) / b + ((start+1) % b != 0);
295a83710eSEric Fiselier         init *= b;
305a83710eSEric Fiselier         --init;
315a83710eSEric Fiselier     }
325a83710eSEric Fiselier     C c(init, 0);
335a83710eSEric Fiselier     for (int i = 0; i < init-start; ++i)
345a83710eSEric Fiselier         c.pop_back();
355a83710eSEric Fiselier     for (int i = 0; i < size; ++i)
365a83710eSEric Fiselier         c.push_back(i);
375a83710eSEric Fiselier     for (int i = 0; i < start; ++i)
385a83710eSEric Fiselier         c.pop_front();
395a83710eSEric Fiselier     return c;
40861d0ea2SEric Fiselier }
415a83710eSEric Fiselier 
425a83710eSEric Fiselier template <class C>
435a83710eSEric Fiselier void
test(int P,C & c1,int x)445a83710eSEric Fiselier test(int P, C& c1, int x)
455a83710eSEric Fiselier {
465a83710eSEric Fiselier     typedef typename C::const_iterator CI;
475a83710eSEric Fiselier     std::size_t c1_osize = c1.size();
485a83710eSEric Fiselier     CI i = c1.insert(c1.begin() + P, x);
495a83710eSEric Fiselier     assert(i == c1.begin() + P);
505a83710eSEric Fiselier     assert(c1.size() == c1_osize + 1);
51*f33d7493SArthur O'Dwyer     assert(static_cast<std::size_t>(std::distance(c1.begin(), c1.end())) == c1.size());
525a83710eSEric Fiselier     i = c1.begin();
535a83710eSEric Fiselier     for (int j = 0; j < P; ++j, ++i)
545a83710eSEric Fiselier         assert(*i == j);
555a83710eSEric Fiselier     assert(*i == x);
565a83710eSEric Fiselier     ++i;
57a11d322fSStephan T. Lavavej     for (int j = P; static_cast<std::size_t>(j) < c1_osize; ++j, ++i)
585a83710eSEric Fiselier         assert(*i == j);
595a83710eSEric Fiselier }
605a83710eSEric Fiselier 
615a83710eSEric Fiselier template <class C>
625a83710eSEric Fiselier void
testN(int start,int N)635a83710eSEric Fiselier testN(int start, int N)
645a83710eSEric Fiselier {
655a83710eSEric Fiselier     for (int i = 0; i <= 3; ++i)
665a83710eSEric Fiselier     {
675a83710eSEric Fiselier         if (0 <= i && i <= N)
685a83710eSEric Fiselier         {
695a83710eSEric Fiselier             C c1 = make<C>(N, start);
705a83710eSEric Fiselier             test(i, c1, -10);
715a83710eSEric Fiselier         }
725a83710eSEric Fiselier     }
735a83710eSEric Fiselier     for (int i = N/2-1; i <= N/2+1; ++i)
745a83710eSEric Fiselier     {
755a83710eSEric Fiselier         if (0 <= i && i <= N)
765a83710eSEric Fiselier         {
775a83710eSEric Fiselier             C c1 = make<C>(N, start);
785a83710eSEric Fiselier             test(i, c1, -10);
795a83710eSEric Fiselier         }
805a83710eSEric Fiselier     }
815a83710eSEric Fiselier     for (int i = N - 3; i <= N; ++i)
825a83710eSEric Fiselier     {
835a83710eSEric Fiselier         if (0 <= i && i <= N)
845a83710eSEric Fiselier         {
855a83710eSEric Fiselier             C c1 = make<C>(N, start);
865a83710eSEric Fiselier             test(i, c1, -10);
875a83710eSEric Fiselier         }
885a83710eSEric Fiselier     }
895a83710eSEric Fiselier }
905a83710eSEric Fiselier 
915a83710eSEric Fiselier template <class C>
925a83710eSEric Fiselier void
self_reference_test()935a83710eSEric Fiselier self_reference_test()
945a83710eSEric Fiselier {
955a83710eSEric Fiselier     typedef typename C::const_iterator CI;
965a83710eSEric Fiselier     for (int i = 0; i < 20; ++i)
975a83710eSEric Fiselier     {
985a83710eSEric Fiselier         for (int j = 0; j < 20; ++j)
995a83710eSEric Fiselier         {
1005a83710eSEric Fiselier             C c = make<C>(20);
1015a83710eSEric Fiselier             CI it = c.cbegin() + i;
1025a83710eSEric Fiselier             CI jt = c.cbegin() + j;
1035a83710eSEric Fiselier             c.insert(it, *jt);
1045a83710eSEric Fiselier             assert(c.size() == 21);
105*f33d7493SArthur O'Dwyer             assert(static_cast<std::size_t>(std::distance(c.begin(), c.end())) == c.size());
1065a83710eSEric Fiselier             it = c.cbegin();
1075a83710eSEric Fiselier             for (int k = 0; k < i; ++k, ++it)
1085a83710eSEric Fiselier                 assert(*it == k);
1095a83710eSEric Fiselier             assert(*it == j);
1105a83710eSEric Fiselier             ++it;
1115a83710eSEric Fiselier             for (int k = i; k < 20; ++k, ++it)
1125a83710eSEric Fiselier                 assert(*it == k);
1135a83710eSEric Fiselier         }
1145a83710eSEric Fiselier     }
1155a83710eSEric Fiselier }
1165a83710eSEric Fiselier 
main(int,char **)1172df59c50SJF Bastien int main(int, char**)
1185a83710eSEric Fiselier {
1195a83710eSEric Fiselier     {
1205a83710eSEric Fiselier     int rng[] = {0, 1, 2, 3, 1023, 1024, 1025, 2047, 2048, 2049};
1215a83710eSEric Fiselier     const int N = sizeof(rng)/sizeof(rng[0]);
1225a83710eSEric Fiselier     for (int i = 0; i < N; ++i)
1235a83710eSEric Fiselier         for (int j = 0; j < N; ++j)
1245a83710eSEric Fiselier             testN<std::deque<int> >(rng[i], rng[j]);
1255a83710eSEric Fiselier     self_reference_test<std::deque<int> >();
1265a83710eSEric Fiselier     }
127c45b673dSEric Fiselier #if TEST_STD_VER >= 11
1285a83710eSEric Fiselier     {
1295a83710eSEric Fiselier     int rng[] = {0, 1, 2, 3, 1023, 1024, 1025, 2047, 2048, 2049};
1305a83710eSEric Fiselier     const int N = sizeof(rng)/sizeof(rng[0]);
1315a83710eSEric Fiselier     for (int i = 0; i < N; ++i)
1325a83710eSEric Fiselier         for (int j = 0; j < N; ++j)
1335a83710eSEric Fiselier             testN<std::deque<int, min_allocator<int>> >(rng[i], rng[j]);
1345a83710eSEric Fiselier     self_reference_test<std::deque<int, min_allocator<int>> >();
1355a83710eSEric Fiselier     }
1365a83710eSEric Fiselier #endif
1372df59c50SJF Bastien 
1382df59c50SJF Bastien   return 0;
1395a83710eSEric Fiselier }
140