std::vector<bool> fix & enhancements

François Dumont frs.dumont@gmail.com
Tue Oct 30 21:47:00 GMT 2018


Running tests in C++98 mode show that I had forgotten a 'return *this;' 
in _Bvector_impl_data::operator=.

So here is the patch again.

On 10/30/18 7:28 AM, François Dumont wrote:
> Following Marc Glisse change to ignore _M_start offset I wanted to go 
> a little step further and just remove it in _GLIBCXX_INLINE_VERSION mode.
>
> I also fix a regression we already fixed on mainstream std::vector 
> regarding noexcept qualification of move constructor with allocator.
>
> And I implemented the same optimizations than in std::vector for 
> allocators always comparing equals and for the std::swap operation.
>
> I also avoid re-implementing in vector::operator[] the same code 
> already implemented in iterator::operator[] but this one should 
> perhaps go in a different commit.
>
>
>     * include/bits/stl_bvector.h
>     [_GLIBCXX_INLINE_VERSION](_Bvector_impl_data::_M_start): Define as
>     _Bit_type*.
>     (_Bvector_impl_data(const _Bvector_impl_data&)): New.
>     (_Bvector_impl_data(_Bvector_impl_data&&)): Delegate to latter.
>     (_Bvector_impl_data::operator=(const _Bvector_impl_data&)): New.
> (_Bvector_impl_data::_M_move_data(_Bvector_impl_data&&)): Use latter.
>     (_Bvector_impl_data::_M_reset()): Likewise.
>     (_Bvector_impl_data::_M_begin()): New.
>     (_Bvector_impl_data::_M_cbegin()): New.
>     (_Bvector_impl_data::_M_start_p()): New.
>     (_Bvector_impl_data::_M_set_start(_Bit_type*)): New.
>     (_Bvector_impl_data::_M_swap_data): New.
>     (_Bvector_impl::_Bvector_impl(_Bvector_impl&&)): Implement 
> explicitely.
>     (_Bvector_impl::_Bvector_impl(_Bit_alloc_type&&, 
> _Bvector_impl&&)): New.
>     (_Bvector_base::_Bvector_base(_Bvector_base&&, const 
> allocator_type&)):
>     New.
>     (_Bvector_base::_M_deallocate()): Adapt.
>     (vector::vector(const vector&, const allocator_type&)): Adapt.
>     (vector::vector(vector&&, const allocator_type&, true_type)): New.
>     (vector::vector(vector&&, const allocator_type&, false_type)): New.
>     (vector::vector(vector&&, const allocator_type&)): Use latters.
>     (vector::vector(const vector&, const allocator_type&)): Adapt.
>     (vector::begin()): Adapt.
>     (vector::cbegin()): Adapt.
>     (vector::operator[](size_type)): Use iterator operator[].
>     (vector::swap(vector&)): Adapt.
>     (vector::flip()): Adapt.
>     (vector::_M_initialize(size_type)): Adapt.
>     (vector::_M_initialize_value(bool)): Adapt.
>     * include/bits/vector.tcc:
>     (vector<bool>::_M_reallocate(size_type)): Adapt.
>     (vector<bool>::_M_fill_insert(iterator, size_type, bool)): Adapt.
>     (vector<bool>::_M_insert_range<_FwdIter>(iterator, _FwdIter, _FwdIter
>     std::forward_iterator_tag)): Adapt.
>     (vector<bool>::_M_insert_aux(iterator, bool)): Adapt.
>     (std::hash<std::vector<bool>>::operator()): Adapt.
>     * 
> testsuite/23_containers/vector/bool/cons/noexcept_move_construct.cc:
>     Add check.
>
> Tested under Linux x86_64.
>
> Ok to commit ?
>
> François
>

-------------- next part --------------
A non-text attachment was scrubbed...
Name: bvector.patch
Type: text/x-patch
Size: 12199 bytes
Desc: not available
URL: <http://gcc.gnu.org/pipermail/libstdc++/attachments/20181030/c0c7133c/attachment.bin>


More information about the Libstdc++ mailing list