2007-05-04 21:22:02 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
//
|
2007-05-12 12:54:15 +00:00
|
|
|
// (C) Copyright Ion Gaztanaga 2007
|
2007-05-04 21:22:02 +00:00
|
|
|
//
|
|
|
|
|
// 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/intrusive for documentation.
|
|
|
|
|
//
|
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
#ifndef BOOST_INTRUSIVE_FWD_HPP
|
|
|
|
|
#define BOOST_INTRUSIVE_FWD_HPP
|
|
|
|
|
|
|
|
|
|
#include <cstddef>
|
2007-09-26 15:26:35 +00:00
|
|
|
#include <boost/intrusive/link_mode.hpp>
|
|
|
|
|
|
|
|
|
|
/// @cond
|
2007-05-04 21:22:02 +00:00
|
|
|
|
|
|
|
|
//std predeclarations
|
|
|
|
|
namespace std{
|
|
|
|
|
|
|
|
|
|
template<class T>
|
|
|
|
|
struct equal_to;
|
|
|
|
|
|
|
|
|
|
template<class T>
|
|
|
|
|
struct less;
|
|
|
|
|
|
|
|
|
|
} //namespace std{
|
|
|
|
|
|
|
|
|
|
namespace boost {
|
2007-06-23 13:01:38 +00:00
|
|
|
|
|
|
|
|
//Hash predeclaration
|
|
|
|
|
template<class T>
|
|
|
|
|
struct hash;
|
|
|
|
|
|
2007-05-04 21:22:02 +00:00
|
|
|
namespace intrusive {
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
struct none;
|
|
|
|
|
|
|
|
|
|
} //namespace intrusive{
|
|
|
|
|
} //namespace boost{
|
|
|
|
|
|
|
|
|
|
namespace boost {
|
|
|
|
|
namespace intrusive {
|
|
|
|
|
|
2007-05-04 21:22:02 +00:00
|
|
|
////////////////////////////
|
|
|
|
|
// Node algorithms
|
|
|
|
|
////////////////////////////
|
|
|
|
|
|
|
|
|
|
//Algorithms predeclarations
|
|
|
|
|
template<class NodeTraits>
|
|
|
|
|
class circular_list_algorithms;
|
|
|
|
|
|
|
|
|
|
template<class NodeTraits>
|
|
|
|
|
class circular_slist_algorithms;
|
|
|
|
|
|
|
|
|
|
template<class NodeTraits>
|
|
|
|
|
class rbtree_algorithms;
|
|
|
|
|
|
|
|
|
|
////////////////////////////
|
|
|
|
|
// Containers
|
|
|
|
|
////////////////////////////
|
|
|
|
|
|
|
|
|
|
//slist
|
2007-09-26 15:26:35 +00:00
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class slist;
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class slist_base_hook;
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class slist_member_hook;
|
|
|
|
|
|
|
|
|
|
//list
|
2007-09-26 15:26:35 +00:00
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class list;
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class list_base_hook;
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class list_member_hook;
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
//rbtree/set/multiset
|
|
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class rbtree;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class set;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class multiset;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
2007-10-24 18:59:26 +00:00
|
|
|
, class O4 = none
|
2007-09-26 15:26:35 +00:00
|
|
|
>
|
|
|
|
|
class set_base_hook;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
2007-10-24 18:59:26 +00:00
|
|
|
, class O4 = none
|
2007-09-26 15:26:35 +00:00
|
|
|
>
|
|
|
|
|
class set_member_hook;
|
|
|
|
|
|
2007-10-24 18:59:26 +00:00
|
|
|
//splaytree/splay_set/splay_multiset
|
|
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class splaytree;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class splay_set;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class splay_multiset;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
>
|
|
|
|
|
class splay_set_base_hook;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
>
|
|
|
|
|
class splay_set_member_hook;
|
|
|
|
|
|
2007-10-30 07:00:51 +00:00
|
|
|
//avltree/avl_set/avl_multiset
|
|
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class avltree;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class avl_set;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class avl_multiset;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class avl_set_base_hook;
|
|
|
|
|
|
|
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
>
|
|
|
|
|
class avl_set_member_hook;
|
|
|
|
|
|
2007-05-04 21:22:02 +00:00
|
|
|
//hash/unordered
|
2007-09-26 15:26:35 +00:00
|
|
|
//rbtree/set/multiset
|
|
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
, class O5 = none
|
|
|
|
|
, class O6 = none
|
|
|
|
|
, class O7 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class hashtable;
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
, class O5 = none
|
|
|
|
|
, class O6 = none
|
|
|
|
|
, class O7 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class unordered_set;
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
template
|
|
|
|
|
< class T
|
|
|
|
|
, class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
, class O4 = none
|
|
|
|
|
, class O5 = none
|
|
|
|
|
, class O6 = none
|
|
|
|
|
, class O7 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class unordered_multiset;
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class unordered_set_base_hook;
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
template
|
|
|
|
|
< class O1 = none
|
|
|
|
|
, class O2 = none
|
|
|
|
|
, class O3 = none
|
|
|
|
|
>
|
2007-05-04 21:22:02 +00:00
|
|
|
class unordered_set_member_hook;
|
|
|
|
|
|
|
|
|
|
} //namespace intrusive {
|
|
|
|
|
} //namespace boost {
|
|
|
|
|
|
2007-09-26 15:26:35 +00:00
|
|
|
/// @endcond
|
|
|
|
|
|
2007-05-04 21:22:02 +00:00
|
|
|
#endif //#ifndef BOOST_INTRUSIVE_FWD_HPP
|