mirror of
https://github.com/boostorg/unordered.git
synced 2025-05-10 07:34:00 +00:00
Merged revisions 43922,43962,43966,43971,43981,43995-43996,44042,44046-44048,44057 via svnmerge from https://svn.boost.org/svn/boost/branches/unordered/trunk ........ r43922 | danieljames | 2008-03-29 14:55:59 +0000 (Sat, 29 Mar 2008) | 1 line Fix some typos in the reference documentation. ........ r43962 | danieljames | 2008-03-31 18:29:59 +0100 (Mon, 31 Mar 2008) | 1 line Add a name variable to the release script, so that I can have different release names in different branches. ........ r43966 | danieljames | 2008-03-31 18:43:16 +0100 (Mon, 31 Mar 2008) | 1 line Fix the image directory for standalone docs. ........ r43971 | danieljames | 2008-03-31 19:17:25 +0100 (Mon, 31 Mar 2008) | 1 line Fix the unordered stylesheet. ........ r43981 | danieljames | 2008-04-01 13:31:26 +0100 (Tue, 01 Apr 2008) | 2 lines Cast the pointer in the Visual C++ 6.5 _Charalloc method. ........ r43995 | danieljames | 2008-04-02 12:50:27 +0100 (Wed, 02 Apr 2008) | 1 line Try using the interprocess containers for testing. Compilation is a bit slower but hopefully I'll run into less cross-platform problems. ........ r43996 | danieljames | 2008-04-02 13:25:49 +0100 (Wed, 02 Apr 2008) | 1 line Revert my experiment with the interprocess containers. It didn't work out. ........ r44042 | danieljames | 2008-04-04 20:38:09 +0100 (Fri, 04 Apr 2008) | 1 line Make hash table data a member of hash table, instead of a base. ........ r44046 | danieljames | 2008-04-05 12:38:05 +0100 (Sat, 05 Apr 2008) | 1 line Remove rvalue_ref from Jamfile.v2 - I didn't mean to check it in. ........ r44047 | danieljames | 2008-04-05 12:39:38 +0100 (Sat, 05 Apr 2008) | 1 line New constructors with allocators. ........ r44048 | danieljames | 2008-04-05 12:58:11 +0100 (Sat, 05 Apr 2008) | 1 line Document the new constructors. ........ r44057 | danieljames | 2008-04-05 17:08:23 +0100 (Sat, 05 Apr 2008) | 1 line Fix some bugs in the exception testing code. ........ [SVN r44417]
138 lines
3.1 KiB
C++
138 lines
3.1 KiB
C++
|
|
// Copyright 2006-2008 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)
|
|
|
|
#include "./containers.hpp"
|
|
#include "../helpers/random_values.hpp"
|
|
#include "../helpers/input_iterator.hpp"
|
|
|
|
test::seed_t seed(91274);
|
|
|
|
struct objects
|
|
{
|
|
test::exception::object obj;
|
|
test::exception::hash hash;
|
|
test::exception::equal_to equal_to;
|
|
test::exception::allocator<test::exception::object> allocator;
|
|
};
|
|
|
|
template <class T>
|
|
struct construct_test1 : public objects, test::exception_base
|
|
{
|
|
void run() const {
|
|
T x;
|
|
}
|
|
};
|
|
|
|
template <class T>
|
|
struct construct_test2 : public objects, test::exception_base
|
|
{
|
|
void run() const {
|
|
T x(300);
|
|
}
|
|
};
|
|
|
|
template <class T>
|
|
struct construct_test3 : public objects, test::exception_base
|
|
{
|
|
void run() const {
|
|
T x(0, hash);
|
|
}
|
|
};
|
|
|
|
template <class T>
|
|
struct construct_test4 : public objects, test::exception_base
|
|
{
|
|
void run() const {
|
|
T x(0, hash, equal_to);
|
|
}
|
|
};
|
|
|
|
template <class T>
|
|
struct construct_test5 : public objects, test::exception_base
|
|
{
|
|
void run() const {
|
|
T x(50, hash, equal_to, allocator);
|
|
}
|
|
};
|
|
|
|
template <class T>
|
|
struct construct_test6 : public objects, test::exception_base
|
|
{
|
|
void run() const {
|
|
T x(allocator);
|
|
}
|
|
};
|
|
|
|
template <class T>
|
|
struct range : public test::exception_base
|
|
{
|
|
test::random_values<T> values;
|
|
|
|
range() : values(5) {}
|
|
range(unsigned int count) : values(count) {}
|
|
};
|
|
|
|
template <class T>
|
|
struct range_construct_test1 : public range<T>, objects
|
|
{
|
|
void run() const {
|
|
T x(this->values.begin(), this->values.end());
|
|
}
|
|
};
|
|
|
|
template <class T>
|
|
struct range_construct_test2 : public range<T>, objects
|
|
{
|
|
void run() const {
|
|
T x(this->values.begin(), this->values.end(), 0);
|
|
}
|
|
};
|
|
|
|
template <class T>
|
|
struct range_construct_test3 : public range<T>, objects
|
|
{
|
|
void run() const {
|
|
T x(this->values.begin(), this->values.end(), 0, hash);
|
|
}
|
|
};
|
|
|
|
template <class T>
|
|
struct range_construct_test4 : public range<T>, objects
|
|
{
|
|
void run() const {
|
|
T x(this->values.begin(), this->values.end(), 100, hash, equal_to);
|
|
}
|
|
};
|
|
|
|
// Need to run at least one test with a fairly large number
|
|
// of objects in case it triggers a rehash.
|
|
template <class T>
|
|
struct range_construct_test5 : public range<T>, objects
|
|
{
|
|
range_construct_test5() : range<T>(60) {}
|
|
|
|
void run() const {
|
|
T x(this->values.begin(), this->values.end(), 0, hash, equal_to, allocator);
|
|
}
|
|
};
|
|
|
|
template <class T>
|
|
struct input_range_construct_test : public range<T>, objects
|
|
{
|
|
input_range_construct_test() : range<T>(60) {}
|
|
|
|
void run() const {
|
|
T x(test::input_iterator(this->values.begin()),
|
|
test::input_iterator(this->values.end()),
|
|
0, hash, equal_to, allocator);
|
|
}
|
|
};
|
|
|
|
RUN_EXCEPTION_TESTS(
|
|
(construct_test1)(construct_test2)(construct_test3)(construct_test4)(construct_test5)(construct_test6)
|
|
(range_construct_test1)(range_construct_test2)(range_construct_test3)(range_construct_test4)(range_construct_test5)
|
|
(input_range_construct_test),
|
|
CONTAINER_SEQ)
|