2
0
mirror of https://github.com/boostorg/align.git synced 2026-01-22 17:02:10 +00:00
Files
align/test/aligned_allocator_adaptor_test.cpp
2014-08-07 09:14:31 -07:00

184 lines
4.1 KiB
C++

/*
Copyright (c) 2014 Glen Joseph Fernandes
glenfe at live dot com
Distributed under the Boost Software License,
Version 1.0. (See accompanying file LICENSE_1_0.txt
or copy at http://boost.org/LICENSE_1_0.txt)
*/
#include <boost/align/aligned_allocator_adaptor.hpp>
#include <boost/align/is_aligned.hpp>
#include <boost/core/lightweight_test.hpp>
#include <new>
#include <cstddef>
#include <cstring>
template<class T>
class Allocator {
public:
typedef T value_type;
typedef T* pointer;
typedef const T* const_pointer;
typedef void* void_pointer;
typedef const void* const_void_pointer;
typedef std::size_t size_type;
typedef std::ptrdiff_t difference_type;
typedef T& reference;
typedef const T& const_reference;
template<class U>
struct rebind {
typedef Allocator<U> other;
};
Allocator()
: state() {
}
Allocator(int value)
: state(value) {
}
template<class U>
Allocator(const Allocator<U>& other)
: state(other.state) {
}
pointer allocate(size_type size, const_void_pointer = 0) {
void* p = ::operator new(sizeof(T) * size);
return static_cast<T*>(p);
}
void deallocate(pointer ptr, size_type) {
::operator delete(ptr);
}
void construct(pointer ptr, const_reference value) {
void* p = ptr;
::new(p) T(value);
}
void destroy(pointer ptr) {
(void)ptr;
ptr->~T();
}
int state;
};
template<class T1, class T2>
bool operator==(const Allocator<T1>& a,
const Allocator<T2>& b) {
return a.state == b.state;
}
template<class T1, class T2>
bool operator!=(const Allocator<T1>& a,
const Allocator<T2>& b) {
return !(a == b);
}
template<std::size_t Alignment>
void test_allocate()
{
{
typename boost::alignment::
aligned_allocator_adaptor<Allocator<int>,
Alignment> a(5);
int* p = a.allocate(1);
BOOST_TEST(p != 0);
BOOST_TEST(boost::alignment::is_aligned(Alignment, p));
std::memset(p, 0, 1);
a.deallocate(p, 1);
}
{
typename boost::alignment::
aligned_allocator_adaptor<Allocator<int>,
Alignment> a(5);
int* p1 = a.allocate(1);
int* p2 = a.allocate(1, p1);
BOOST_TEST(p2 != 0);
BOOST_TEST(boost::alignment::is_aligned(Alignment, p2));
std::memset(p2, 0, 1);
a.deallocate(p2, 1);
a.deallocate(p1, 1);
}
{
typename boost::alignment::
aligned_allocator_adaptor<Allocator<int>,
Alignment> a(5);
int* p = a.allocate(0);
a.deallocate(p, 0);
}
}
template<std::size_t Alignment>
void test_construct()
{
typename boost::alignment::
aligned_allocator_adaptor<Allocator<int>,
Alignment> a(5);
int* p = a.allocate(1);
a.construct(p, 1);
BOOST_TEST(*p == 1);
a.destroy(p);
a.deallocate(p, 1);
}
template<std::size_t Alignment>
void test_constructor()
{
{
typename boost::alignment::
aligned_allocator_adaptor<Allocator<char>,
Alignment> a1(5);
typename boost::alignment::
aligned_allocator_adaptor<Allocator<int>,
Alignment> a2(a1);
BOOST_TEST(a2 == a1);
}
{
Allocator<int> a1(5);
typename boost::alignment::
aligned_allocator_adaptor<Allocator<int>,
Alignment> a2(a1);
BOOST_TEST(a2.base() == a1);
}
}
template<std::size_t Alignment>
void test_rebind()
{
typename boost::alignment::
aligned_allocator_adaptor<Allocator<char>,
Alignment> a1(5);
typename boost::alignment::
aligned_allocator_adaptor<Allocator<int>,
Alignment>::template
rebind<int>::other a2(a1);
BOOST_TEST(a2 == a1);
}
template<std::size_t Alignment>
void test()
{
test_allocate<Alignment>();
test_construct<Alignment>();
test_constructor<Alignment>();
test_rebind<Alignment>();
}
int main()
{
test<1>();
test<2>();
test<4>();
test<8>();
test<16>();
test<32>();
test<64>();
test<128>();
return boost::report_errors();
}