2013-01-13 14:38:19 -08:00
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// (C) Copyright Ion Gaztanaga 2011-2012. 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_ALLOCATOR_SCOPED_ALLOCATOR_FWD_HPP
|
|
|
|
#define BOOST_CONTAINER_ALLOCATOR_SCOPED_ALLOCATOR_FWD_HPP
|
|
|
|
|
2014-03-01 11:00:20 -08:00
|
|
|
#if defined(_MSC_VER)
|
2013-01-13 14:38:19 -08:00
|
|
|
# pragma once
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <boost/container/detail/config_begin.hpp>
|
|
|
|
#include <boost/container/detail/workaround.hpp>
|
|
|
|
|
2013-02-13 20:03:52 -08:00
|
|
|
#if defined(BOOST_NO_CXX11_VARIADIC_TEMPLATES)
|
2013-01-13 14:38:19 -08:00
|
|
|
#include <boost/container/detail/preprocessor.hpp>
|
|
|
|
#include <boost/container/detail/type_traits.hpp>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
namespace boost { namespace container {
|
|
|
|
|
|
|
|
///@cond
|
|
|
|
|
2013-02-13 20:03:52 -08:00
|
|
|
#if !defined(BOOST_NO_CXX11_VARIADIC_TEMPLATES)
|
2013-01-13 14:38:19 -08:00
|
|
|
|
|
|
|
#if !defined(BOOST_CONTAINER_UNIMPLEMENTED_PACK_EXPANSION_TO_FIXED_LIST)
|
|
|
|
|
|
|
|
template <typename OuterAlloc, typename ...InnerAllocs>
|
|
|
|
class scoped_allocator_adaptor;
|
|
|
|
|
|
|
|
#else // #if !defined(BOOST_CONTAINER_UNIMPLEMENTED_PACK_EXPANSION_TO_FIXED_LIST)
|
|
|
|
|
|
|
|
template <typename ...InnerAllocs>
|
|
|
|
class scoped_allocator_adaptor;
|
|
|
|
|
|
|
|
template <typename OuterAlloc, typename ...InnerAllocs>
|
|
|
|
class scoped_allocator_adaptor<OuterAlloc, InnerAllocs...>;
|
|
|
|
|
|
|
|
#endif // #if !defined(BOOST_CONTAINER_UNIMPLEMENTED_PACK_EXPANSION_TO_FIXED_LIST)
|
|
|
|
|
|
|
|
|
2013-02-13 20:03:52 -08:00
|
|
|
#else // #if !defined(BOOST_NO_CXX11_VARIADIC_TEMPLATES)
|
2013-01-13 14:38:19 -08:00
|
|
|
|
|
|
|
template <typename OuterAlloc
|
|
|
|
BOOST_PP_ENUM_TRAILING( BOOST_CONTAINER_MAX_CONSTRUCTOR_PARAMETERS
|
|
|
|
, BOOST_CONTAINER_PP_TEMPLATE_PARAM_WITH_DEFAULT, container_detail::nat)
|
|
|
|
>
|
|
|
|
class scoped_allocator_adaptor;
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
///@endcond
|
|
|
|
|
|
|
|
//! The allocator_arg_t struct is an empty structure type used as a unique type to
|
|
|
|
//! disambiguate constructor and function overloading. Specifically, several types
|
|
|
|
//! have constructors with allocator_arg_t as the first argument, immediately followed
|
|
|
|
//! by an argument of a type that satisfies the Allocator requirements
|
|
|
|
struct allocator_arg_t{};
|
|
|
|
|
|
|
|
//! A instance of type allocator_arg_t
|
|
|
|
//!
|
|
|
|
static const allocator_arg_t allocator_arg = allocator_arg_t();
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
struct constructible_with_allocator_suffix;
|
|
|
|
|
|
|
|
template <class T>
|
|
|
|
struct constructible_with_allocator_prefix;
|
|
|
|
|
|
|
|
template <typename T, typename Alloc>
|
|
|
|
struct uses_allocator;
|
|
|
|
|
|
|
|
}} // namespace boost { namespace container {
|
|
|
|
|
|
|
|
#include <boost/container/detail/config_end.hpp>
|
|
|
|
|
|
|
|
#endif // BOOST_CONTAINER_ALLOCATOR_SCOPED_ALLOCATOR_FWD_HPP
|