59 namespace std _GLIBCXX_VISIBILITY(default)
    61 _GLIBCXX_BEGIN_NAMESPACE_CONTAINER
    63 #if __cplusplus >= 201103L    64   template <
typename _Tp, 
typename _Alloc>
    67     _M_default_initialize()
    72           for (__cur = this->_M_impl._M_start._M_node;
    73                __cur < this->_M_impl._M_finish._M_node;
    75             std::__uninitialized_default_a(*__cur, *__cur + _S_buffer_size(),
    76                                            _M_get_Tp_allocator());
    77           std::__uninitialized_default_a(this->_M_impl._M_finish._M_first,
    78                                          this->_M_impl._M_finish._M_cur,
    79                                          _M_get_Tp_allocator());
    83           std::_Destroy(this->_M_impl._M_start, iterator(*__cur, __cur),
    84                         _M_get_Tp_allocator());
    85           __throw_exception_again;
    90   template <
typename _Tp, 
typename _Alloc>
    97 #if __cplusplus >= 201103L    98           if (_Alloc_traits::_S_propagate_on_copy_assign())
   100               if (!_Alloc_traits::_S_always_equal()
   101                   && _M_get_Tp_allocator() != __x._M_get_Tp_allocator())
   106                   std::__alloc_on_copy(_M_get_Tp_allocator(),
   107                                        __x._M_get_Tp_allocator());
   110               std::__alloc_on_copy(_M_get_Tp_allocator(),
   111                                    __x._M_get_Tp_allocator());
   114           const size_type __len = size();
   115           if (__len >= __x.
size())
   116             _M_erase_at_end(std::copy(__x.
begin(), __x.
end(),
   117                                       this->_M_impl._M_start));
   121               std::copy(__x.
begin(), __mid, this->_M_impl._M_start);
   122               insert(this->_M_impl._M_finish, __mid, __x.
end());
   128 #if __cplusplus >= 201103L   129   template<
typename _Tp, 
typename _Alloc>
   130     template<
typename... _Args>
   135         if (this->_M_impl._M_start._M_cur != this->_M_impl._M_start._M_first)
   137             _Alloc_traits::construct(this->_M_impl,
   138                                      this->_M_impl._M_start._M_cur - 1,
   139                                      std::forward<_Args>(__args)...);
   140             --this->_M_impl._M_start._M_cur;
   143           _M_push_front_aux(std::forward<_Args>(__args)...);
   146   template<
typename _Tp, 
typename _Alloc>
   147     template<
typename... _Args>
   152         if (this->_M_impl._M_finish._M_cur
   153             != this->_M_impl._M_finish._M_last - 1)
   155             _Alloc_traits::construct(this->_M_impl,
   156                                      this->_M_impl._M_finish._M_cur,
   157                                      std::forward<_Args>(__args)...);
   158             ++this->_M_impl._M_finish._M_cur;
   161           _M_push_back_aux(std::forward<_Args>(__args)...);
   165 #if __cplusplus >= 201103L   166   template<
typename _Tp, 
typename _Alloc>
   167     template<
typename... _Args>
   172         if (__position._M_cur == this->_M_impl._M_start._M_cur)
   174             emplace_front(std::forward<_Args>(__args)...);
   175             return this->_M_impl._M_start;
   177         else if (__position._M_cur == this->_M_impl._M_finish._M_cur)
   179             emplace_back(std::forward<_Args>(__args)...);
   180             iterator __tmp = this->_M_impl._M_finish;
   185           return _M_insert_aux(__position._M_const_cast(),
   186                                std::forward<_Args>(__args)...);
   190   template <
typename _Tp, 
typename _Alloc>
   193 #if __cplusplus >= 201103L   196     insert(
iterator __position, 
const value_type& __x)
   199       if (__position._M_cur == this->_M_impl._M_start._M_cur)
   202           return this->_M_impl._M_start;
   204       else if (__position._M_cur == this->_M_impl._M_finish._M_cur)
   207           iterator __tmp = this->_M_impl._M_finish;
   212         return _M_insert_aux(__position._M_const_cast(), __x);
   215   template <
typename _Tp, 
typename _Alloc>
   222       const difference_type __index = __position - 
