| bool
            full() const;
 Is the
 circular_buffer_space_optimizedfull?
              
                Returns:
              
                trueif the number of elements stored in thecircular_buffer_space_optimizedequals the capacity of thecircular_buffer_space_optimized;falseotherwise. 
              
                Throws:
              
                Nothing.
               
              
                Exception Safety:
              
                No-throw.
               
              
                Iterator Invalidation:
              
                Does not invalidate any iterators.
               
              
                Complexity:
              
                Constant (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                empty() | 
        
          | size_type
            reserve() const;
 Get the maximum number of elements which can be inserted into the
 circular_buffer_space_optimizedwithout overwriting any of already stored elements.
              
                Returns:
              
                capacity().capacity()
                - size() 
              
                Throws:
              
                Nothing.
               
              
                Exception Safety:
              
                No-throw.
               
              
                Iterator Invalidation:
              
                Does not invalidate any iterators.
               
              
                Complexity:
              
                Constant (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                capacity(),size(),max_size() | 
        
          | const
            capacity_type&
            capacity() const;
 Get the capacity of the
 circular_buffer_space_optimized.
              
                Returns:
              
                The capacity controller representing the maximum number of elements which can be stored in the
                circular_buffer_space_optimizedand the minimal allocated size of the internal buffer. 
              
                Throws:
              
                Nothing.
               
              
                Exception Safety:
              
                No-throw.
               
              
                Iterator Invalidation:
              
                Does not invalidate any iterators.
               
              
                Complexity:
              
                Constant (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                reserve(),size(),max_size(),set_capacity(const
                capacity_type&) | 
        
          | void
            set_capacity(const capacity_type&
            capacity_ctrl);
 Change the capacity (and the minimal guaranteed amount of allocated memory) of the
 circular_buffer_space_optimized.
              
                Effect:
              
                capacity() ==
                capacity_ctrl && size()
                <= capacity_ctrl.capacity()
 If the current number of elements stored in the
 circular_buffer_space_optimizedis greater
                than the desired new capacity then number of[size() -
                capacity_ctrl.capacity()]last elements will be removed and the new size will be equal tocapacity_ctrl.capacity().
 If the current number of elements stored in the
 circular_buffer_space_optimizedis lower
                than the new capacity then the amount of allocated memory in the internal buffer may be accommodated as
                necessary but it will never drop belowcapacity_ctrl.min_capacity(). 
              
                Parameter(s):
              
                
                  
                    capacity_ctrl
                    The new capacity controller.
                   
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Strong.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in min[size(),
                capacity_ctrl.capacity()]). 
              
                Note:
              
                To explicitly clear the extra allocated memory use the shrink-to-fit technique:
 
 boost::circular_buffer_space_optimized<int>
                cb(1000);...
 boost::circular_buffer_space_optimized<int>(cb).swap(cb);
 For more information about the shrink-to-fit technique in STL see http://www.gotw.ca/gotw/054.htm.
 
              
                See Also:
              
                rset_capacity(const
                capacity_type&),resize(size_type,
                const_reference) | 
        
          | void
            resize(size_type
            new_size, const_reference
            item = value_type());
 Change the size of the
 circular_buffer_space_optimized.
              
                Effect:
              
                size() ==
                new_size && capacity().capacity()
                >= new_size
 If the new size is greater than the current size, copies of
 itemwill be inserted at the
                back of the of thecircular_buffer_space_optimizedin order to achieve the desired
                size. In the case the resulting size exceeds the current capacity the capacity will be set tonew_size.
 If the current number of elements stored in the
 circular_buffer_space_optimizedis greater
                than the desired new size then number of[size() -
                new_size]last elements will be removed. (The capacity will remain unchanged.)
 The amount of allocated memory in the internal buffer may be accommodated as necessary.
 
              
                Parameter(s):
              
                
                  
                    new_size
                    The new size.
                  
                
                  
                    item
                    The element the circular_buffer_space_optimizedwill be filled with in order to gain
                    the requested size. (See the Effect.) 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the new size of the circular_buffer_space_optimized). 
              
                See Also:
              
                rresize(size_type,
                const_reference),set_capacity(const
                capacity_type&) | 
        
          | void
            rset_capacity(const capacity_type&
            capacity_ctrl);
 Change the capacity (and the minimal guaranteed amount of allocated memory) of the
 circular_buffer_space_optimized.
              
                Effect:
              
                capacity() ==
                capacity_ctrl && size()
                <= capacity_ctrl
 If the current number of elements stored in the
 circular_buffer_space_optimizedis greater
                than the desired new capacity then number of[size() -
                capacity_ctrl.capacity()]first elements will be removed and the new size will be equal
                tocapacity_ctrl.capacity().
 If the current number of elements stored in the
 circular_buffer_space_optimizedis lower
                than the new capacity then the amount of allocated memory in the internal buffer may be accommodated as
                necessary but it will never drop belowcapacity_ctrl.min_capacity(). 
              
                Parameter(s):
              
                
                  
                    capacity_ctrl
                    The new capacity controller.
                   
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Strong.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in min[size(),
                capacity_ctrl.capacity()]). 
              
                See Also:
              
                set_capacity(const
                capacity_type&),rresize(size_type,
                const_reference) | 
        
          | void
            rresize(size_type
            new_size, const_reference
            item = value_type());
 Change the size of the
 circular_buffer_space_optimized.
              
                Effect:
              
                size() ==
                new_size && capacity().capacity()
                >= new_size
 If the new size is greater than the current size, copies of
 itemwill be inserted at the
                front of the of thecircular_buffer_space_optimizedin order to achieve the desired
                size. In the case the resulting size exceeds the current capacity the capacity will be set tonew_size.
 If the current number of elements stored in the
 circular_buffer_space_optimizedis greater
                than the desired new size then number of[size() -
                new_size]first elements will be removed. (The capacity will remain unchanged.)
 The amount of allocated memory in the internal buffer may be accommodated as necessary.
 
              
                Parameter(s):
              
                
                  
                    new_size
                    The new size.
                  
                
                  
                    item
                    The element the circular_buffer_space_optimizedwill be filled with in order to gain
                    the requested size. (See the Effect.) 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the new size of the circular_buffer_space_optimized). 
              
                See Also:
              
                resize(size_type,
                const_reference),rset_capacity(const
                capacity_type&) | 
        
          | circular_buffer_space_optimized<T,Alloc>&
            operator=(const circular_buffer_space_optimized<T,Alloc>& cb);
 The assign operator.
 
              Makes this circular_buffer_space_optimizedto become a copy of the specifiedcircular_buffer_space_optimized. 
              
                Effect:
              
                *this == cb
 The amount of allocated memory in the internal buffer is
 cb.size(). 
              
                Parameter(s):
              
                
                  
                    cb
                    The circular_buffer_space_optimizedto be copied. 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Strong.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to this circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of cb). 
              
                See Also:
              
                assign(size_type,
                const_reference),assign(capacity_type,
                size_type, const_reference),assign(InputIterator,
                InputIterator),assign(capacity_type,
                InputIterator, InputIterator) | 
        
          | void
            assign(size_type n,
            const_reference
            item);
 Assign
 nitems into the space optimized circular buffer.
              The content of the circular_buffer_space_optimizedwill be removed and replaced withncopies of theitem. 
              
                Effect:
              
                capacity().capacity()
                == n && capacity().min_capacity()
                == 0 && size() == n
                && (*this)[0] == item && (*this)[1] == item && ... && (*this) [n - 1]
                == item
 The amount of allocated memory in the internal buffer is
 n. 
              
                Parameter(s):
              
                
                  
                    n
                    The number of elements the circular_buffer_space_optimizedwill be filled with.
                
                  
                    item
                    The element the circular_buffer_space_optimizedwill be filled with. 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the n). 
              
                See Also:
              
                operator=,assign(capacity_type,
                size_type, const_reference),assign(InputIterator,
                InputIterator),assign(capacity_type,
                InputIterator, InputIterator) | 
        
          | void
            assign(capacity_type
            capacity_ctrl, size_type n,
            const_reference
            item);
 Assign
 nitems into the space optimized circular buffer specifying the capacity.
              The capacity of the circular_buffer_space_optimizedwill be set to the specified value and
              the content of thecircular_buffer_space_optimizedwill be removed and replaced withncopies of theitem. 
              
                Precondition:
              
                capacity_ctrl.capacity() >= n 
              
                Effect:
              
                capacity() ==
                capacity_ctrl && size() == n
                && (*this)[0] == item && (*this)[1] == item && ... && (*this) [n - 1]
                == item
 The amount of allocated memory will be
 max[n, capacity_ctrl.min_capacity()]. 
              
                Parameter(s):
              
                
                  
                    capacity_ctrl
                    The new capacity controller.
                  
                
                  
                    n
                    The number of elements the circular_buffer_space_optimizedwill be filled with.
                
                  
                    item
                    The element the circular_buffer_space_optimizedwill be filled with. 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the n). 
              
                See Also:
              
                operator=,assign(size_type,
                const_reference),assign(InputIterator,
                InputIterator),assign(capacity_type,
                InputIterator, InputIterator) | 
        
          | template
            <class InputIterator>void assign(InputIterator first, InputIterator last);
 Assign a copy of the range into the space optimized circular buffer.
 
              The content of the circular_buffer_space_optimizedwill be removed and replaced with copies
              of elements from the specified range. 
              
                Precondition:
              
                Valid range [first, last).
 firstandlasthave to meet the requirements of InputIterator. 
              
                Effect:
              
                capacity().capacity()
                == std::distance(first, last) && capacity().min_capacity()
                == 0 && size() ==
                std::distance(first, last) && (*this)[0]== *first && (*this)[1] == *(first + 1)
                && ... && (*this)[std::distance(first, last) - 1] == *(last - 1)
 The amount of allocated memory in the internal buffer is
 std::distance(first, last). 
              
                Parameter(s):
              
                
                  
                    first
                    The beginning of the range to be copied.
                  
                
                  
                    last
                    The end of the range to be copied.
                   
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the std::distance(first, last)). 
              
                See Also:
              
                operator=,assign(size_type,
                const_reference),assign(capacity_type,
                size_type, const_reference),assign(capacity_type,
                InputIterator, InputIterator) | 
        
          | template
            <class InputIterator>void assign(capacity_type
            capacity_ctrl, InputIterator first, InputIterator last);
 Assign a copy of the range into the space optimized circular buffer specifying the capacity.
 
              The capacity of the circular_buffer_space_optimizedwill be set to the specified value and
              the content of thecircular_buffer_space_optimizedwill be removed and replaced with copies
              of elements from the specified range. 
              
                Precondition:
              
                Valid range [first, last).
 firstandlasthave to meet the requirements of InputIterator. 
              
                Effect:
              
                capacity() ==
                capacity_ctrl && size()
                <= std::distance(first, last) && (*this)[0]== *(last - capacity) && (*this)[1] ==
                *(last - capacity + 1) && ... && (*this)[capacity - 1] == *(last - 1)
 If the number of items to be copied from the range
 [first, last)is greater than the
                specifiedcapacitythen only elements from the range[last - capacity, last)will be copied.
 The amount of allocated memory in the internal buffer is
 max[std::distance(first, last),
                capacity_ctrl.min_capacity()]. 
              
                Parameter(s):
              
                
                  
                    capacity_ctrl
                    The new capacity controller.
                  
                
                  
                    first
                    The beginning of the range to be copied.
                  
                
                  
                    last
                    The end of the range to be copied.
                   
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in std::distance(first, last); inmin[capacity_ctrl.capacity(),
                std::distance(first, last)]if theInputIteratoris a RandomAccessIterator). 
              
                See Also:
              
                operator=,assign(size_type,
                const_reference),assign(capacity_type,
                size_type, const_reference),assign(InputIterator,
                InputIterator) | 
        
          | void
            swap(circular_buffer_space_optimized<T,Alloc>& cb);
 Swap the contents of two space optimized circular buffers.
 
              
                Effect:
              
                thiscontains elements ofcband vice versa; the capacity and the amount of
                allocated memory in the internal buffer ofthisequal to the capacity and the amount of
                allocated memory ofcband vice versa. 
              
                Parameter(s):
              
                
                  
                    cb
                    The circular_buffer_space_optimizedwhose content will be swapped. 
              
                Throws:
              
                Nothing.
               
              
                Exception Safety:
              
                No-throw.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators of both circular_buffer_space_optimizedcontainers. (On the
                other hand the iterators still point to the same elements but within another container. If you want to
                rely on this feature you have to turn the Debug Support off
                otherwise an assertion will report an error if such invalidated iterator is used.) 
              
                Complexity:
              
                Constant (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                swap(circular_buffer_space_optimized<T,
                Alloc>&, circular_buffer_space_optimized<T, Alloc>&) | 
        
          | void
            push_back(const_reference
            item = value_type());
 Insert a new element at the end of the space optimized circular buffer.
 
              
                Effect:
              
                if capacity().capacity()
                > 0thenback() ==
                itemIf the
 circular_buffer_space_optimizedis full, the first element will be removed. If the
                capacity is0, nothing will be inserted.
 The amount of allocated memory in the internal buffer may be predictively increased.
 
              
                Parameter(s):
              
                
                  
                    item
                    The element to be inserted.
                   
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                push_front(const_reference),pop_back(),pop_front() | 
        
          | void
            push_front(const_reference
            item = value_type());
 Insert a new element at the beginning of the space optimized circular buffer.
 
              
                Effect:
              
                if capacity().capacity()
                > 0thenfront() ==
                itemIf the
 circular_buffer_space_optimizedis full, the last element will be removed. If the
                capacity is0, nothing will be inserted.
 The amount of allocated memory in the internal buffer may be predictively increased.
 
              
                Parameter(s):
              
                
                  
                    item
                    The element to be inserted.
                   
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                push_back(const_reference),pop_back(),pop_front() | 
        
          | void
            pop_back();
 Remove the last element from the space optimized circular buffer.
 
              
                Precondition:
              
                !empty() 
              
                Effect:
              
                The last element is removed from the circular_buffer_space_optimized.
 The amount of allocated memory in the internal buffer may be predictively decreased.
 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used). 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                pop_front(),push_back(const_reference),push_front(const_reference) | 
        
          | void
            pop_front();
 Remove the first element from the space optimized circular buffer.
 
              
                Precondition:
              
                !empty() 
              
                Effect:
              
                The first element is removed from the circular_buffer_space_optimized.
 The amount of allocated memory in the internal buffer may be predictively decreased.
 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used). 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                pop_back(),push_back(const_reference),push_front(const_reference) | 
        
          | iterator
            insert(iterator pos,
            const_reference
            item = value_type());
 Insert an element at the specified position.
 
              
                Precondition:
              
                posis a valid iterator pointing to thecircular_buffer_space_optimizedor
                its end. 
              
                Effect:
              
                The itemwill be inserted at the positionpos.If the
 circular_buffer_space_optimizedis full, the first element will be overwritten. If
                thecircular_buffer_space_optimizedis full and thepospoints tobegin(),
                then theitemwill not be inserted. If the capacity is0, nothing will be
                inserted.
 The amount of allocated memory in the internal buffer may be predictively increased.
 
              
                Parameter(s):
              
                
                  
                    pos
                    An iterator specifying the position where the itemwill be inserted.
                
                  
                    item
                    The element to be inserted.
                   
              
                Returns:
              
                Iterator to the inserted element or begin()if theitemis not inserted. (See the Effect.) 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws.
                Whatever T::operator = (const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                insert(iterator,
                size_type, value_type),insert(iterator,
                InputIterator, InputIterator),rinsert(iterator,
                value_type),rinsert(iterator,
                size_type, value_type),rinsert(iterator,
                InputIterator, InputIterator) | 
        
          | void
            insert(iterator pos,
            size_type n,
            const_reference
            item);
 Insert
 ncopies of theitemat the specified position.
              
                Precondition:
              
                posis a valid iterator pointing to thecircular_buffer_space_optimizedor
                its end. 
              
                Effect:
              
                The number of min[n, (pos - begin()) +
                reserve()]elements will be inserted at the positionpos.The number of
 min[pos - begin(),
                max[0, n - reserve()]]elements will be overwritten at the beginning of thecircular_buffer_space_optimized.(See Example for the explanation.)
 
 The amount of allocated memory in the internal buffer may be predictively increased.
 
              
                Parameter(s):
              
                
                  
                    pos
                    An iterator specifying the position where the items will be inserted.
                
                  
                    n
                    The number of items the to be inserted.
                
                  
                    item
                    The element whose copies will be inserted.
                   
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws.
                Whatever T::operator = (const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in min[capacity().capacity(),
                size() +
                n]). 
              
                Example:
              
                Consider a circular_buffer_space_optimizedwith the capacity of 6 and the size of 4. Its
                internal buffer may look like the one below.
 
 |1|2|3|4| | |
 p ---^
 After inserting 5 elements at the position
 p:
 
 insert(p, (size_t)5, 0);
 actually only 4 elements get inserted and elements
 1and2are overwritten.
                This is due to the fact the insert operation preserves the capacity. After insertion the internal
                buffer looks like this:
 
 |0|0|0|0|3|4|
 For comparison if the capacity would not be preserved the internal buffer would then result in
 |1|2|0|0|0|0|0|3|4|. 
              
                See Also:
              
                insert(iterator,
                value_type),insert(iterator,
                InputIterator, InputIterator),rinsert(iterator,
                value_type),rinsert(iterator,
                size_type, value_type),rinsert(iterator,
                InputIterator, InputIterator) | 
        
          | template
            <class InputIterator>void insert(iterator pos,
            InputIterator first, InputIterator last);
 Insert the range
 [first, last)at the specified position.
              
                Precondition:
              
                posis a valid iterator pointing to thecircular_buffer_space_optimizedor
                its end.Valid range
 [first, last)wherefirstandlastmeet the
                requirements of an InputIterator. 
              
                Effect:
              
                Elements from the range [first + max[0, distance(first, last) - (pos - begin()) -
                reserve()],
                last)will be inserted at the positionpos.The number of
 min[pos - begin(),
                max[0, distance(first, last) - reserve()]]elements will be overwritten at the beginning of thecircular_buffer_space_optimized.(See Example for the explanation.)
 
 The amount of allocated memory in the internal buffer may be predictively increased.
 
              
                Parameter(s):
              
                
                  
                    pos
                    An iterator specifying the position where the range will be inserted.
                  
                
                  
                    first
                    The beginning of the range to be inserted.
                  
                
                  
                    last
                    The end of the range to be inserted.
                   
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws.
                Whatever T::operator = (const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in [size() +
                std::distance(first, last)]; inmin[capacity().capacity(),
                size() +
                std::distance(first, last)]if theInputIteratoris a RandomAccessIterator). 
              
                Example:
              
                Consider a circular_buffer_space_optimizedwith the capacity of 6 and the size of 4. Its
                internal buffer may look like the one below.
 
 |1|2|3|4| | |
 p ---^
 After inserting a range of elements at the position
 p:
 
 int array[] = { 5, 6, 7, 8, 9 };
 insert(p, array, array + 5);
 actually only elements
 6,7,8and9from the
                specified range get inserted and elements1and2are overwritten. This is
                due to the fact the insert operation preserves the capacity. After insertion the internal buffer looks
                like this:
 
 |6|7|8|9|3|4|
 For comparison if the capacity would not be preserved the internal buffer would then result in
 |1|2|5|6|7|8|9|3|4|. 
              
                See Also:
              
                insert(iterator,
                value_type),insert(iterator,
                size_type, value_type),rinsert(iterator,
                value_type),rinsert(iterator,
                size_type, value_type),rinsert(iterator,
                InputIterator, InputIterator) | 
        
          | iterator
            rinsert(iterator pos,
            const_reference
            item = value_type());
 Insert an element before the specified position.
 
              
                Precondition:
              
                posis a valid iterator pointing to thecircular_buffer_space_optimizedor
                its end. 
              
                Effect:
              
                The itemwill be inserted before the positionpos.If the
 circular_buffer_space_optimizedis full, the last element will be overwritten. If
                thecircular_buffer_space_optimizedis full and thepospoints toend(),
                then theitemwill not be inserted. If the capacity is0, nothing will be
                inserted.
 The amount of allocated memory in the internal buffer may be predictively increased.
 
              
                Parameter(s):
              
                
                  
                    pos
                    An iterator specifying the position before which the itemwill be inserted.
                
                  
                    item
                    The element to be inserted.
                   
              
                Returns:
              
                Iterator to the inserted element or end()if theitemis not inserted. (See the Effect.) 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws.
                Whatever T::operator = (const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                rinsert(iterator,
                size_type, value_type),rinsert(iterator,
                InputIterator, InputIterator),insert(iterator,
                value_type),insert(iterator,
                size_type, value_type),insert(iterator,
                InputIterator, InputIterator) | 
        
          | void
            rinsert(iterator pos,
            size_type n,
            const_reference
            item);
 Insert
 ncopies of theitembefore the specified position.
              
                Precondition:
              
                posis a valid iterator pointing to thecircular_buffer_space_optimizedor
                its end. 
              
                Effect:
              
                The number of min[n, (end() -
                pos) + reserve()]elements will be inserted before the positionpos.The number of
 min[end() -
                pos, max[0, n - reserve()]]elements will be overwritten at the end of thecircular_buffer_space_optimized.(See Example for the explanation.)
 
 The amount of allocated memory in the internal buffer may be predictively increased.
 
              
                Parameter(s):
              
                
                  
                    pos
                    An iterator specifying the position where the items will be inserted.
                
                  
                    n
                    The number of items the to be inserted.
                
                  
                    item
                    The element whose copies will be inserted.
                   
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws.
                Whatever T::operator = (const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in min[capacity().capacity(),
                size() +
                n]). 
              
                Example:
              
                Consider a circular_buffer_space_optimizedwith the capacity of 6 and the size of 4. Its
                internal buffer may look like the one below.
 
 |1|2|3|4| | |
 p ---^
 After inserting 5 elements before the position
 p:
 
 rinsert(p, (size_t)5, 0);
 actually only 4 elements get inserted and elements
 3and4are overwritten.
                This is due to the fact the rinsert operation preserves the capacity. After insertion the internal
                buffer looks like this:
 
 |1|2|0|0|0|0|
 For comparison if the capacity would not be preserved the internal buffer would then result in
 |1|2|0|0|0|0|0|3|4|. 
              
                See Also:
              
                rinsert(iterator,
                value_type),rinsert(iterator,
                InputIterator, InputIterator),insert(iterator,
                value_type),insert(iterator,
                size_type, value_type),insert(iterator,
                InputIterator, InputIterator) | 
        
          | template
            <class InputIterator>void rinsert(iterator pos,
            InputIterator first, InputIterator last);
 Insert the range
 [first, last)before the specified position.
              
                Precondition:
              
                posis a valid iterator pointing to thecircular_buffer_space_optimizedor
                its end.Valid range
 [first, last)wherefirstandlastmeet the
                requirements of an InputIterator. 
              
                Effect:
              
                Elements from the range [first, last - max[0, distance(first, last) - (end() -
                pos) - reserve()])will be inserted before the positionpos.The number of
 min[end() -
                pos, max[0, distance(first, last) - reserve()]]elements will be overwritten at the end of thecircular_buffer.(See Example for the explanation.)
 
 The amount of allocated memory in the internal buffer may be predictively increased.
 
              
                Parameter(s):
              
                
                  
                    pos
                    An iterator specifying the position where the range will be inserted.
                  
                
                  
                    first
                    The beginning of the range to be inserted.
                  
                
                  
                    last
                    The end of the range to be inserted.
                   
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::T(const T&)throws.
                Whatever T::operator = (const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in [size() +
                std::distance(first, last)]; inmin[capacity().capacity(),
                size() +
                std::distance(first, last)]if theInputIteratoris a RandomAccessIterator). 
              
                Example:
              
                Consider a circular_buffer_space_optimizedwith the capacity of 6 and the size of 4. Its
                internal buffer may look like the one below.
 
 |1|2|3|4| | |
 p ---^
 After inserting a range of elements before the position
 p:
 
 int array[] = { 5, 6, 7, 8, 9 };
 insert(p, array, array + 5);
 actually only elements
 5,6,7and8from the
                specified range get inserted and elements3and4are overwritten. This is
                due to the fact the rinsert operation preserves the capacity. After insertion the internal buffer looks
                like this:
 
 |1|2|5|6|7|8|
 For comparison if the capacity would not be preserved the internal buffer would then result in
 |1|2|5|6|7|8|9|3|4|. 
              
                See Also:
              
                rinsert(iterator,
                value_type),rinsert(iterator,
                size_type, value_type),insert(iterator,
                value_type),insert(iterator,
                size_type, value_type),insert(iterator,
                InputIterator, InputIterator) | 
        
          | iterator
            erase(iterator
            pos);
 Remove an element at the specified position.
 
              
                Precondition:
              
                posis a valid iterator pointing to thecircular_buffer_space_optimized(but
                not anend()). 
              
                Effect:
              
                The element at the position posis removed.
 The amount of allocated memory in the internal buffer may be predictively decreased.
 
              
                Parameter(s):
              
                
                  
                    pos
                    An iterator pointing at the element to be removed.
                   
              
                Returns:
              
                Iterator to the first element remaining beyond the removed element or end()if no such element exists. 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::operator = (const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                erase(iterator,
                iterator),rerase(iterator),rerase(iterator,
                iterator),clear() | 
        
          | iterator
            erase(iterator first,
            iterator
            last);
 Erase the range
 [first, last).
              
                Precondition:
              
                Valid range [first, last). 
              
                Effect:
              
                The elements from the range [first, last)are removed. (Iffirst == lastnothing is removed.)
 The amount of allocated memory in the internal buffer may be predictively decreased.
 
              
                Parameter(s):
              
                
                  
                    first
                    The beginning of the range to be removed.
                  
                
                  
                    last
                    The end of the range to be removed.
                   
              
                Returns:
              
                Iterator to the first element remaining beyond the removed elements or end()if no such element exists. 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::operator = (const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                erase(iterator),rerase(iterator),rerase(iterator,
                iterator),clear() | 
        
          | iterator
            rerase(iterator
            pos);
 Remove an element at the specified position.
 
              
                Precondition:
              
                posis a valid iterator pointing to thecircular_buffer_space_optimized(but
                not anend()).
 The amount of allocated memory in the internal buffer may be predictively decreased.
 
              
                Effect:
              
                The element at the position posis removed. 
              
                Parameter(s):
              
                
                  
                    pos
                    An iterator pointing at the element to be removed.
                   
              
                Returns:
              
                Iterator to the first element remaining in front of the removed element or begin()if no such element exists. 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::operator = (const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                Note:
              
                Basically there is no difference between erase(iterator)and this method. It is implemented only for consistency with the basecircular_buffer. 
              
                See Also:
              
                erase(iterator),erase(iterator,
                iterator),rerase(iterator,
                iterator),clear() | 
        
          | iterator
            rerase(iterator first,
            iterator
            last);
 Erase the range
 [first, last).
              
                Precondition:
              
                Valid range [first, last). 
              
                Effect:
              
                The elements from the range [first, last)are removed. (Iffirst == lastnothing is removed.)
 The amount of allocated memory in the internal buffer may be predictively decreased.
 
              
                Parameter(s):
              
                
                  
                    first
                    The beginning of the range to be removed.
                  
                
                  
                    last
                    The end of the range to be removed.
                   
              
                Returns:
              
                Iterator to the first element remaining in front of the removed elements or begin()if no such element exists. 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used).
                Whatever T::operator = (const T&)throws. 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                Note:
              
                Basically there is no difference between erase(iterator,
                iterator)and this method. It is implemented only for consistency with the basecircular_buffer. 
              
                See Also:
              
                erase(iterator),erase(iterator,
                iterator),rerase(iterator),clear() | 
        
          | void
            clear();
 Remove all stored elements from the space optimized circular buffer.
 
              
                Effect:
              
                size() ==
                0
 The amount of allocated memory in the internal buffer may be predictively decreased.
 
              
                Throws:
              
                An allocation error if memory is exhausted (std::bad_allocif the standard allocator is
                used). 
              
                Exception Safety:
              
                Basic.
               
              
                Iterator Invalidation:
              
                Invalidates all iterators pointing to the circular_buffer_space_optimized(except
                iterators equal toend()). 
              
                Complexity:
              
                Linear (in the size of the circular_buffer_space_optimized). 
              
                See Also:
              
                ~circular_buffer_space_optimized(),erase(iterator),erase(iterator,
                iterator),rerase(iterator),rerase(iterator,
                iterator) |