mirror of
https://github.com/boostorg/unordered.git
synced 2025-05-11 05:23:58 +00:00
48 lines
1.6 KiB
C++
48 lines
1.6 KiB
C++
|
|
// Copyright 2005-2006 Daniel James.
|
|
// 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)
|
|
|
|
#if !defined(BOOST_UNORDERED_TEST_HELPERS_STRONG_HEADER)
|
|
#define BOOST_UNORDERED_TEST_HELPERS_STRONG_HEADER
|
|
|
|
#include <boost/config.hpp>
|
|
#include <vector>
|
|
#include <iterator>
|
|
#include "./metafunctions.hpp"
|
|
#include "./equivalent.hpp"
|
|
#include "../objects/exception.hpp"
|
|
|
|
namespace test
|
|
{
|
|
template <class X>
|
|
class strong
|
|
{
|
|
typedef std::vector<typename non_const_value_type<X>::type> values_type;
|
|
values_type values_;
|
|
public:
|
|
void store(X const& x) {
|
|
// TODO: Well, I shouldn't be disabling exceptions here. Instead
|
|
// the test runner should provide a method to the test which
|
|
// disables exceptions and calls this.
|
|
//
|
|
// Actually, the test runner could also keep track of how many times
|
|
// store is called in a run. Because it knows that in the next run
|
|
// the first n-1 stores are unnecessary - since no exceptions will
|
|
// be thrown for them.
|
|
DISABLE_EXCEPTIONS;
|
|
values_.clear();
|
|
values_.reserve(x.size());
|
|
std::copy(x.cbegin(), x.cend(), std::back_inserter(values_));
|
|
}
|
|
|
|
void test(X const& x) const {
|
|
if(!(x.size() == values_.size() &&
|
|
std::equal(x.cbegin(), x.cend(), values_.begin(), test::equivalent)))
|
|
BOOST_ERROR("Strong exception safety failure.");
|
|
}
|
|
};
|
|
}
|
|
|
|
#endif
|