begin();
   223       if (static_cast<size_type>(__index) < (size() >> 1))
   225           if (__position != 
begin())
   226             _GLIBCXX_MOVE_BACKWARD3(
begin(), __position, __next);
   232             _GLIBCXX_MOVE3(__next, 
end(), __position);
   235       return begin() + __index;
   238   template <
typename _Tp, 
typename _Alloc>
   243       if (__first == __last)
   245       else if (__first == 
begin() && __last == 
end())
   252           const difference_type __n = __last - __first;
   253           const difference_type __elems_before = __first - 
begin();
   254           if (static_cast<size_type>(__elems_before) <= (size() - __n) / 2)
   256               if (__first != 
begin())
   257                 _GLIBCXX_MOVE_BACKWARD3(
begin(), __first, __last);
   258               _M_erase_at_begin(
begin() + __n);
   263                 _GLIBCXX_MOVE3(__last, 
end(), __first);
   264               _M_erase_at_end(
end() - __n);
   266           return begin() + __elems_before;
   270   template <
typename _Tp, 
class _Alloc>
   271     template <
typename _InputIterator>
   278         for (; __first != __last && __cur != 
end(); ++__cur, ++__first)
   280         if (__first == __last)
   281           _M_erase_at_end(__cur);
   283           insert(
end(), __first, __last);
   286   template <
typename _Tp, 
typename _Alloc>
   291       if (__pos._M_cur == this->_M_impl._M_start._M_cur)
   293           iterator __new_start = _M_reserve_elements_at_front(__n);
   296               std::__uninitialized_fill_a(__new_start, this->_M_impl._M_start,
   297                                           __x, _M_get_Tp_allocator());
   298               this->_M_impl._M_start = __new_start;
   302               _M_destroy_nodes(__new_start._M_node,
   303                                this->_M_impl._M_start._M_node);
   304               __throw_exception_again;
   307       else if (__pos._M_cur == this->_M_impl._M_finish._M_cur)
   309           iterator __new_finish = _M_reserve_elements_at_back(__n);
   312               std::__uninitialized_fill_a(this->_M_impl._M_finish,
   314                                           _M_get_Tp_allocator());
   315               this->_M_impl._M_finish = __new_finish;
   319               _M_destroy_nodes(this->_M_impl._M_finish._M_node + 1,
   320                                __new_finish._M_node + 1);
   321               __throw_exception_again;
   325         _M_insert_aux(__pos, __n, __x);
   328 #if __cplusplus >= 201103L   329   template <
typename _Tp, 
typename _Alloc>
   336           iterator __new_finish = _M_reserve_elements_at_back(__n);
   339               std::__uninitialized_default_a(this->_M_impl._M_finish,
   341                                              _M_get_Tp_allocator());
   342               this->_M_impl._M_finish = __new_finish;
   346               _M_destroy_nodes(this->_M_impl._M_finish._M_node + 1,
   347                                __new_finish._M_node + 1);
   348               __throw_exception_again;
   353   template <
typename _Tp, 
typename _Alloc>
   358       const difference_type __front_capacity
   359         = (this->_M_impl._M_start._M_cur - this->_M_impl._M_start._M_first);
   360       if (__front_capacity == 0)
   363       const difference_type __back_capacity
   364         = (this->_M_impl._M_finish._M_last - this->_M_impl._M_finish._M_cur);
   365       if (__front_capacity + __back_capacity < _S_buffer_size())
   368       return std::__shrink_to_fit_aux<deque>::_S_do_it(*
this);
   372   template <
typename _Tp, 
typename _Alloc>
   380           for (__cur = this->_M_impl._M_start._M_node;
   381                __cur < this->_M_impl._M_finish._M_node;
   383             std::__uninitialized_fill_a(*__cur, *__cur + _S_buffer_size(),
   384                                         __value, _M_get_Tp_allocator());
   385           std::__uninitialized_fill_a(this->_M_impl._M_finish._M_first,
   386                                       this->_M_impl._M_finish._M_cur,
   387                                       __value, _M_get_Tp_allocator());
   392                         _M_get_Tp_allocator());
   393           __throw_exception_again;
   397   template <
typename _Tp, 
typename _Alloc>
   398     template <
