mirror of
https://github.com/boostorg/container.git
synced 2025-08-03 06:24:26 +02:00
@@ -1216,6 +1216,19 @@ use [*Boost.Container]? There are several reasons for that:
|
|||||||
[section:release_notes_boost_1_60_00 Boost 1.60 Release]
|
[section:release_notes_boost_1_60_00 Boost 1.60 Release]
|
||||||
|
|
||||||
* Implemented [link container.extended_functionality.polymorphic_memory_resources Polymorphic Memory Resources].
|
* Implemented [link container.extended_functionality.polymorphic_memory_resources Polymorphic Memory Resources].
|
||||||
|
* Fixed bugs:
|
||||||
|
* [@https://svn.boost.org/trac/boost/ticket/11627 Trac #11627: ['"small_vector<T,n>::swap() appears to be broken"]].
|
||||||
|
* [@https://svn.boost.org/trac/boost/ticket/11628 Trac #11628: ['"small_vector<int,n> iterates over elements in destructor"]].
|
||||||
|
|
||||||
|
[endsect]
|
||||||
|
|
||||||
|
[section:release_notes_boost_1_60_00 Boost 1.60 Release]
|
||||||
|
|
||||||
|
* [@https://github.com/boostorg/container/pull/26 GitHub #26: ['Fix bug in stable_vector::capacity()]]. Thanks to timsong-cpp/Arindam Mukerjee.
|
||||||
|
* [@https://github.com/boostorg/container/pull/27 GitHub #27: ['fix stable_vector's index_of's doxygen comment]]. Thanks to kariya-mitsuru.
|
||||||
|
* [@https://svn.boost.org/trac/boost/ticket/11380 Trac #11380: ['"Container library std forward declarations incorrect in std_fwd.hpp on libc++ with gcc"]].
|
||||||
|
* [@https://svn.boost.org/trac/boost/ticket/11388 Trac #11388: ['"boost::container::list::emplace_back broken on Visual Studio 2010"]].
|
||||||
|
* [@https://svn.boost.org/trac/boost/ticket/11339 Trac #11339: ['"VC12 LNK2005 error with boost::container::adaptive_pool"]].
|
||||||
|
|
||||||
[endsect]
|
[endsect]
|
||||||
|
|
||||||
|
@@ -252,15 +252,15 @@ struct disable_if_memzero_initializable
|
|||||||
|
|
||||||
template <typename I, typename R>
|
template <typename I, typename R>
|
||||||
struct enable_if_trivially_destructible
|
struct enable_if_trivially_destructible
|
||||||
: enable_if_c < false/*container_detail::is_trivially_destructible
|
: enable_if_c < container_detail::is_trivially_destructible
|
||||||
<typename boost::container::iterator_traits<I>::value_type>::value*/
|
<typename boost::container::iterator_traits<I>::value_type>::value
|
||||||
, R>
|
, R>
|
||||||
{};
|
{};
|
||||||
|
|
||||||
template <typename I, typename R>
|
template <typename I, typename R>
|
||||||
struct disable_if_trivially_destructible
|
struct disable_if_trivially_destructible
|
||||||
: enable_if_c <true/*!container_detail::is_trivially_destructible
|
: enable_if_c <!container_detail::is_trivially_destructible
|
||||||
<typename boost::container::iterator_traits<I>::value_type>::value*/
|
<typename boost::container::iterator_traits<I>::value_type>::value
|
||||||
, R>
|
, R>
|
||||||
{};
|
{};
|
||||||
|
|
||||||
|
@@ -346,18 +346,17 @@ struct vector_alloc_holder
|
|||||||
static bool is_propagable_from(const allocator_type &from_alloc, pointer p, const allocator_type &to_alloc, bool const propagate_allocator)
|
static bool is_propagable_from(const allocator_type &from_alloc, pointer p, const allocator_type &to_alloc, bool const propagate_allocator)
|
||||||
{
|
{
|
||||||
(void)propagate_allocator; (void)p; (void)to_alloc; (void)from_alloc;
|
(void)propagate_allocator; (void)p; (void)to_alloc; (void)from_alloc;
|
||||||
return (!allocator_traits_type::is_partially_propagable::value ||
|
const bool all_storage_propagable = !allocator_traits_type::is_partially_propagable::value ||
|
||||||
!allocator_traits_type::storage_is_unpropagable(from_alloc, p)) &&
|
!allocator_traits_type::storage_is_unpropagable(from_alloc, p);
|
||||||
(propagate_allocator || allocator_traits_type::equal(from_alloc, to_alloc));
|
return all_storage_propagable && (propagate_allocator || allocator_traits_type::equal(from_alloc, to_alloc));
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool are_swap_propagable(const allocator_type &l_a, pointer l_p, const allocator_type &r_a, pointer r_p, bool const propagate_allocator)
|
static bool are_swap_propagable(const allocator_type &l_a, pointer l_p, const allocator_type &r_a, pointer r_p, bool const propagate_allocator)
|
||||||
{
|
{
|
||||||
(void)propagate_allocator; (void)l_p; (void)r_p; (void)l_a; (void)r_a;
|
(void)propagate_allocator; (void)l_p; (void)r_p; (void)l_a; (void)r_a;
|
||||||
return (!allocator_traits_type::is_partially_propagable::value ||
|
const bool all_storage_propagable = !allocator_traits_type::is_partially_propagable::value ||
|
||||||
(!allocator_traits_type::storage_is_unpropagable(r_a, r_p) &&
|
!(allocator_traits_type::storage_is_unpropagable(l_a, l_p) || allocator_traits_type::storage_is_unpropagable(r_a, r_p));
|
||||||
!allocator_traits_type::storage_is_unpropagable(l_a, l_p))
|
return all_storage_propagable && (propagate_allocator || allocator_traits_type::equal(l_a, r_a));
|
||||||
) && (propagate_allocator || allocator_traits_type::equal(l_a, r_a));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Constructor, does not throw
|
//Constructor, does not throw
|
||||||
@@ -2452,7 +2451,7 @@ class vector
|
|||||||
{
|
{
|
||||||
const bool propagate_alloc = allocator_traits_type::propagate_on_container_swap::value;
|
const bool propagate_alloc = allocator_traits_type::propagate_on_container_swap::value;
|
||||||
if(are_swap_propagable( this->get_stored_allocator(), this->m_holder.start()
|
if(are_swap_propagable( this->get_stored_allocator(), this->m_holder.start()
|
||||||
, x.get_stored_allocator(), this->m_holder.start(), propagate_alloc)){
|
, x.get_stored_allocator(), x.m_holder.start(), propagate_alloc)){
|
||||||
//Just swap internals
|
//Just swap internals
|
||||||
this->m_holder.swap_resources(x.m_holder);
|
this->m_holder.swap_resources(x.m_holder);
|
||||||
}
|
}
|
||||||
@@ -2471,6 +2470,8 @@ class vector
|
|||||||
, boost::make_move_iterator(container_detail::iterator_to_raw_pointer(big.nth(common_elements)))
|
, boost::make_move_iterator(container_detail::iterator_to_raw_pointer(big.nth(common_elements)))
|
||||||
, boost::make_move_iterator(container_detail::iterator_to_raw_pointer(big.end()))
|
, boost::make_move_iterator(container_detail::iterator_to_raw_pointer(big.end()))
|
||||||
);
|
);
|
||||||
|
//Destroy remaining elements
|
||||||
|
big.erase(big.nth(common_elements), big.cend());
|
||||||
}
|
}
|
||||||
//And now swap the allocator
|
//And now swap the allocator
|
||||||
container_detail::swap_alloc(this->m_holder.alloc(), x.m_holder.alloc(), container_detail::bool_<propagate_alloc>());
|
container_detail::swap_alloc(this->m_holder.alloc(), x.m_holder.alloc(), container_detail::bool_<propagate_alloc>());
|
||||||
|
@@ -108,40 +108,80 @@ bool test_small_vector_base_test()
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//small vector has internal storage so some special swap cases must be tested
|
||||||
|
bool test_swap()
|
||||||
|
{
|
||||||
|
typedef boost::container::small_vector<int, 10> vec;
|
||||||
|
{ //v bigger than static capacity, w empty
|
||||||
|
vec v;
|
||||||
|
for(std::size_t i = 0, max = v.capacity()+1; i != max; ++i){
|
||||||
|
v.push_back(int(i));
|
||||||
|
}
|
||||||
|
vec w;
|
||||||
|
const std::size_t v_size = v.size();
|
||||||
|
const std::size_t w_size = w.size();
|
||||||
|
v.swap(w);
|
||||||
|
if(v.size() != w_size || w.size() != v_size)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
{ //v smaller than static capacity, w empty
|
||||||
|
vec v;
|
||||||
|
for(std::size_t i = 0, max = v.capacity()-1; i != max; ++i){
|
||||||
|
v.push_back(int(i));
|
||||||
|
}
|
||||||
|
vec w;
|
||||||
|
const std::size_t v_size = v.size();
|
||||||
|
const std::size_t w_size = w.size();
|
||||||
|
v.swap(w);
|
||||||
|
if(v.size() != w_size || w.size() != v_size)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
{ //v & w smaller than static capacity
|
||||||
|
vec v;
|
||||||
|
for(std::size_t i = 0, max = v.capacity()-1; i != max; ++i){
|
||||||
|
v.push_back(int(i));
|
||||||
|
}
|
||||||
|
vec w;
|
||||||
|
for(std::size_t i = 0, max = v.capacity()/2; i != max; ++i){
|
||||||
|
w.push_back(int(i));
|
||||||
|
}
|
||||||
|
const std::size_t v_size = v.size();
|
||||||
|
const std::size_t w_size = w.size();
|
||||||
|
v.swap(w);
|
||||||
|
if(v.size() != w_size || w.size() != v_size)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
{ //v & w bigger than static capacity
|
||||||
|
vec v;
|
||||||
|
for(std::size_t i = 0, max = v.capacity()+1; i != max; ++i){
|
||||||
|
v.push_back(int(i));
|
||||||
|
}
|
||||||
|
vec w;
|
||||||
|
for(std::size_t i = 0, max = v.capacity()*2; i != max; ++i){
|
||||||
|
w.push_back(int(i));
|
||||||
|
}
|
||||||
|
const std::size_t v_size = v.size();
|
||||||
|
const std::size_t w_size = w.size();
|
||||||
|
v.swap(w);
|
||||||
|
if(v.size() != w_size || w.size() != v_size)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
using namespace boost::container;
|
using namespace boost::container;
|
||||||
/*
|
|
||||||
typedef small_vector<char, 0>::storage_test storage_test;
|
|
||||||
std::cout << "needed_extra_storages: " << storage_test::needed_extra_storages << '\n';
|
|
||||||
std::cout << "needed_bytes: " << storage_test::needed_bytes << '\n';
|
|
||||||
std::cout << "header_bytes: " << storage_test::header_bytes << '\n';
|
|
||||||
std::cout << "s_start: " << storage_test::s_start << '\n';
|
|
||||||
|
|
||||||
//char
|
if(!test_swap())
|
||||||
std::cout << "sizeof(small_vector<char, 0>): " << sizeof(small_vector<char, 0>) << " extra: " << small_vector<char, 0>::needed_extra_storages << " internal storage: " << small_vector<char, 0>::internal_capacity() << '\n';
|
return 1;
|
||||||
std::cout << "sizeof(small_vector<char, 1>): " << sizeof(small_vector<char, 1>) << " extra: " << small_vector<char, 1>::needed_extra_storages << " internal storage: " << small_vector<char, 1>::internal_capacity() << '\n';
|
|
||||||
std::cout << "sizeof(small_vector<char, 2>): " << sizeof(small_vector<char, 2>) << " extra: " << small_vector<char, 2>::needed_extra_storages << " internal storage: " << small_vector<char, 2>::internal_capacity() << '\n';
|
|
||||||
std::cout << "sizeof(small_vector<char, 3>): " << sizeof(small_vector<char, 3>) << " extra: " << small_vector<char, 3>::needed_extra_storages << " internal storage: " << small_vector<char, 3>::internal_capacity() << '\n';
|
|
||||||
std::cout << "sizeof(small_vector<char, 4>): " << sizeof(small_vector<char, 4>) << " extra: " << small_vector<char, 4>::needed_extra_storages << " internal storage: " << small_vector<char, 4>::internal_capacity() << '\n';
|
|
||||||
std::cout << "sizeof(small_vector<char, 5>): " << sizeof(small_vector<char, 5>) << " extra: " << small_vector<char, 5>::needed_extra_storages << " internal storage: " << small_vector<char, 5>::internal_capacity() << '\n';
|
|
||||||
std::cout << "\n";
|
|
||||||
|
|
||||||
//short
|
|
||||||
std::cout << "sizeof(small_vector<short, 0>): " << sizeof(small_vector<short, 0>) << " extra: " << small_vector<short, 0>::needed_extra_storages << " internal storage: " << small_vector<short, 0>::internal_capacity() << '\n';
|
|
||||||
std::cout << "sizeof(small_vector<short, 1>): " << sizeof(small_vector<short, 1>) << " extra: " << small_vector<short, 1>::needed_extra_storages << " internal storage: " << small_vector<short, 1>::internal_capacity() << '\n';
|
|
||||||
std::cout << "sizeof(small_vector<short, 2>): " << sizeof(small_vector<short, 2>) << " extra: " << small_vector<short, 2>::needed_extra_storages << " internal storage: " << small_vector<short, 2>::internal_capacity() << '\n';
|
|
||||||
std::cout << "sizeof(small_vector<short, 3>): " << sizeof(small_vector<short, 3>) << " extra: " << small_vector<short, 3>::needed_extra_storages << " internal storage: " << small_vector<short, 3>::internal_capacity() << '\n';
|
|
||||||
std::cout << "sizeof(small_vector<short, 4>): " << sizeof(small_vector<short, 4>) << " extra: " << small_vector<short, 4>::needed_extra_storages << " internal storage: " << small_vector<short, 4>::internal_capacity() << '\n';
|
|
||||||
std::cout << "sizeof(small_vector<short, 5>): " << sizeof(small_vector<short, 5>) << " extra: " << small_vector<short, 5>::needed_extra_storages << " internal storage: " << small_vector<short, 5>::internal_capacity() << '\n';
|
|
||||||
*/
|
|
||||||
if(test::vector_test< small_vector<int, 0> >())
|
if(test::vector_test< small_vector<int, 0> >())
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
if(test::vector_test< small_vector<int, 2000> >())
|
if(test::vector_test< small_vector<int, 2000> >())
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
|
|
||||||
////////////////////////////////////
|
////////////////////////////////////
|
||||||
// Default init test
|
// Default init test
|
||||||
////////////////////////////////////
|
////////////////////////////////////
|
||||||
|
Reference in New Issue
Block a user