...one of the most highly
regarded and expertly designed C++ library projects in the
world.
— Herb Sutter and Andrei
Alexandrescu, C++
Coding Standards
namespace boost { namespace container { struct ordered_range_impl_t; struct ordered_unique_range_impl_t; static const ordered_range_t ordered_range; static const ordered_unique_range_t ordered_unique_range; } }
namespace boost { namespace container { template<typename T, typename A = std::allocator<T> > class deque; template<typename T, typename A> bool operator==(const deque< T, A > & x, const deque< T, A > & y); template<typename T, typename A> bool operator<(const deque< T, A > & x, const deque< T, A > & y); template<typename T, typename A> bool operator!=(const deque< T, A > & x, const deque< T, A > & y); template<typename T, typename A> bool operator>(const deque< T, A > & x, const deque< T, A > & y); template<typename T, typename A> bool operator<=(const deque< T, A > & x, const deque< T, A > & y); template<typename T, typename A> bool operator>=(const deque< T, A > & x, const deque< T, A > & y); template<typename T, typename A> void swap(deque< T, A > & x, deque< T, A > & y); } }
namespace boost { namespace container { template<typename Key, typename T, typename Pred = std::less< std::pair< Key, T> >, typename A = std::allocator<T> > class flat_map; template<typename Key, typename T, typename Pred = std::less< std::pair< Key, T> >, typename A = std::allocator<T> > class flat_multimap; template<typename Key, typename T, typename Pred, typename A> bool operator==(const flat_map< Key, T, Pred, A > & x, const flat_map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator<(const flat_map< Key, T, Pred, A > & x, const flat_map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator!=(const flat_map< Key, T, Pred, A > & x, const flat_map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator>(const flat_map< Key, T, Pred, A > & x, const flat_map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator<=(const flat_map< Key, T, Pred, A > & x, const flat_map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator>=(const flat_map< Key, T, Pred, A > & x, const flat_map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> void swap(flat_map< Key, T, Pred, A > & x, flat_map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator==(const flat_multimap< Key, T, Pred, A > & x, const flat_multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator<(const flat_multimap< Key, T, Pred, A > & x, const flat_multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator!=(const flat_multimap< Key, T, Pred, A > & x, const flat_multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator>(const flat_multimap< Key, T, Pred, A > & x, const flat_multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator<=(const flat_multimap< Key, T, Pred, A > & x, const flat_multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator>=(const flat_multimap< Key, T, Pred, A > & x, const flat_multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> void swap(flat_multimap< Key, T, Pred, A > & x, flat_multimap< Key, T, Pred, A > & y); } }
namespace boost { namespace container { template<typename T, typename Pred = std::less<T>, typename A = std::allocator<T> > class flat_set; template<typename T, typename Pred = std::less<T>, typename A = std::allocator<T> > class flat_multiset; template<typename T, typename Pred, typename A> bool operator==(const flat_set< T, Pred, A > & x, const flat_set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator<(const flat_set< T, Pred, A > & x, const flat_set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator!=(const flat_set< T, Pred, A > & x, const flat_set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator>(const flat_set< T, Pred, A > & x, const flat_set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator<=(const flat_set< T, Pred, A > & x, const flat_set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator>=(const flat_set< T, Pred, A > & x, const flat_set< T, Pred, A > & y); template<typename T, typename Pred, typename A> void swap(flat_set< T, Pred, A > & x, flat_set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator==(const flat_multiset< T, Pred, A > & x, const flat_multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator<(const flat_multiset< T, Pred, A > & x, const flat_multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator!=(const flat_multiset< T, Pred, A > & x, const flat_multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator>(const flat_multiset< T, Pred, A > & x, const flat_multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator<=(const flat_multiset< T, Pred, A > & x, const flat_multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator>=(const flat_multiset< T, Pred, A > & x, const flat_multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> void swap(flat_multiset< T, Pred, A > & x, flat_multiset< T, Pred, A > & y); } }
namespace boost { namespace container { template<typename T, typename A = std::allocator<T> > class list; template<typename T, typename A> bool operator==(const list< T, A > & x, const list< T, A > & y); template<typename T, typename A> bool operator<(const list< T, A > & x, const list< T, A > & y); template<typename T, typename A> bool operator!=(const list< T, A > & x, const list< T, A > & y); template<typename T, typename A> bool operator>(const list< T, A > & x, const list< T, A > & y); template<typename T, typename A> bool operator<=(const list< T, A > & x, const list< T, A > & y); template<typename T, typename A> bool operator>=(const list< T, A > & x, const list< T, A > & y); template<typename T, typename A> void swap(list< T, A > & x, list< T, A > & y); } }
namespace boost { namespace container { template<typename Key, typename T, typename Pred = std::less< std::pair< const Key, T> >, typename A = std::allocator<T> > class map; template<typename Key, typename T, typename Pred = std::less< std::pair< const Key, T> >, typename A = std::allocator<T> > class multimap; template<typename Key, typename T, typename Pred, typename A> bool operator==(const map< Key, T, Pred, A > & x, const map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator<(const map< Key, T, Pred, A > & x, const map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator!=(const map< Key, T, Pred, A > & x, const map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator>(const map< Key, T, Pred, A > & x, const map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator<=(const map< Key, T, Pred, A > & x, const map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator>=(const map< Key, T, Pred, A > & x, const map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> void swap(map< Key, T, Pred, A > & x, map< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator==(const multimap< Key, T, Pred, A > & x, const multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator<(const multimap< Key, T, Pred, A > & x, const multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator!=(const multimap< Key, T, Pred, A > & x, const multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator>(const multimap< Key, T, Pred, A > & x, const multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator<=(const multimap< Key, T, Pred, A > & x, const multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> bool operator>=(const multimap< Key, T, Pred, A > & x, const multimap< Key, T, Pred, A > & y); template<typename Key, typename T, typename Pred, typename A> void swap(multimap< Key, T, Pred, A > & x, multimap< Key, T, Pred, A > & y); } }
namespace boost { namespace container { template<typename T, typename Pred = std::less<T>, typename A = std::allocator<T> > class set; template<typename T, typename Pred = std::less<T>, typename A = std::allocator<T> > class multiset; template<typename T, typename Pred, typename A> bool operator==(const set< T, Pred, A > & x, const set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator<(const set< T, Pred, A > & x, const set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator!=(const set< T, Pred, A > & x, const set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator>(const set< T, Pred, A > & x, const set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator<=(const set< T, Pred, A > & x, const set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator>=(const set< T, Pred, A > & x, const set< T, Pred, A > & y); template<typename T, typename Pred, typename A> void swap(set< T, Pred, A > & x, set< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator==(const multiset< T, Pred, A > & x, const multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator<(const multiset< T, Pred, A > & x, const multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator!=(const multiset< T, Pred, A > & x, const multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator>(const multiset< T, Pred, A > & x, const multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator<=(const multiset< T, Pred, A > & x, const multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> bool operator>=(const multiset< T, Pred, A > & x, const multiset< T, Pred, A > & y); template<typename T, typename Pred, typename A> void swap(multiset< T, Pred, A > & x, multiset< T, Pred, A > & y); } }
namespace boost { namespace container { template<typename T, typename A = std::allocator<T> > class slist; template<typename T, typename A> bool operator==(const slist< T, A > & x, const slist< T, A > & y); template<typename T, typename A> bool operator<(const slist< T, A > & sL1, const slist< T, A > & sL2); template<typename T, typename A> bool operator!=(const slist< T, A > & sL1, const slist< T, A > & sL2); template<typename T, typename A> bool operator>(const slist< T, A > & sL1, const slist< T, A > & sL2); template<typename T, typename A> bool operator<=(const slist< T, A > & sL1, const slist< T, A > & sL2); template<typename T, typename A> bool operator>=(const slist< T, A > & sL1, const slist< T, A > & sL2); template<typename T, typename A> void swap(slist< T, A > & x, slist< T, A > & y); } }
namespace boost { namespace container { template<typename T, typename A = std::allocator<T> > class stable_vector; template<typename T, typename A> bool operator==(const stable_vector< T, A > & x, const stable_vector< T, A > & y); template<typename T, typename A> bool operator<(const stable_vector< T, A > & x, const stable_vector< T, A > & y); template<typename T, typename A> bool operator!=(const stable_vector< T, A > & x, const stable_vector< T, A > & y); template<typename T, typename A> bool operator>(const stable_vector< T, A > & x, const stable_vector< T, A > & y); template<typename T, typename A> bool operator>=(const stable_vector< T, A > & x, const stable_vector< T, A > & y); template<typename T, typename A> bool operator<=(const stable_vector< T, A > & x, const stable_vector< T, A > & y); template<typename T, typename A> void swap(stable_vector< T, A > & x, stable_vector< T, A > & y); } }
namespace boost { namespace container { template<typename CharT, typename Traits = std::char_traits<CharT>, typename A = std::allocator<CharT> > class basic_string; typedef basic_string< char,std::char_traits< char >,std::allocator< char > > string; typedef basic_string< wchar_t,std::char_traits< wchar_t >,std::allocator< wchar_t > > wstring; template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > operator+(const basic_string< CharT, Traits, A > & x, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && operator+(basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && mx, basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && my); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && operator+(basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && mx, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && operator+(const basic_string< CharT, Traits, A > & x, basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && my); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > operator+(const CharT * s, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && operator+(const CharT * s, basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && my); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > operator+(CharT c, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && operator+(CharT c, basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && my); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > operator+(const basic_string< CharT, Traits, A > & x, const CharT * s); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && operator+(basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && mx, const CharT * s); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > operator+(const basic_string< CharT, Traits, A > & x, const CharT c); template<typename CharT, typename Traits, typename A> basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && operator+(basic_string< CharT, Traits, A > basic_string< CharT, Traits, A > && mx, const CharT c); template<typename CharT, typename Traits, typename A> bool operator==(const basic_string< CharT, Traits, A > & x, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator==(const CharT * s, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator==(const basic_string< CharT, Traits, A > & x, const CharT * s); template<typename CharT, typename Traits, typename A> bool operator!=(const basic_string< CharT, Traits, A > & x, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator!=(const CharT * s, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator!=(const basic_string< CharT, Traits, A > & x, const CharT * s); template<typename CharT, typename Traits, typename A> bool operator<(const basic_string< CharT, Traits, A > & x, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator<(const CharT * s, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator<(const basic_string< CharT, Traits, A > & x, const CharT * s); template<typename CharT, typename Traits, typename A> bool operator>(const basic_string< CharT, Traits, A > & x, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator>(const CharT * s, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator>(const basic_string< CharT, Traits, A > & x, const CharT * s); template<typename CharT, typename Traits, typename A> bool operator<=(const basic_string< CharT, Traits, A > & x, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator<=(const CharT * s, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator<=(const basic_string< CharT, Traits, A > & x, const CharT * s); template<typename CharT, typename Traits, typename A> bool operator>=(const basic_string< CharT, Traits, A > & x, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator>=(const CharT * s, const basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> bool operator>=(const basic_string< CharT, Traits, A > & x, const CharT * s); template<typename CharT, typename Traits, typename A> void swap(basic_string< CharT, Traits, A > & x, basic_string< CharT, Traits, A > & y); template<typename CharT, typename Traits, typename A> std::basic_ostream< CharT, Traits > & operator<<(std::basic_ostream< CharT, Traits > & os, const basic_string< CharT, Traits, A > & s); template<typename CharT, typename Traits, typename A> std::basic_istream< CharT, Traits > & operator>>(std::basic_istream< CharT, Traits > & is, basic_string< CharT, Traits, A > & s); template<typename CharT, typename Traits, typename A> std::basic_istream< CharT, Traits > & getline(std::istream & is, basic_string< CharT, Traits, A > & s, CharT delim); template<typename CharT, typename Traits, typename A> std::basic_istream< CharT, Traits > & getline(std::basic_istream< CharT, Traits > & is, basic_string< CharT, Traits, A > & s); template<typename Ch, typename A> std::size_t hash_value(basic_string< Ch, std::char_traits< Ch >, A > const & v); } }
namespace boost { namespace container { template<typename T, typename A = std::allocator<T> > class vector; template<typename T, typename A> bool operator==(const vector< T, A > & x, const vector< T, A > & y); template<typename T, typename A> bool operator!=(const vector< T, A > & x, const vector< T, A > & y); template<typename T, typename A> bool operator<(const vector< T, A > & x, const vector< T, A > & y); template<typename T, typename A> void swap(vector< T, A > & x, vector< T, A > & y); } }