typename _InputIterator>
   404         this->_M_initialize_map(0);
   407             for (; __first != __last; ++__first)
   408 #
if __cplusplus >= 201103L
   409               emplace_back(*__first);
   417             __throw_exception_again;
   421   template <
typename _Tp, 
typename _Alloc>
   422     template <
typename _ForwardIterator>
   429         this->_M_initialize_map(__n);
   431         _Map_pointer __cur_node;
   434             for (__cur_node = this->_M_impl._M_start._M_node;
   435                  __cur_node < this->_M_impl._M_finish._M_node;
   438                 _ForwardIterator __mid = __first;
   440                 std::__uninitialized_copy_a(__first, __mid, *__cur_node,
   441                                             _M_get_Tp_allocator());
   444             std::__uninitialized_copy_a(__first, __last,
   445                                         this->_M_impl._M_finish._M_first,
   446                                         _M_get_Tp_allocator());
   452                           _M_get_Tp_allocator());
   453             __throw_exception_again;
   458   template<
typename _Tp, 
typename _Alloc>
   459 #if __cplusplus >= 201103L   460     template<
typename... _Args>
   470         _M_reserve_map_at_back();
   471         *(this->_M_impl._M_finish._M_node + 1) = this->_M_allocate_node();
   474 #if __cplusplus >= 201103L   475             _Alloc_traits::construct(this->_M_impl,
   476                                      this->_M_impl._M_finish._M_cur,
   477                                      std::forward<_Args>(__args)...);
   479             this->_M_impl.construct(this->_M_impl._M_finish._M_cur, __t);
   481             this->_M_impl._M_finish._M_set_node(this->_M_impl._M_finish._M_node
   483             this->_M_impl._M_finish._M_cur = this->_M_impl._M_finish._M_first;
   487             _M_deallocate_node(*(this->_M_impl._M_finish._M_node + 1));
   488             __throw_exception_again;
   493   template<
typename _Tp, 
typename _Alloc>
   494 #if __cplusplus >= 201103L   495     template<
typename... _Args>
   505         _M_reserve_map_at_front();
   506         *(this->_M_impl._M_start._M_node - 1) = this->_M_allocate_node();
   509             this->_M_impl._M_start._M_set_node(this->_M_impl._M_start._M_node
   511             this->_M_impl._M_start._M_cur = this->_M_impl._M_start._M_last - 1;
   512 #if __cplusplus >= 201103L   513             _Alloc_traits::construct(this->_M_impl,
   514                                      this->_M_impl._M_start._M_cur,
   515                                      std::forward<_Args>(__args)...);
   517             this->_M_impl.construct(this->_M_impl._M_start._M_cur, __t);
   522             ++this->_M_impl._M_start;
   523             _M_deallocate_node(*(this->_M_impl._M_start._M_node - 1));
   524             __throw_exception_again;
   529   template <
typename _Tp, 
typename _Alloc>
   533       _M_deallocate_node(this->_M_impl._M_finish._M_first);
   534       this->_M_impl._M_finish._M_set_node(this->_M_impl._M_finish._M_node - 1);
   535       this->_M_impl._M_finish._M_cur = this->_M_impl._M_finish._M_last - 1;
   536       _Alloc_traits::destroy(_M_get_Tp_allocator(),
   537                              this->_M_impl._M_finish._M_cur);
   545   template <
typename _Tp, 
typename _Alloc>
   549       _Alloc_traits::destroy(_M_get_Tp_allocator(),
   550                              this->_M_impl._M_start._M_cur);
   551       _M_deallocate_node(this->_M_impl._M_start._M_first);
   552       this->_M_impl._M_start._M_set_node(this->_M_impl._M_start._M_node + 1);
   553       this->_M_impl._M_start._M_cur = this->_M_impl._M_start._M_first;
   556   template <
typename _Tp, 
typename _Alloc>
   557     template <
typename _InputIterator>
   561                           _InputIterator __first, _InputIterator __last,
   565   template <
typename _Tp, 
typename _Alloc>
   566     template <
typename _ForwardIterator>
   570                           _ForwardIterator __first, _ForwardIterator __last,
   574         if (__pos._M_cur == this->_M_impl._M_start._M_cur)
   576             iterator __new_start = _M_reserve_elements_at_front(__n);
   579                 std::__uninitialized_copy_a(__first, __last, __new_start,
   580                                             _M_get_Tp_allocator());
   581                 this->_M_impl._M_start = __new_start;
   585                 _M_destroy_nodes(__new_start._M_node,
   586                                  this->_M_impl._M_start._M_node);
   587                 __throw_exception_again;
   590         else if (__pos._M_cur == this->_M_impl._M_finish._M_cur)
   592             iterator __new_finish = _M_reserve_elements_at_back(__n);
   595                 std::__uninitialized_copy_a(__first, __last,
   596                                             this->_M_impl._M_finish,
   597                                             _M_get_Tp_allocator());
   598                 this->_M_impl._M_finish = __new_finish;
   602                 _M_destroy_nodes(this->_M_impl._M_finish._M_node + 1,
   603                                  __new_finish._M_node + 1);
   604                 __throw_exception_again;
   608           _M_insert_aux(__pos, __first, __last, __n);
   611   template<
typename _Tp, 
typename _Alloc>
   612 #if __cplusplus >= 201103L   613     template<
typename... _Args>
   618         value_type __x_copy(std::forward<_Args>(__args)...); 
   624         value_type __x_copy = __x; 
   626         difference_type __index = __pos - this->_M_impl._M_start;
   627         if (static_cast<size_type>(__index) < size() / 2)
   629             push_front(_GLIBCXX_MOVE(front()));
   630             iterator __front1 = this->_M_impl._M_start;
   634             __pos = this->_M_impl._M_start + __index;
   637             _GLIBCXX_MOVE3(__front2, __pos1, __front1);
   641             push_back(_GLIBCXX_MOVE(back()));
   642             iterator __back1 = this->_M_impl._M_finish;
   646             __pos = this->_M_impl._M_start + __index;
   647             _GLIBCXX_MOVE_BACKWARD3(__pos, __back2, __back1);
   649         *__pos = _GLIBCXX_MOVE(__x_copy);
   653   template <
typename _Tp, 
typename _Alloc>
   658       const difference_type __elems_before = __pos - this->_M_impl._M_start;
   659       const size_type __length = this->size();
   660       value_type __x_copy = __x;
   661       if (__elems_before < difference_type(__length / 2))
   663           iterator __new_start = _M_reserve_elements_at_front(__n);
   664           iterator __old_start = this->_M_impl._M_start;
   665           __pos = this->_M_impl._M_start + __elems_before;
   668               if (__elems_before >= difference_type(__n))
   670                   iterator __start_n = (this->_M_impl._M_start
   671                                         + difference_type(__n));
   672                   std::__uninitialized_move_a(this->_M_impl._M_start,
   673                                               __start_n, __new_start,
   674                                               _M_get_Tp_allocator());
   675                   this->_M_impl._M_start = __new_start;
   676                   _GLIBCXX_MOVE3(__start_n, __pos, __old_start);
   677                   std::fill(__pos - difference_type(__n), __pos, __x_copy);
   681                   std::__uninitialized_move_fill(this->_M_impl._M_start,
   683                                                  this->_M_impl._M_start,
   685                                                  _M_get_Tp_allocator());
   686                   this->_M_impl._M_start = __new_start;
   687                   std::fill(__old_start, __pos, __x_copy);
   692               _M_destroy_nodes(__new_start._M_node,
   693                                this->_M_impl._M_start._M_node);
   694               __throw_exception_again;
   699           iterator __new_finish = _M_reserve_elements_at_back(__n);
   700           iterator __old_finish = this->_M_impl._M_finish;
   701           const difference_type __elems_after =
   702             difference_type(__length) - __elems_before;
   703           __pos = this->_M_impl._M_finish - __elems_after;
   706               if (__elems_after > difference_type(__n))
   708                   iterator __finish_n = (this->_M_impl._M_finish
   709                                          - difference_type(__n));
   710                   std::__uninitialized_move_a(__finish_n,
   711                                               this->_M_impl._M_finish,
   712                                               this->_M_impl._M_finish,
   713                                               _M_get_Tp_allocator());
   714                   this->_M_impl._M_finish = __new_finish;
   715                   _GLIBCXX_MOVE_BACKWARD3(__pos, __finish_n, __old_finish);
   716                   std::fill(__pos, __pos + difference_type(__n), __x_copy);
   720                   std::__uninitialized_fill_move(this->_M_impl._M_finish,
   721                                                  __pos + difference_type(__n),
   723                                                  this->_M_impl._M_finish,
   724                                                  _M_get_Tp_allocator());
   725                   this->_M_impl._M_finish = __new_finish;
   726                   std::fill(__pos, __old_finish, __x_copy);
   731               _M_destroy_nodes(this->_M_impl._M_finish._M_node + 1,
   732                                __new_finish._M_node + 1);
   733               __throw_exception_again;
   738   template <
typename _Tp, 
typename _Alloc>
   739     template <
typename _ForwardIterator>
   743                     _ForwardIterator __first, _ForwardIterator __last,
   746         const difference_type __elemsbefore = __pos - this->_M_impl._M_start;
   747         const size_type __length = size();
   748         if (static_cast<size_type>(__elemsbefore) < __length / 2)
   750             iterator __new_start = _M_reserve_elements_at_front(__n);
   751             iterator __old_start = this->_M_impl._M_start;
   752             __pos = this->_M_impl._M_start + __elemsbefore;
   755                 if (__elemsbefore >= difference_type(__n))
   757                     iterator __start_n = (this->_M_impl._M_start
   758                                           + difference_type(__n));
   759                     std::__uninitialized_move_a(this->_M_impl._M_start,
   760                                                 __start_n, __new_start,
   761                                                 _M_get_Tp_allocator());
   762                     this->_M_impl._M_start = __new_start;
   763                     _GLIBCXX_MOVE3(__start_n, __pos, __old_start);
   764                     std::copy(__first, __last, __pos - difference_type(__n));
   768                     _ForwardIterator __mid = __first;
   769                     std::advance(__mid, difference_type(__n) - __elemsbefore);
   770                     std::__uninitialized_move_copy(this->_M_impl._M_start,
   771                                                    __pos, __first, __mid,
   773                                                    _M_get_Tp_allocator());
   774                     this->_M_impl._M_start = __new_start;
   775                     std::copy(__mid, __last, __old_start);
   780                 _M_destroy_nodes(__new_start._M_node,
   781                                  this->_M_impl._M_start._M_node);
   782                 __throw_exception_again;
   787           iterator __new_finish = _M_reserve_elements_at_back(__n);
   788           iterator __old_finish = this->_M_impl._M_finish;
   789           const difference_type __elemsafter =
   790             difference_type(__length) - __elemsbefore;
   791           __pos = this->_M_impl._M_finish - __elemsafter;
   794               if (__elemsafter > difference_type(__n))
   796                   iterator __finish_n = (this->_M_impl._M_finish
   797                                          - difference_type(__n));
   798                   std::__uninitialized_move_a(__finish_n,
   799                                               this->_M_impl._M_finish,
   800                                               this->_M_impl._M_finish,
   801                                               _M_get_Tp_allocator());
   802                   this->_M_impl._M_finish = __new_finish;
   803                   _GLIBCXX_MOVE_BACKWARD3(__pos, __finish_n, __old_finish);
   804                   std::copy(__first, __last, __pos);
   808                   _ForwardIterator __mid = __first;
   810                   std::__uninitialized_copy_move(__mid, __last, __pos,
   811                                                  this->_M_impl._M_finish,
   812                                                  this->_M_impl._M_finish,
   813                                                  _M_get_Tp_allocator());
   814                   this->_M_impl._M_finish = __new_finish;
   815                   std::copy(__first, __mid, __pos);
   820               _M_destroy_nodes(this->_M_impl._M_finish._M_node + 1,
   821                                __new_finish._M_node + 1);
   822               __throw_exception_again;
   827    template<
typename _Tp, 
typename _Alloc>
   832        for (_Map_pointer __node = __first._M_node + 1;
   833             __node < __last._M_node; ++__node)
   835                        _M_get_Tp_allocator());
   837        if (__first._M_node != __last._M_node)
   840                          _M_get_Tp_allocator());
   842                          _M_get_Tp_allocator());
   846                        _M_get_Tp_allocator());
   849   template <
