2012-05-09 21:45:30 -07:00
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
2012-07-21 11:37:40 -07:00
|
|
|
// (C) Copyright Ion Gaztanaga 2005-2012. Distributed under the Boost
|
2012-05-09 21:45:30 -07:00
|
|
|
// 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_CONTAINER_FWD_HPP
|
|
|
|
#define BOOST_CONTAINER_CONTAINER_FWD_HPP
|
|
|
|
|
|
|
|
#if (defined _MSC_VER) && (_MSC_VER >= 1200)
|
|
|
|
# pragma once
|
|
|
|
#endif
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Standard predeclarations
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/// @cond
|
|
|
|
|
2012-07-21 11:37:40 -07:00
|
|
|
namespace boost{
|
|
|
|
namespace intrusive{
|
2012-05-09 21:45:30 -07:00
|
|
|
//Create namespace to avoid compilation errors
|
|
|
|
}}
|
|
|
|
|
|
|
|
namespace boost{ namespace container{ namespace container_detail{
|
|
|
|
|
|
|
|
namespace bi = boost::intrusive;
|
|
|
|
|
|
|
|
}}}
|
|
|
|
|
2012-07-21 11:37:40 -07:00
|
|
|
#include <utility>
|
|
|
|
#include <memory>
|
|
|
|
#include <functional>
|
2012-05-09 21:45:30 -07:00
|
|
|
#include <iosfwd>
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
/// @endcond
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Containers
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
namespace boost {
|
|
|
|
namespace container {
|
|
|
|
|
|
|
|
//vector class
|
|
|
|
template <class T
|
|
|
|
,class A = std::allocator<T> >
|
|
|
|
class vector;
|
|
|
|
|
|
|
|
//vector class
|
|
|
|
template <class T
|
|
|
|
,class A = std::allocator<T> >
|
|
|
|
class stable_vector;
|
|
|
|
|
|
|
|
//vector class
|
|
|
|
template <class T
|
|
|
|
,class A = std::allocator<T> >
|
|
|
|
class deque;
|
|
|
|
|
|
|
|
//list class
|
|
|
|
template <class T
|
|
|
|
,class A = std::allocator<T> >
|
|
|
|
class list;
|
|
|
|
|
|
|
|
//slist class
|
|
|
|
template <class T
|
|
|
|
,class A = std::allocator<T> >
|
|
|
|
class slist;
|
|
|
|
|
|
|
|
//set class
|
|
|
|
template <class T
|
|
|
|
,class Pred = std::less<T>
|
|
|
|
,class A = std::allocator<T> >
|
|
|
|
class set;
|
|
|
|
|
|
|
|
//multiset class
|
|
|
|
template <class T
|
|
|
|
,class Pred = std::less<T>
|
|
|
|
,class A = std::allocator<T> >
|
|
|
|
class multiset;
|
|
|
|
|
|
|
|
//map class
|
|
|
|
template <class Key
|
|
|
|
,class T
|
|
|
|
,class Pred = std::less<Key>
|
|
|
|
,class A = std::allocator<std::pair<const Key, T> > >
|
|
|
|
class map;
|
|
|
|
|
|
|
|
//multimap class
|
|
|
|
template <class Key
|
|
|
|
,class T
|
|
|
|
,class Pred = std::less<Key>
|
|
|
|
,class A = std::allocator<std::pair<const Key, T> > >
|
|
|
|
class multimap;
|
|
|
|
|
|
|
|
//flat_set class
|
|
|
|
template <class T
|
|
|
|
,class Pred = std::less<T>
|
|
|
|
,class A = std::allocator<T> >
|
|
|
|
class flat_set;
|
|
|
|
|
|
|
|
//flat_multiset class
|
|
|
|
template <class T
|
|
|
|
,class Pred = std::less<T>
|
|
|
|
,class A = std::allocator<T> >
|
|
|
|
class flat_multiset;
|
|
|
|
|
|
|
|
//flat_map class
|
|
|
|
template <class Key
|
|
|
|
,class T
|
|
|
|
,class Pred = std::less<Key>
|
|
|
|
,class A = std::allocator<std::pair<Key, T> > >
|
|
|
|
class flat_map;
|
|
|
|
|
|
|
|
//flat_multimap class
|
|
|
|
template <class Key
|
|
|
|
,class T
|
|
|
|
,class Pred = std::less<Key>
|
|
|
|
,class A = std::allocator<std::pair<Key, T> > >
|
|
|
|
class flat_multimap;
|
|
|
|
|
|
|
|
//basic_string class
|
|
|
|
template <class CharT
|
|
|
|
,class Traits = std::char_traits<CharT>
|
2012-07-21 11:37:40 -07:00
|
|
|
,class A = std::allocator<CharT> >
|
2012-05-09 21:45:30 -07:00
|
|
|
class basic_string;
|
|
|
|
|
|
|
|
//! Type used to tag that the input range is
|
|
|
|
//! guaranteed to be ordered
|
2012-07-21 11:37:40 -07:00
|
|
|
struct ordered_range_t
|
|
|
|
{};
|
2012-05-09 21:45:30 -07:00
|
|
|
|
|
|
|
//! Type used to tag that the input range is
|
|
|
|
//! guaranteed to be ordered and unique
|
2012-07-21 11:37:40 -07:00
|
|
|
struct ordered_unique_range_t
|
|
|
|
: public ordered_range_t
|
|
|
|
{};
|
2012-05-09 21:45:30 -07:00
|
|
|
|
|
|
|
//! Value used to tag that the input range is
|
|
|
|
//! guaranteed to be ordered
|
2012-07-21 11:37:40 -07:00
|
|
|
static const ordered_range_t ordered_range = ordered_range_t();
|
2012-05-09 21:45:30 -07:00
|
|
|
|
|
|
|
//! Value used to tag that the input range is
|
|
|
|
//! guaranteed to be ordered and unique
|
2012-07-21 11:37:40 -07:00
|
|
|
static const ordered_unique_range_t ordered_unique_range = ordered_unique_range_t();
|
2012-05-09 21:45:30 -07:00
|
|
|
|
|
|
|
/// @cond
|
|
|
|
|
|
|
|
namespace detail_really_deep_namespace {
|
|
|
|
|
|
|
|
//Otherwise, gcc issues a warning of previously defined
|
|
|
|
//anonymous_instance and unique_instance
|
|
|
|
struct dummy
|
|
|
|
{
|
|
|
|
dummy()
|
|
|
|
{
|
|
|
|
(void)ordered_range;
|
|
|
|
(void)ordered_unique_range;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
} //detail_really_deep_namespace {
|
|
|
|
|
|
|
|
/// @endcond
|
|
|
|
|
|
|
|
}} //namespace boost { namespace container {
|
|
|
|
|
|
|
|
#endif //#ifndef BOOST_CONTAINER_CONTAINER_FWD_HPP
|