mirror of
https://github.com/boostorg/unordered.git
synced 2025-05-10 07:34:00 +00:00
* added concurrent node containers * removed spurious typename * added missing includes * avoided unused param warning * worked around Clang bug * s/{}/() to work around GCC4.8 problems with aggregate initialization * used /bigobj for cfoa/visit_tests.cpp * suppressed localized maybe-uninitialized warnings * fixed comments * added /bigobj to cfoa/insert_tests.cpp * instrumented double exact comparison to spot a spurious error * fixed pedantic error * refactored byte_span machinery * compromised on sub-epsilon equality for doubles that should be identical * documented boost::concurrent_node_(map|set) * added concurrent_node_set * added missing AlternativeType * tested empty node insertion * tested node_handle allocator management * added nonassignable_allocator and node_handle_allocator_swap_tests * fixed warning disabling * silenced spurious GCC warning * broadened scope of previous pragma * broadened even more * worked around spurious constexpr-related msvc-14.0 bug https://godbolt.org/z/v78545Ebf * added workaround back * replaced previous workaround with built-in one * added workaround back on top of built-in solution (which doesn't work 100% of the time)
175 lines
4.2 KiB
C++
175 lines
4.2 KiB
C++
// Copyright (C) 2023 Christian Mazakas
|
|
// Copyright (C) 2023-2024 Joaquin M Lopez Munoz
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
#include "helpers.hpp"
|
|
#include <boost/config/workaround.hpp>
|
|
#include <boost/unordered/concurrent_flat_map_fwd.hpp>
|
|
#include <boost/unordered/concurrent_flat_set_fwd.hpp>
|
|
#include <boost/unordered/concurrent_node_map_fwd.hpp>
|
|
#include <boost/unordered/concurrent_node_set_fwd.hpp>
|
|
#include <limits>
|
|
|
|
test::seed_t initialize_seed{32304628};
|
|
|
|
using test::default_generator;
|
|
using test::limited_range;
|
|
using test::sequential;
|
|
|
|
template <class T>
|
|
void swap_call(boost::unordered::concurrent_flat_map<T, T>& x1,
|
|
boost::unordered::concurrent_flat_map<T, T>& x2)
|
|
{
|
|
swap(x1, x2);
|
|
}
|
|
|
|
template <class T>
|
|
bool equal_call(boost::unordered::concurrent_flat_map<T, T>& x1,
|
|
boost::unordered::concurrent_flat_map<T, T>& x2)
|
|
{
|
|
return x1 == x2;
|
|
}
|
|
|
|
template <class T>
|
|
bool unequal_call(boost::unordered::concurrent_flat_map<T, T>& x1,
|
|
boost::unordered::concurrent_flat_map<T, T>& x2)
|
|
{
|
|
return x1 != x2;
|
|
}
|
|
|
|
template <class T>
|
|
void swap_call(boost::unordered::concurrent_node_map<T, T>& x1,
|
|
boost::unordered::concurrent_node_map<T, T>& x2)
|
|
{
|
|
swap(x1, x2);
|
|
}
|
|
|
|
template <class T>
|
|
bool equal_call(boost::unordered::concurrent_node_map<T, T>& x1,
|
|
boost::unordered::concurrent_node_map<T, T>& x2)
|
|
{
|
|
return x1 == x2;
|
|
}
|
|
|
|
template <class T>
|
|
bool unequal_call(boost::unordered::concurrent_node_map<T, T>& x1,
|
|
boost::unordered::concurrent_node_map<T, T>& x2)
|
|
{
|
|
return x1 != x2;
|
|
}
|
|
|
|
template <class T>
|
|
void swap_call(boost::unordered::concurrent_flat_set<T>& x1,
|
|
boost::unordered::concurrent_flat_set<T>& x2)
|
|
{
|
|
swap(x1, x2);
|
|
}
|
|
|
|
template <class T>
|
|
bool equal_call(boost::unordered::concurrent_flat_set<T>& x1,
|
|
boost::unordered::concurrent_flat_set<T>& x2)
|
|
{
|
|
return x1 == x2;
|
|
}
|
|
|
|
template <class T>
|
|
bool unequal_call(boost::unordered::concurrent_flat_set<T>& x1,
|
|
boost::unordered::concurrent_flat_set<T>& x2)
|
|
{
|
|
return x1 != x2;
|
|
}
|
|
|
|
template <class T>
|
|
void swap_call(boost::unordered::concurrent_node_set<T>& x1,
|
|
boost::unordered::concurrent_node_set<T>& x2)
|
|
{
|
|
swap(x1, x2);
|
|
}
|
|
|
|
template <class T>
|
|
bool equal_call(boost::unordered::concurrent_node_set<T>& x1,
|
|
boost::unordered::concurrent_node_set<T>& x2)
|
|
{
|
|
return x1 == x2;
|
|
}
|
|
|
|
template <class T>
|
|
bool unequal_call(boost::unordered::concurrent_node_set<T>& x1,
|
|
boost::unordered::concurrent_node_set<T>& x2)
|
|
{
|
|
return x1 != x2;
|
|
}
|
|
|
|
#include <boost/unordered/concurrent_flat_map.hpp>
|
|
#include <boost/unordered/concurrent_flat_set.hpp>
|
|
#include <boost/unordered/concurrent_node_map.hpp>
|
|
#include <boost/unordered/concurrent_node_set.hpp>
|
|
|
|
using map_type = boost::unordered::concurrent_flat_map<int, int>;
|
|
using node_map_type = boost::unordered::concurrent_node_map<int, int>;
|
|
using set_type = boost::unordered::concurrent_flat_set<int>;
|
|
using node_set_type = boost::unordered::concurrent_node_set<int>;
|
|
|
|
map_type* test_map;
|
|
node_map_type* test_node_map;
|
|
set_type* test_set;
|
|
node_set_type* test_node_set;
|
|
|
|
template <typename X>
|
|
void fwd_swap_call(X*)
|
|
{
|
|
#if !defined(BOOST_CLANG_VERSION) || \
|
|
BOOST_WORKAROUND(BOOST_CLANG_VERSION, < 30700) || \
|
|
BOOST_WORKAROUND(BOOST_CLANG_VERSION, >= 30800)
|
|
// clang-3.7 seems to have a codegen bug here so we workaround it
|
|
|
|
X x1, x2;
|
|
swap_call(x1, x2);
|
|
#endif
|
|
}
|
|
|
|
template <typename X>
|
|
void fwd_equal_call(X*)
|
|
{
|
|
X x1, x2;
|
|
BOOST_TEST(equal_call(x1, x2));
|
|
}
|
|
|
|
template <typename X>
|
|
void fwd_unequal_call(X*)
|
|
{
|
|
X x1, x2;
|
|
BOOST_TEST_NOT(unequal_call(x1, x2));
|
|
}
|
|
|
|
// this isn't the best place for this test but it's better than introducing a
|
|
// new file
|
|
template <typename X>
|
|
void max_size(X*)
|
|
{
|
|
X x1;
|
|
BOOST_TEST_EQ(
|
|
x1.max_size(), std::numeric_limits<typename X::size_type>::max());
|
|
}
|
|
|
|
// clang-format off
|
|
UNORDERED_TEST(
|
|
fwd_swap_call,
|
|
((test_map)(test_node_map)(test_set)(test_node_set)))
|
|
|
|
UNORDERED_TEST(
|
|
fwd_equal_call,
|
|
((test_map)(test_node_map)(test_set)(test_node_set)))
|
|
|
|
UNORDERED_TEST(
|
|
fwd_unequal_call,
|
|
((test_map)(test_node_map)(test_set)(test_node_set)))
|
|
|
|
UNORDERED_TEST(
|
|
max_size,
|
|
((test_map)(test_node_map)(test_set)(test_node_set)))
|
|
// clang-format on
|
|
|
|
RUN_TESTS()
|