/////////////////////////////////////////////////////////////////////////////// // // (C) Copyright Ion Gaztanaga 2005-2013. 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) // // See http://www.boost.org/libs/container for documentation. // /////////////////////////////////////////////////////////////////////////////// #ifndef BOOST_CONTAINER_DUMMY_TEST_ALLOCATOR_HPP #define BOOST_CONTAINER_DUMMY_TEST_ALLOCATOR_HPP #ifndef BOOST_CONFIG_HPP # include #endif #if defined(BOOST_HAS_PRAGMA_ONCE) # pragma once #endif #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include namespace boost { namespace container { namespace test { //Very simple version 1 allocator template class simple_allocator { public: typedef T value_type; simple_allocator() {} template simple_allocator(const simple_allocator &) {} T* allocate(std::size_t n) { return (T*)::new char[sizeof(T)*n]; } void deallocate(T*p, std::size_t) { delete[] ((char*)p);} friend bool operator==(const simple_allocator &, const simple_allocator &) { return true; } friend bool operator!=(const simple_allocator &, const simple_allocator &) { return false; } }; template< class T , bool PropagateOnContCopyAssign , bool PropagateOnContMoveAssign , bool PropagateOnContSwap , bool CopyOnPropagateOnContSwap , bool EqualIfEqualIds > class propagation_test_allocator { BOOST_COPYABLE_AND_MOVABLE(propagation_test_allocator) public: typedef T value_type; typedef boost::container::dtl::bool_ propagate_on_container_copy_assignment; typedef boost::container::dtl::bool_ propagate_on_container_move_assignment; typedef boost::container::dtl::bool_ propagate_on_container_swap; template struct rebind { typedef propagation_test_allocator < T2 , PropagateOnContCopyAssign , PropagateOnContMoveAssign , PropagateOnContSwap , CopyOnPropagateOnContSwap , EqualIfEqualIds> other; }; propagation_test_allocator select_on_container_copy_construction() const { return CopyOnPropagateOnContSwap ? propagation_test_allocator(*this) : propagation_test_allocator(); } explicit propagation_test_allocator() : id_(++unique_id_) , ctr_copies_(0) , ctr_moves_(0) , assign_copies_(0) , assign_moves_(0) , swaps_(0) {} propagation_test_allocator(const propagation_test_allocator &x) : id_(x.id_) , ctr_copies_(x.ctr_copies_+1) , ctr_moves_(x.ctr_moves_) , assign_copies_(x.assign_copies_) , assign_moves_(x.assign_moves_) , swaps_(x.swaps_) {} template propagation_test_allocator(const propagation_test_allocator < U , PropagateOnContCopyAssign , PropagateOnContMoveAssign , PropagateOnContSwap , CopyOnPropagateOnContSwap , EqualIfEqualIds> &x) : id_(x.id_) , ctr_copies_(x.ctr_copies_+1) , ctr_moves_(0) , assign_copies_(0) , assign_moves_(0) , swaps_(0) {} propagation_test_allocator(BOOST_RV_REF(propagation_test_allocator) x) : id_(x.id_) , ctr_copies_(x.ctr_copies_) , ctr_moves_(x.ctr_moves_ + 1) , assign_copies_(x.assign_copies_) , assign_moves_(x.assign_moves_) , swaps_(x.swaps_) {} propagation_test_allocator &operator=(BOOST_COPY_ASSIGN_REF(propagation_test_allocator) x) { id_ = x.id_; ctr_copies_ = x.ctr_copies_; ctr_moves_ = x.ctr_moves_; assign_copies_ = x.assign_copies_+1; assign_moves_ = x.assign_moves_; swaps_ = x.swaps_; return *this; } propagation_test_allocator &operator=(BOOST_RV_REF(propagation_test_allocator) x) { id_ = x.id_; ctr_copies_ = x.ctr_copies_; ctr_moves_ = x.ctr_moves_; assign_copies_ = x.assign_copies_; assign_moves_ = x.assign_moves_+1; swaps_ = x.swaps_; return *this; } static void reset_unique_id(unsigned id = 0) { unique_id_ = id; } T* allocate(std::size_t n) { return (T*)::new char[sizeof(T)*n]; } void deallocate(T*p, std::size_t) { delete[] ((char*)p);} friend bool operator==(const propagation_test_allocator &a, const propagation_test_allocator &b) { return EqualIfEqualIds ? a.id_ == b.id_ : true; } friend bool operator!=(const propagation_test_allocator &a, const propagation_test_allocator &b) { return EqualIfEqualIds ? a.id_ != b.id_ : false; } void swap(propagation_test_allocator &r) { ++this->swaps_; ++r.swaps_; boost::adl_move_swap(this->id_, r.id_); boost::adl_move_swap(this->ctr_copies_, r.ctr_copies_); boost::adl_move_swap(this->ctr_moves_, r.ctr_moves_); boost::adl_move_swap(this->assign_copies_, r.assign_copies_); boost::adl_move_swap(this->assign_moves_, r.assign_moves_); boost::adl_move_swap(this->swaps_, r.swaps_); } friend void swap(propagation_test_allocator &l, propagation_test_allocator &r) { l.swap(r); } unsigned int id_; unsigned int ctr_copies_; unsigned int ctr_moves_; unsigned int assign_copies_; unsigned int assign_moves_; unsigned int swaps_; static unsigned unique_id_; }; template< class T , bool PropagateOnContCopyAssign , bool PropagateOnContMoveAssign , bool PropagateOnContSwap , bool CopyOnPropagateOnContSwap , bool EqualIfEqualIds > unsigned int propagation_test_allocator< T , PropagateOnContCopyAssign , PropagateOnContMoveAssign , PropagateOnContSwap , CopyOnPropagateOnContSwap , EqualIfEqualIds >::unique_id_ = 0; } //namespace test { } //namespace container { } //namespace boost { #include #endif //BOOST_CONTAINER_DUMMY_TEST_ALLOCATOR_HPP