typename _Tp, 
typename _Alloc>
   854       if (this->max_size() - this->size() < __new_elems)
   855         __throw_length_error(__N(
"deque::_M_new_elements_at_front"));
   857       const size_type __new_nodes = ((__new_elems + _S_buffer_size() - 1)
   859       _M_reserve_map_at_front(__new_nodes);
   863           for (__i = 1; __i <= __new_nodes; ++__i)
   864             *(this->_M_impl._M_start._M_node - __i) = this->_M_allocate_node();
   868           for (size_type __j = 1; __j < __i; ++__j)
   869             _M_deallocate_node(*(this->_M_impl._M_start._M_node - __j));
   870           __throw_exception_again;
   874   template <
typename _Tp, 
typename _Alloc>
   879       if (this->max_size() - this->size() < __new_elems)
   880         __throw_length_error(__N(
"deque::_M_new_elements_at_back"));
   882       const size_type __new_nodes = ((__new_elems + _S_buffer_size() - 1)
   884       _M_reserve_map_at_back(__new_nodes);
   888           for (__i = 1; __i <= __new_nodes; ++__i)
   889             *(this->_M_impl._M_finish._M_node + __i) = this->_M_allocate_node();
   893           for (size_type __j = 1; __j < __i; ++__j)
   894             _M_deallocate_node(*(this->_M_impl._M_finish._M_node + __j));
   895           __throw_exception_again;
   899   template <
typename _Tp, 
typename _Alloc>
   904       const size_type __old_num_nodes
   905         = this->_M_impl._M_finish._M_node - this->_M_impl._M_start._M_node + 1;
   906       const size_type __new_num_nodes = __old_num_nodes + __nodes_to_add;
   908       _Map_pointer __new_nstart;
   909       if (this->_M_impl._M_map_size > 2 * __new_num_nodes)
   911           __new_nstart = this->_M_impl._M_map + (this->_M_impl._M_map_size
   912                                          - __new_num_nodes) / 2
   913                          + (__add_at_front ? __nodes_to_add : 0);
   914           if (__new_nstart < this->_M_impl._M_start._M_node)
   915             std::copy(this->_M_impl._M_start._M_node,
   916                       this->_M_impl._M_finish._M_node + 1,
   919             std::copy_backward(this->_M_impl._M_start._M_node,
   920                                this->_M_impl._M_finish._M_node + 1,
   921                                __new_nstart + __old_num_nodes);
   925           size_type __new_map_size = this->_M_impl._M_map_size
   926                                      + 
std::max(this->_M_impl._M_map_size,
   929           _Map_pointer __new_map = this->_M_allocate_map(__new_map_size);
   930           __new_nstart = __new_map + (__new_map_size - __new_num_nodes) / 2
   931                          + (__add_at_front ? __nodes_to_add : 0);
   932           std::copy(this->_M_impl._M_start._M_node,
   933                     this->_M_impl._M_finish._M_node + 1,
   935           _M_deallocate_map(this->_M_impl._M_map, this->_M_impl._M_map_size);
   937           this->_M_impl._M_map = __new_map;
   938           this->_M_impl._M_map_size = __new_map_size;
   941       this->_M_impl._M_start._M_set_node(__new_nstart);
   942       this->_M_impl._M_finish._M_set_node(__new_nstart + __old_num_nodes - 1);
   947   template<
typename _Tp>
   954       for (
typename _Self::_Map_pointer __node = __first._M_node + 1;
   955            __node < __last._M_node; ++__node)
   956         std::fill(*__node, *__node + _Self::_S_buffer_size(), __value);
   958       if (__first._M_node != __last._M_node)
   960           std::fill(__first._M_cur, __first._M_last, __value);
   961           std::fill(__last._M_first, __last._M_cur, __value);
   964         std::fill(__first._M_cur, __last._M_cur, __value);
   967   template<
typename _Tp>
   974       typedef typename _Self::difference_type difference_type;
   976       difference_type __len = __last - __first;
   979           const difference_type __clen
   981                                        __result._M_last - __result._M_cur));
   982           std::copy(__first._M_cur, __first._M_cur + __clen, __result._M_cur);
   990   template<
typename _Tp>
   997       typedef typename _Self::difference_type difference_type;
   999       difference_type __len = __last - __first;
  1002           difference_type __llen = __last._M_cur - __last._M_first;
  1003           _Tp* __lend = __last._M_cur;
  1005           difference_type __rlen = __result._M_cur - __result._M_first;
  1006           _Tp* __rend = __result._M_cur;
  1010               __llen = _Self::_S_buffer_size();
  1011               __lend = *(__last._M_node - 1) + __llen;
  1015               __rlen = _Self::_S_buffer_size();
  1016               __rend = *(__result._M_node - 1) + __rlen;
  1019           const difference_type __clen = 
std::min(__len,
  1021           std::copy_backward(__lend - __clen, __lend, __rend);
  1029 #if __cplusplus >= 201103L  1030   template<
typename _Tp>
  1037       typedef typename _Self::difference_type difference_type;
  1039       difference_type __len = __last - __first;
  1042           const difference_type __clen
  1044                                        __result._M_last - __result._M_cur));
  1045           std::move(__first._M_cur, __first._M_cur + __clen, __result._M_cur);
  1053   template<
typename _Tp>
  1060       typedef typename _Self::difference_type difference_type;
  1062       difference_type __len = __last - __first;
  1065           difference_type __llen = __last._M_cur - __last._M_first;
  1066           _Tp* __lend = __last._M_cur;
  1068           difference_type __rlen = __result._M_cur - __result._M_first;
  1069           _Tp* __rend = __result._M_cur;
  1073               __llen = _Self::_S_buffer_size();
  1074               __lend = *(__last._M_node - 1) + __llen;
  1078               __rlen = _Self::_S_buffer_size();
  1079               __rend = *(__result._M_node - 1) + __rlen;
  1082           const difference_type __clen = 
std::min(__len,
  1084           std::move_backward(__lend - __clen, __lend, __rend);
  1093 _GLIBCXX_END_NAMESPACE_CONTAINER
 void advance(_InputIterator &__i, _Distance __n)
A generalization of pointer arithmetic. 
insert_iterator< _Container > inserter(_Container &__x, _Iterator __i)
void _M_new_elements_at_back(size_type __new_elements)
Memory-handling helpers for the previous internal insert functions. 
void _M_pop_back_aux()
Helper functions for push_* and pop_*. 
void _M_new_elements_at_front(size_type __new_elements)
Memory-handling helpers for the previous internal insert functions. 
iterator begin() noexcept
void _M_fill_initialize(const value_type &__value)
Fills the deque with copies of value. 
A standard container using fixed-size memory allocation and constant-time manipulation of elements at...
iterator emplace(const_iterator __position, _Args &&...__args)
Inserts an object in deque before specified iterator. 
iterator_traits< _InputIterator >::difference_type distance(_InputIterator __first, _InputIterator __last)
A generalization of pointer arithmetic. 
void _Destroy(_Tp *__pointer)
constexpr const _Tp * begin(initializer_list< _Tp > __ils) noexcept
Return an iterator pointing to the first element of the initializer_list. 
_GLIBCXX14_CONSTEXPR const _Tp & min(const _Tp &, const _Tp &)
This does what you think it does. 
void _M_pop_front_aux()
Helper functions for push_* and pop_*. 
deque & operator=(const deque &__x)
Deque assignment operator. 
_GLIBCXX14_CONSTEXPR const _Tp & max(const _Tp &, const _Tp &)
This does what you think it does. 
void _M_reallocate_map(size_type __nodes_to_add, bool __add_at_front)
Memory-handling helpers for the major map. 
allocator_type get_allocator() const  noexcept
Get a copy of the memory allocation object. 
void _M_push_back_aux(_Args &&...__args)
Helper functions for push_* and pop_*. 
void _M_push_front_aux(_Args &&...__args)
Helper functions for push_* and pop_*. 
void _M_range_initialize(_InputIterator __first, _InputIterator __last, std::input_iterator_tag)
Fills the deque with whatever is in [first,last). 
Forward iterators support a superset of input iterator operations. 
ISO C++ entities toplevel namespace is std. 
constexpr const _Tp * end(initializer_list< _Tp > __ils) noexcept
Return an iterator pointing to one past the last element of the initializer_list. ...
size_type size() const  noexcept