erase_store_hash_fn_imps.hpp: Formatting fixes.

2006-09-28  Benjamin Kosnik  <bkoz@redhat.com>

	* include/ext/pb_ds/detail/cc_hash_table_map_/
	erase_store_hash_fn_imps.hpp: Formatting fixes.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	constructor_destructor_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/cmp_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	insert_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/find_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	policy_access_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	resize_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	constructor_destructor_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	insert_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/info_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	entry_list_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/trace_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	find_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/erase_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	debug_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/resize_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	constructor_destructor_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	cond_key_dtor_entry_dealtor.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	debug_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	erase_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/size_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	iterators_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/cc_hash_table_map_/
	resize_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/find_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/policy_access_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/child_iterator.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/update_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/split_join_branch_bag.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/head.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/info_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/cond_dtor_entry_dealtor.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/pat_trie_.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/leaf.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/trace_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/erase_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/node_base.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/node_iterators.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/point_iterators.hpp: Same.
	* include/ext/pb_ds/detail/pat_trie_/iterators_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	erase_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	constructor_destructor_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	insert_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	policy_access_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	resize_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/gp_ht_map_.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	constructor_destructor_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	insert_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	iterator_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	info_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	find_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	find_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	debug_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/resize_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	constructor_destructor_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	erase_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/gp_hash_table_map_/
	resize_no_store_hash_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/binomial_heap_/binomial_heap_.hpp: Same.
	* include/ext/pb_ds/detail/ov_tree_map_/erase_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/ov_tree_map_/
	policy_access_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/ov_tree_map_/insert_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/ov_tree_map_/ov_tree_map_.hpp: Same.
	* include/ext/pb_ds/detail/ov_tree_map_/debug_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/ov_tree_map_/node_iterators.hpp: Same.
	* include/ext/pb_ds/detail/ov_tree_map_/split_join_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/ov_tree_map_/info_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/ov_tree_map_/iterators_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/splay_tree_/erase_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/splay_tree_/find_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/splay_tree_/insert_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/splay_tree_/
	constructors_destructor_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/splay_tree_/debug_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/splay_tree_/splay_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/splay_tree_/node.hpp: Same.
	* include/ext/pb_ds/detail/splay_tree_/split_join_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/splay_tree_/splay_tree_.hpp: Same.
	* include/ext/pb_ds/detail/splay_tree_/traits.hpp: Same.
	* include/ext/pb_ds/detail/list_update_map_/trace_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/list_update_map_/erase_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/list_update_map_/
	entry_metadata_base.hpp: Same.
	* include/ext/pb_ds/detail/list_update_map_/find_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/list_update_map_/lu_map_.hpp: Same.
	* include/ext/pb_ds/detail/list_update_map_/insert_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/list_update_map_/info_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/list_update_map_/
	iterators_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/rb_tree_map_/erase_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/rb_tree_map_/insert_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/rb_tree_map_/
	constructors_destructor_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/rb_tree_map_/debug_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/rb_tree_map_/rb_tree_.hpp: Same.
	* include/ext/pb_ds/detail/rb_tree_map_/node.hpp: Same.
	* include/ext/pb_ds/detail/rb_tree_map_/split_join_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/rb_tree_map_/info_fn_imps.hpp: Same.
	* include/ext/pb_ds/detail/rb_tree_map_/traits.hpp: Same.

From-SVN: r117281
This commit is contained in:
Benjamin Kosnik 2006-09-28 13:40:07 +00:00 committed by Benjamin Kosnik
parent 4553813629
commit 1b24692f65
94 changed files with 1281 additions and 2569 deletions

View File

@ -1,3 +1,135 @@
2006-09-28 Benjamin Kosnik <bkoz@redhat.com>
* include/ext/pb_ds/detail/cc_hash_table_map_/
erase_store_hash_fn_imps.hpp: Formatting fixes.
* include/ext/pb_ds/detail/cc_hash_table_map_/
constructor_destructor_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/cmp_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
insert_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/find_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
policy_access_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
resize_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
constructor_destructor_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
insert_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/info_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
entry_list_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/trace_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
find_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/erase_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
debug_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/resize_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
constructor_destructor_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
cond_key_dtor_entry_dealtor.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
debug_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
erase_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/size_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
iterators_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/cc_hash_table_map_/
resize_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/find_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/policy_access_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/child_iterator.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/update_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/split_join_branch_bag.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/head.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/info_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/cond_dtor_entry_dealtor.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/pat_trie_.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/leaf.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/trace_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/erase_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/node_base.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/node_iterators.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/point_iterators.hpp: Same.
* include/ext/pb_ds/detail/pat_trie_/iterators_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
erase_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
constructor_destructor_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
insert_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
policy_access_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
resize_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/gp_ht_map_.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
constructor_destructor_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
insert_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
iterator_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
info_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
find_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
find_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
debug_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/resize_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
constructor_destructor_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
erase_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/gp_hash_table_map_/
resize_no_store_hash_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/binomial_heap_/binomial_heap_.hpp: Same.
* include/ext/pb_ds/detail/ov_tree_map_/erase_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/ov_tree_map_/
policy_access_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/ov_tree_map_/insert_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/ov_tree_map_/ov_tree_map_.hpp: Same.
* include/ext/pb_ds/detail/ov_tree_map_/debug_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/ov_tree_map_/node_iterators.hpp: Same.
* include/ext/pb_ds/detail/ov_tree_map_/split_join_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/ov_tree_map_/info_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/ov_tree_map_/iterators_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/splay_tree_/erase_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/splay_tree_/find_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/splay_tree_/insert_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/splay_tree_/
constructors_destructor_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/splay_tree_/debug_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/splay_tree_/splay_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/splay_tree_/node.hpp: Same.
* include/ext/pb_ds/detail/splay_tree_/split_join_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/splay_tree_/splay_tree_.hpp: Same.
* include/ext/pb_ds/detail/splay_tree_/traits.hpp: Same.
* include/ext/pb_ds/detail/list_update_map_/trace_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/list_update_map_/erase_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/list_update_map_/
entry_metadata_base.hpp: Same.
* include/ext/pb_ds/detail/list_update_map_/find_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/list_update_map_/lu_map_.hpp: Same.
* include/ext/pb_ds/detail/list_update_map_/insert_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/list_update_map_/info_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/list_update_map_/
iterators_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/rb_tree_map_/erase_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/rb_tree_map_/insert_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/rb_tree_map_/
constructors_destructor_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/rb_tree_map_/debug_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/rb_tree_map_/rb_tree_.hpp: Same.
* include/ext/pb_ds/detail/rb_tree_map_/node.hpp: Same.
* include/ext/pb_ds/detail/rb_tree_map_/split_join_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/rb_tree_map_/info_fn_imps.hpp: Same.
* include/ext/pb_ds/detail/rb_tree_map_/traits.hpp: Same.
2006-09-28 Paolo Carlini <pcarlini@suse.de> 2006-09-28 Paolo Carlini <pcarlini@suse.de>
* include/tr1/boost_shared_ptr.h: Use __atomic_add_dispatch and * include/tr1/boost_shared_ptr.h: Use __atomic_add_dispatch and

View File

@ -75,44 +75,26 @@ namespace pb_ds
template<typename Value_Type, class Cmp_Fn, class Allocator> template<typename Value_Type, class Cmp_Fn, class Allocator>
class binomial_heap_ : public PB_DS_BASE_C_DEC class binomial_heap_ : public PB_DS_BASE_C_DEC
{ {
private: private:
typedef PB_DS_BASE_C_DEC base_type; typedef PB_DS_BASE_C_DEC base_type;
typedef typename base_type::node_pointer node_pointer; typedef typename base_type::node_pointer node_pointer;
typedef typename base_type::const_node_pointer const_node_pointer; typedef typename base_type::const_node_pointer const_node_pointer;
public: public:
typedef typename Allocator::size_type size_type;
typedef typename Allocator::difference_type difference_type;
typedef Value_Type value_type; typedef Value_Type value_type;
typedef typename Allocator::size_type size_type;
typedef typename Allocator::difference_type difference_type;
typedef typename base_type::pointer pointer; typedef typename base_type::pointer pointer;
typedef typename base_type::const_pointer const_pointer; typedef typename base_type::const_pointer const_pointer;
typedef typename base_type::reference reference; typedef typename base_type::reference reference;
typedef typename base_type::const_reference const_reference; typedef typename base_type::const_reference const_reference;
typedef typename base_type::const_point_iterator const_point_iterator; typedef typename base_type::const_point_iterator const_point_iterator;
typedef typename base_type::point_iterator point_iterator; typedef typename base_type::point_iterator point_iterator;
typedef typename base_type::const_iterator const_iterator; typedef typename base_type::const_iterator const_iterator;
typedef typename base_type::iterator iterator; typedef typename base_type::iterator iterator;
typedef typename base_type::cmp_fn cmp_fn; typedef typename base_type::cmp_fn cmp_fn;
typedef typename base_type::allocator allocator; typedef typename base_type::allocator allocator;
public:
binomial_heap_(); binomial_heap_();
binomial_heap_(const Cmp_Fn& r_cmp_fn); binomial_heap_(const Cmp_Fn& r_cmp_fn);

View File

@ -50,9 +50,7 @@ template<typename Other_HT_Map_Type>
bool bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
operator==(const Other_HT_Map_Type& other) const operator==(const Other_HT_Map_Type& other) const
{ { return cmp_with_other(other); }
return (cmp_with_other(other));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
template<typename Other_Map_Type> template<typename Other_Map_Type>
@ -61,27 +59,26 @@ PB_DS_CLASS_C_DEC::
cmp_with_other(const Other_Map_Type& other) const cmp_with_other(const Other_Map_Type& other) const
{ {
if (size() != other.size()) if (size() != other.size())
return (false); return false;
for (typename Other_Map_Type::const_iterator it = other.begin(); for (typename Other_Map_Type::const_iterator it = other.begin();
it != other.end(); ++it) it != other.end(); ++it)
{ {
const_key_reference r_key =(const_key_reference)PB_DS_V2F(*it); const_key_reference r_key = const_key_reference(PB_DS_V2F(*it));
const_mapped_pointer p_mapped_value = const_mapped_pointer p_mapped_value =
const_cast<PB_DS_CLASS_C_DEC& >(*this). const_cast<PB_DS_CLASS_C_DEC& >(*this).
find_key_pointer(r_key, traits_base::m_store_hash_indicator); find_key_pointer(r_key, traits_base::m_store_hash_indicator);
if (p_mapped_value == NULL) if (p_mapped_value == NULL)
return (false); return false;
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
if (p_mapped_value->second != it->second) if (p_mapped_value->second != it->second)
return (false); return false;
#endif #endif
} }
return true;
return (true);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -89,6 +86,4 @@ template<typename Other_HT_Map_Type>
bool bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
operator!=(const Other_HT_Map_Type& other) const operator!=(const Other_HT_Map_Type& other) const
{ { return !operator==(other); }
return (!operator==(other));
}

View File

@ -49,12 +49,8 @@ namespace pb_ds
namespace detail namespace detail
{ {
#define PB_DS_CLASS_T_DEC \ #define PB_DS_CLASS_T_DEC template<typename HT_Map>
template<typename HT_Map> #define PB_DS_CLASS_C_DEC PB_DS_CKDED_CLASS_NAME<HT_Map>
#define PB_DS_CLASS_C_DEC \
PB_DS_CKDED_CLASS_NAME< \
HT_Map>
/** /**
* A conditional key destructor, used for exception handling. * A conditional key destructor, used for exception handling.
@ -64,12 +60,9 @@ namespace pb_ds
{ {
public: public:
typedef typename HT_Map::entry entry; typedef typename HT_Map::entry entry;
typedef typename HT_Map::entry_allocator entry_allocator; typedef typename HT_Map::entry_allocator entry_allocator;
typedef typename HT_Map::key_type key_type; typedef typename HT_Map::key_type key_type;
public:
inline inline
PB_DS_CKDED_CLASS_NAME(entry_allocator* p_a, entry* p_e); PB_DS_CKDED_CLASS_NAME(entry_allocator* p_a, entry* p_e);
@ -93,10 +86,8 @@ namespace pb_ds
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline inline
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_CKDED_CLASS_NAME(entry_allocator* p_a, entry* p_e) : PB_DS_CKDED_CLASS_NAME(entry_allocator* p_a, entry* p_e)
m_p_a(p_a), : m_p_a(p_a), m_p_e(p_e), m_key_destruct(false),
m_p_e(p_e),
m_key_destruct(false),
m_no_action_destructor(false) m_no_action_destructor(false)
{ } { }
@ -104,17 +95,13 @@ namespace pb_ds
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
set_key_destruct() set_key_destruct()
{ { m_key_destruct = true; }
m_key_destruct = true;
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
set_no_action_destructor() set_no_action_destructor()
{ { m_no_action_destructor = true; }
m_no_action_destructor = true;
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline inline
@ -123,10 +110,8 @@ namespace pb_ds
{ {
if (m_no_action_destructor) if (m_no_action_destructor)
return; return;
if (m_key_destruct) if (m_key_destruct)
m_p_e->m_value.first.~key_type(); m_p_e->m_value.first.~key_type();
m_p_a->deallocate(m_p_e, 1); m_p_a->deallocate(m_p_e, 1);
} }

View File

@ -143,7 +143,7 @@ PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC& other) :
{ {
copy_from_range(other.begin(), other.end()); copy_from_range(other.begin(), other.end());
} }
catch (...) catch(...)
{ {
deallocate_all(); deallocate_all();
throw; throw;

View File

@ -51,11 +51,10 @@ PB_DS_CLASS_C_DEC::
constructor_insert_new_imp(const_mapped_reference r_val, size_type pos, integral_constant<int,false>) constructor_insert_new_imp(const_mapped_reference r_val, size_type pos, integral_constant<int,false>)
{ {
// Following lines might throw an exception. // Following lines might throw an exception.
entry_pointer p_e = get_entry(r_val, traits_base::s_no_throw_copies_indicator); entry_pointer p = get_entry(r_val, traits_base::s_no_throw_copies_indicator);
// At this point no exceptions can be thrown. // At this point no exceptions can be thrown.
p->m_p_next = m_entries[pos];
p_e->m_p_next = m_entries[pos]; m_entries[pos] = p;
m_entries[pos] = p_e;
_GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new(r_key);)
} }

View File

@ -51,13 +51,12 @@ PB_DS_CLASS_C_DEC::
constructor_insert_new_imp(const_reference r_val, size_type pos, true_type) constructor_insert_new_imp(const_reference r_val, size_type pos, true_type)
{ {
// Following lines might throw an exception. // Following lines might throw an exception.
entry_pointer p_e = get_entry(r_val, entry_pointer p = get_entry(r_val, traits_base::s_no_throw_copies_indicator);
traits_base::s_no_throw_copies_indicator);
// At this point no exceptions can be thrown. // At this point no exceptions can be thrown.
p_e->m_p_next = m_entries[pos]; p->m_p_next = m_entries[pos];
p_e->m_hash = ranged_hash_fn_base::operator()((const_key_reference)(PB_DS_V2F(p_e->m_value))).second; p->m_hash = ranged_hash_fn_base::operator()((const_key_reference)(PB_DS_V2F(p->m_value))).second;
m_entries[pos] = p_e; m_entries[pos] = p;
_GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new(r_key);)
} }

View File

@ -49,8 +49,7 @@
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
assert_entry_pointer_valid(const entry_pointer p_e, assert_entry_pointer_valid(const entry_pointer p, store_hash_false_type) const
store_hash_false_type) const { map_debug_base::check_key_exists(PB_DS_V2F(p->m_value)); }
{ map_debug_base::check_key_exists(PB_DS_V2F(p_e->m_value)); }
#endif #endif

View File

@ -49,11 +49,10 @@
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
assert_entry_pointer_valid(const entry_pointer p_e, store_hash_true_type) const assert_entry_pointer_valid(const entry_pointer p_e, store_hash_true_type) const
{ {
map_debug_base::check_key_exists(PB_DS_V2F(p_e->m_value)); map_debug_base::check_key_exists(PB_DS_V2F(p_e->m_value));
comp_hash pos_hash_pair = ranged_hash_fn_base::operator()(PB_DS_V2F(p_e->m_value)); comp_hash pos_hash_pair = ranged_hash_fn_base::operator()(PB_DS_V2F(p_e->m_value));
_GLIBCXX_DEBUG_ASSERT(p_e->m_hash == pos_hash_pair.second); _GLIBCXX_DEBUG_ASSERT(p_e->m_hash == pos_hash_pair.second);
} }

View File

@ -52,9 +52,7 @@ deallocate_links_in_list(entry_pointer p_e)
while (p_e != NULL) while (p_e != NULL)
{ {
entry_pointer p_dealloc_e = p_e; entry_pointer p_dealloc_e = p_e;
p_e = p_e->m_p_next; p_e = p_e->m_p_next;
s_entry_allocator.deallocate(p_dealloc_e, 1); s_entry_allocator.deallocate(p_dealloc_e, 1);
} }
} }
@ -65,14 +63,11 @@ PB_DS_CLASS_C_DEC::
get_entry(const_reference r_val, no_throw_copies_true_type) get_entry(const_reference r_val, no_throw_copies_true_type)
{ {
// Following line might throw an exception. // Following line might throw an exception.
entry_pointer p_e = s_entry_allocator.allocate(1); entry_pointer p_e = s_entry_allocator.allocate(1);
// Following lines* cannot* throw an exception. // Following lines* cannot* throw an exception.
new (&p_e->m_value) value_type(r_val); new (&p_e->m_value) value_type(r_val);
return p_e;
return (p_e);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -81,18 +76,13 @@ PB_DS_CLASS_C_DEC::
get_entry(const_reference r_val, no_throw_copies_false_type) get_entry(const_reference r_val, no_throw_copies_false_type)
{ {
// Following line might throw an exception. // Following line might throw an exception.
entry_pointer p_e = s_entry_allocator.allocate(1); entry_pointer p_e = s_entry_allocator.allocate(1);
cond_dealtor_t cond(p_e); cond_dealtor_t cond(p_e);
// Following lines might throw an exception. // Following lines might throw an exception.
new (&p_e->m_value) value_type(r_val); new (&p_e->m_value) value_type(r_val);
cond.set_no_action(); cond.set_no_action();
return p_e;
return (p_e);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -100,11 +90,8 @@ inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
rels_entry(entry_pointer p_e) rels_entry(entry_pointer p_e)
{ {
/* The following lines cannot throw exceptions // The following lines cannot throw exceptions (unless if key-data dtors do).
* (unless if key-data dtors do). */
p_e->m_value.~value_type(); p_e->m_value.~value_type();
s_entry_allocator.deallocate(p_e, 1); s_entry_allocator.deallocate(p_e, 1);
} }

View File

@ -49,15 +49,11 @@ inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
erase_entry_pointer(entry_pointer& r_p_e) erase_entry_pointer(entry_pointer& r_p_e)
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::erase_existing( _GLIBCXX_DEBUG_ONLY(map_debug_base::erase_existing(PB_DS_V2F(r_p_e->m_value)));
PB_DS_V2F(r_p_e->m_value)));
entry_pointer p_e = r_p_e; entry_pointer p_e = r_p_e;
r_p_e = r_p_e->m_p_next; r_p_e = r_p_e->m_p_next;
rels_entry(p_e); rels_entry(p_e);
_GLIBCXX_DEBUG_ASSERT(m_num_used_e > 0); _GLIBCXX_DEBUG_ASSERT(m_num_used_e > 0);
resize_base::notify_erased(--m_num_used_e); resize_base::notify_erased(--m_num_used_e);
} }
@ -68,34 +64,24 @@ inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
erase_if(Pred pred) erase_if(Pred pred)
{ {
typedef typename PB_DS_TYPES_TRAITS_C_DEC::const_reference const_reference;
size_type num_ersd = 0; size_type num_ersd = 0;
for (size_type pos = 0; pos < m_num_e; ++pos) for (size_type pos = 0; pos < m_num_e; ++pos)
{ {
typedef while (m_entries[pos] != NULL && pred(m_entries[pos]->m_value))
typename PB_DS_TYPES_TRAITS_C_DEC::const_reference
const_reference;
while (m_entries[pos] != NULL&&
pred(m_entries[pos]->m_value))
{ {
++num_ersd; ++num_ersd;
entry_pointer p_next_e = m_entries[pos]->m_p_next; entry_pointer p_next_e = m_entries[pos]->m_p_next;
erase_entry_pointer(m_entries[pos]); erase_entry_pointer(m_entries[pos]);
m_entries[pos] = p_next_e; m_entries[pos] = p_next_e;
} }
entry_pointer p_e = m_entries[pos]; entry_pointer p_e = m_entries[pos];
while (p_e != NULL && p_e->m_p_next != NULL)
while (p_e != NULL&& p_e->m_p_next != NULL)
{ {
if (pred(p_e->m_p_next->m_value)) if (pred(p_e->m_p_next->m_value))
{ {
++num_ersd; ++num_ersd;
erase_entry_pointer(p_e->m_p_next); erase_entry_pointer(p_e->m_p_next);
} }
else else
@ -104,8 +90,7 @@ erase_if(Pred pred)
} }
do_resize_if_needed_no_throw(); do_resize_if_needed_no_throw();
return num_ersd;
return (num_ersd);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -116,9 +101,7 @@ clear()
for (size_type pos = 0; pos < m_num_e; ++pos) for (size_type pos = 0; pos < m_num_e; ++pos)
while (m_entries[pos] != NULL) while (m_entries[pos] != NULL)
erase_entry_pointer(m_entries[pos]); erase_entry_pointer(m_entries[pos]);
do_resize_if_needed_no_throw(); do_resize_if_needed_no_throw();
resize_base::notify_cleared(); resize_base::notify_cleared();
} }

View File

@ -41,8 +41,8 @@
/** /**
* @file erase_no_store_hash_fn_imps.hpp * @file erase_no_store_hash_fn_imps.hpp
* Contains implementations of cc_ht_map_'s erase related functions, when the hash * Contains implementations of cc_ht_map_'s erase related functions,
* value is not stored. * when the hash value is not stored.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -51,9 +51,7 @@ PB_DS_CLASS_C_DEC::
erase(const_key_reference r_key) erase(const_key_reference r_key)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return erase_in_pos_imp(r_key, ranged_hash_fn_base::operator()(r_key));
return (erase_in_pos_imp(r_key,
ranged_hash_fn_base::operator()(r_key)));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -62,77 +60,47 @@ PB_DS_CLASS_C_DEC::
erase_in_pos_imp(const_key_reference r_key, size_type pos) erase_in_pos_imp(const_key_reference r_key, size_type pos)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
entry_pointer p_e = m_entries[pos];
entry_pointer p_e = m_entries[pos];
resize_base::notify_erase_search_start(); resize_base::notify_erase_search_start();
if (p_e == NULL) if (p_e == NULL)
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist( _GLIBCXX_DEBUG_ONLY(assert_valid();)
r_key);) return false;
_GLIBCXX_DEBUG_ONLY(assert_valid();)
return (false);
} }
if (hash_eq_fn_base::operator()( if (hash_eq_fn_base::operator()(PB_DS_V2F(p_e->m_value), r_key))
PB_DS_V2F(p_e->m_value),
r_key))
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base:: check_key_exists(r_key);)
_GLIBCXX_DEBUG_ONLY(map_debug_base:: erase_entry_pointer(m_entries[pos]);
check_key_exists(r_key);)
erase_entry_pointer(m_entries[pos]);
do_resize_if_needed_no_throw(); do_resize_if_needed_no_throw();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return true;
return (true);
} }
while (true) while (true)
{ {
entry_pointer p_next_e = p_e->m_p_next; entry_pointer p_next_e = p_e->m_p_next;
if (p_next_e == NULL) if (p_next_e == NULL)
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
_GLIBCXX_DEBUG_ONLY(map_debug_base:: _GLIBCXX_DEBUG_ONLY(assert_valid();)
check_key_does_not_exist(r_key);) return false;
_GLIBCXX_DEBUG_ONLY(assert_valid();)
return (false);
} }
if (hash_eq_fn_base::operator()( if (hash_eq_fn_base::operator()(PB_DS_V2F(p_next_e->m_value), r_key))
PB_DS_V2F(p_next_e->m_value),
r_key))
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);)
_GLIBCXX_DEBUG_ONLY(map_debug_base:: erase_entry_pointer(p_e->m_p_next);
check_key_exists(r_key);)
erase_entry_pointer(p_e->m_p_next);
do_resize_if_needed_no_throw(); do_resize_if_needed_no_throw();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return true;
return (true);
} }
resize_base::notify_erase_search_collision(); resize_base::notify_erase_search_collision();
p_e = p_next_e; p_e = p_next_e;
} }
} }

View File

@ -41,8 +41,8 @@
/** /**
* @file erase_store_hash_fn_imps.hpp * @file erase_store_hash_fn_imps.hpp
* Contains implementations of cc_ht_map_'s erase related functions, when the hash * Contains implementations of cc_ht_map_'s erase related functions,
* value is stored. * when the hash value is stored.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -51,83 +51,50 @@ PB_DS_CLASS_C_DEC::
erase_in_pos_imp(const_key_reference r_key, const comp_hash& r_pos_hash_pair) erase_in_pos_imp(const_key_reference r_key, const comp_hash& r_pos_hash_pair)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
entry_pointer p_e = m_entries[r_pos_hash_pair.first];
entry_pointer p_e = m_entries[r_pos_hash_pair.first];
resize_base::notify_erase_search_start(); resize_base::notify_erase_search_start();
if (p_e == NULL) if (p_e == NULL)
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base:: check_key_does_not_exist(r_key);)
_GLIBCXX_DEBUG_ONLY(map_debug_base:: _GLIBCXX_DEBUG_ONLY(assert_valid();)
check_key_does_not_exist( return false;
r_key);)
_GLIBCXX_DEBUG_ONLY(assert_valid();)
return (false);
} }
if (hash_eq_fn_base::operator()( if (hash_eq_fn_base::operator()(PB_DS_V2F(p_e->m_value), p_e->m_hash,
PB_DS_V2F(p_e->m_value), r_key, r_pos_hash_pair.second))
p_e->m_hash,
r_key,
r_pos_hash_pair.second))
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);)
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists( erase_entry_pointer(m_entries[r_pos_hash_pair.first]);
r_key);)
erase_entry_pointer(m_entries[r_pos_hash_pair.first]);
do_resize_if_needed_no_throw(); do_resize_if_needed_no_throw();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return true;
return (true);
} }
while (true) while (true)
{ {
entry_pointer p_next_e = p_e->m_p_next; entry_pointer p_next_e = p_e->m_p_next;
if (p_next_e == NULL) if (p_next_e == NULL)
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
_GLIBCXX_DEBUG_ONLY(map_debug_base:: _GLIBCXX_DEBUG_ONLY(assert_valid();)
check_key_does_not_exist(r_key);) return false;
_GLIBCXX_DEBUG_ONLY(assert_valid();)
return (false);
} }
if (hash_eq_fn_base::operator()( if (hash_eq_fn_base::operator()(PB_DS_V2F(p_next_e->m_value),
PB_DS_V2F(p_next_e->m_value), p_next_e->m_hash, r_key,
p_next_e->m_hash,
r_key,
r_pos_hash_pair.second)) r_pos_hash_pair.second))
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);)
_GLIBCXX_DEBUG_ONLY(map_debug_base:: erase_entry_pointer(p_e->m_p_next);
check_key_exists(
r_key);)
erase_entry_pointer(p_e->m_p_next);
do_resize_if_needed_no_throw(); do_resize_if_needed_no_throw();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return true;
return (true);
} }
resize_base::notify_erase_search_collision(); resize_base::notify_erase_search_collision();
p_e = p_next_e; p_e = p_next_e;
} }
} }

View File

@ -50,8 +50,7 @@ PB_DS_CLASS_C_DEC::
find(const_key_reference r_key) find(const_key_reference r_key)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return find_key_pointer(r_key, traits_base::m_store_extra_indicator);
return (find_key_pointer(r_key, traits_base::m_store_extra_indicator));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -60,23 +59,19 @@ PB_DS_CLASS_C_DEC::
find(const_key_reference r_key) const find(const_key_reference r_key) const
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return const_cast<PB_DS_CLASS_C_DEC& >(*this).find_key_pointer(r_key,
return (const_cast<PB_DS_CLASS_C_DEC& >(*this).find_key_pointer( r_key, traits_base::m_store_extra_indicator)); traits_base::m_store_extra_indicator);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::point_iterator inline typename PB_DS_CLASS_C_DEC::point_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
find_end() find_end()
{ { return NULL; }
return (NULL);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_point_iterator inline typename PB_DS_CLASS_C_DEC::const_point_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
find_end() const find_end() const
{ { return NULL; }
return (NULL);
}

View File

@ -41,7 +41,7 @@
/** /**
* @file find_store_hash_fn_imps.hpp * @file find_store_hash_fn_imps.hpp
* Contains implementations of cc_ht_map_'s find related functions, when the hash * Contains implementations of cc_ht_map_'s find related functions,
* value is stored. * when the hash value is stored.
*/ */

View File

@ -42,41 +42,33 @@
/** /**
* @file info_fn_imps.hpp * @file info_fn_imps.hpp
* Contains implementations of cc_ht_map_'s entire container info related * Contains implementations of cc_ht_map_'s entire container info related
* functions. * functions.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
size() const size() const
{ { return m_num_used_e; }
return (m_num_used_e);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
max_size() const max_size() const
{ { return m_entry_allocator.max_size(); }
return (m_entry_allocator.max_size());
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline bool inline bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
empty() const empty() const
{ { return (size() == 0); }
return (size() == 0);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
template<typename Other_HT_Map_Type> template<typename Other_HT_Map_Type>
bool bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
operator==(const Other_HT_Map_Type& other) const operator==(const Other_HT_Map_Type& other) const
{ { return cmp_with_other(other); }
return (cmp_with_other(other));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
template<typename Other_Map_Type> template<typename Other_Map_Type>
@ -85,27 +77,25 @@ PB_DS_CLASS_C_DEC::
cmp_with_other(const Other_Map_Type& other) const cmp_with_other(const Other_Map_Type& other) const
{ {
if (size() != other.size()) if (size() != other.size())
return (false); return false;
for (typename Other_Map_Type::const_iterator it = other.begin(); for (typename Other_Map_Type::const_iterator it = other.begin();
it != other.end(); ++it) it != other.end(); ++it)
{ {
const_key_reference r_key =(const_key_reference)PB_DS_V2F(*it); const_key_reference r_key =(const_key_reference)PB_DS_V2F(*it);
const_mapped_pointer p_mapped_value = const_mapped_pointer p_mapped_value =
const_cast<PB_DS_CLASS_C_DEC& >(*this). const_cast<PB_DS_CLASS_C_DEC& >(*this).
find_key_pointer(r_key, traits_base::m_store_hash_indicator); find_key_pointer(r_key, traits_base::m_store_hash_indicator);
if (p_mapped_value == NULL) if (p_mapped_value == NULL)
return (false); return false;
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
if (p_mapped_value->second != it->second) if (p_mapped_value->second != it->second)
return (false); return false;
#endif // #ifdef PB_DS_DATA_TRUE_INDICATOR #endif
} }
return true;
return (true);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -113,6 +103,4 @@ template<typename Other_HT_Map_Type>
bool bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
operator!=(const Other_HT_Map_Type& other) const operator!=(const Other_HT_Map_Type& other) const
{ { return !operator==(other); }
return (!operator==(other));
}

View File

@ -41,49 +41,36 @@
/** /**
* @file insert_no_store_hash_fn_imps.hpp * @file insert_no_store_hash_fn_imps.hpp
* Contains implementations of cc_ht_map_'s insert related functions, when the hash * Contains implementations of cc_ht_map_'s insert related functions,
* value is not stored. * when the hash value is not stored.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline std::pair< inline std::pair<typename PB_DS_CLASS_C_DEC::point_iterator, bool>
typename PB_DS_CLASS_C_DEC::point_iterator,
bool>
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
insert_imp(const_reference r_val, store_hash_false_type) insert_imp(const_reference r_val, store_hash_false_type)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
const_key_reference r_key = PB_DS_V2F(r_val);
const_key_reference r_key = PB_DS_V2F(r_val);
const size_type pos = ranged_hash_fn_base::operator()(r_key); const size_type pos = ranged_hash_fn_base::operator()(r_key);
entry_pointer p_e = m_entries[pos]; entry_pointer p_e = m_entries[pos];
resize_base::notify_insert_search_start(); resize_base::notify_insert_search_start();
while (p_e != NULL&& while (p_e != NULL && !hash_eq_fn_base::operator()(PB_DS_V2F(p_e->m_value),
!hash_eq_fn_base::operator()(PB_DS_V2F(p_e->m_value), r_key)) r_key))
{ {
resize_base::notify_insert_search_collision(); resize_base::notify_insert_search_collision();
p_e = p_e->m_p_next; p_e = p_e->m_p_next;
} }
resize_base::notify_insert_search_end(); resize_base::notify_insert_search_end();
if (p_e != NULL) if (p_e != NULL)
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);)
return std::make_pair(&p_e->m_value, false);
return (
std::make_pair( & p_e->m_value, false));
} }
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
return std::make_pair(insert_new_imp(r_val, pos), true);
return (std::make_pair(
insert_new_imp(r_val, pos),
true));
} }

View File

@ -41,51 +41,37 @@
/** /**
* @file insert_store_hash_fn_imps.hpp * @file insert_store_hash_fn_imps.hpp
* Contains implementations of cc_ht_map_'s insert related functions, when the hash * Contains implementations of cc_ht_map_'s insert related functions,
* value is stored. * when the hash value is stored.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline std::pair< inline std::pair<typename PB_DS_CLASS_C_DEC::point_iterator, bool>
typename PB_DS_CLASS_C_DEC::point_iterator,
bool>
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
insert_imp(const_reference r_val, store_hash_true_type) insert_imp(const_reference r_val, store_hash_true_type)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
const_key_reference key = PB_DS_V2F(r_val);
const_key_reference r_key = PB_DS_V2F(r_val); comp_hash pos_hash_pair = ranged_hash_fn_base::operator()(key);
comp_hash pos_hash_pair = ranged_hash_fn_base::operator()(r_key);
entry_pointer p_e = m_entries[pos_hash_pair.first]; entry_pointer p_e = m_entries[pos_hash_pair.first];
resize_base::notify_insert_search_start(); resize_base::notify_insert_search_start();
while (p_e != NULL&& while (p_e != NULL && !hash_eq_fn_base::operator()(PB_DS_V2F(p_e->m_value),
!hash_eq_fn_base::operator()( p_e->m_hash,
PB_DS_V2F(p_e->m_value), key, pos_hash_pair.second))
p_e->m_hash,
r_key, pos_hash_pair.second))
{ {
resize_base::notify_insert_search_collision(); resize_base::notify_insert_search_collision();
p_e = p_e->m_p_next; p_e = p_e->m_p_next;
} }
resize_base::notify_insert_search_end(); resize_base::notify_insert_search_end();
if (p_e != NULL) if (p_e != NULL)
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(key);)
return std::make_pair(&p_e->m_value, false);
return (std::make_pair( & p_e->m_value, false));
} }
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(key);)
return std::make_pair(insert_new_imp(r_val, pos_hash_pair), true);
return (std::make_pair(
insert_new_imp(r_val, pos_hash_pair),
true));
} }

View File

@ -42,7 +42,7 @@
/** /**
* @file iterators_fn_imps.hpp * @file iterators_fn_imps.hpp
* Contains implementations of cc_ht_map_'s iterators related functions, e.g., * Contains implementations of cc_ht_map_'s iterators related functions, e.g.,
* begin(). * begin().
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -60,19 +60,15 @@ begin()
{ {
pointer p_value; pointer p_value;
std::pair<entry_pointer, size_type> pos; std::pair<entry_pointer, size_type> pos;
get_start_it_state(p_value, pos); get_start_it_state(p_value, pos);
return iterator(p_value, pos, this);
return (iterator(p_value, pos, this));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::iterator inline typename PB_DS_CLASS_C_DEC::iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
end() end()
{ { return s_end_it; }
return (s_end_it);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_iterator inline typename PB_DS_CLASS_C_DEC::const_iterator
@ -81,17 +77,13 @@ begin() const
{ {
pointer p_value; pointer p_value;
std::pair<entry_pointer, size_type> pos; std::pair<entry_pointer, size_type> pos;
get_start_it_state(p_value, pos); get_start_it_state(p_value, pos);
return const_iterator(p_value, pos, this);
return (const_iterator(p_value, pos, this));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_iterator inline typename PB_DS_CLASS_C_DEC::const_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
end() const end() const
{ { return s_const_end_it; }
return (s_const_end_it);
}

View File

@ -49,62 +49,46 @@ PB_DS_CLASS_T_DEC
Hash_Fn& Hash_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_hash_fn() get_hash_fn()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const Hash_Fn& const Hash_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_hash_fn() const get_hash_fn() const
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
Eq_Fn& Eq_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_eq_fn() get_eq_fn()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const Eq_Fn& const Eq_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_eq_fn() const get_eq_fn() const
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
Comb_Hash_Fn& Comb_Hash_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_comb_hash_fn() get_comb_hash_fn()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const Comb_Hash_Fn& const Comb_Hash_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_comb_hash_fn() const get_comb_hash_fn() const
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
Resize_Policy& Resize_Policy&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_resize_policy() get_resize_policy()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const Resize_Policy& const Resize_Policy&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_resize_policy() const get_resize_policy() const
{ { return *this; }
return (*this);
}

View File

@ -50,21 +50,16 @@ PB_DS_CLASS_C_DEC::
do_resize_if_needed() do_resize_if_needed()
{ {
if (!resize_base::is_resize_needed()) if (!resize_base::is_resize_needed())
return (false); return false;
resize_imp(resize_base::get_new_size(m_num_e, m_num_used_e));
resize_imp(resize_base::get_new_size( m_num_e, m_num_used_e)); return true;
return (true);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
do_resize(size_type size) do_resize(size_type size)
{ { resize_imp(resize_base::get_nearest_larger_size(size)); }
resize_imp(resize_base::get_nearest_larger_size(
size));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
@ -76,13 +71,13 @@ do_resize_if_needed_no_throw()
try try
{ {
resize_imp(resize_base::get_new_size( m_num_e, m_num_used_e)); resize_imp(resize_base::get_new_size(m_num_e, m_num_used_e));
} }
catch(...) catch(...)
{ } { }
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
@ -90,67 +85,54 @@ PB_DS_CLASS_C_DEC::
resize_imp(size_type new_size) resize_imp(size_type new_size)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
if (new_size == m_num_e)
if (new_size == m_num_e) return;
return;
const size_type old_size = m_num_e; const size_type old_size = m_num_e;
entry_pointer_array a_p_entries_resized; entry_pointer_array a_p_entries_resized;
// Following line might throw an exception. // Following line might throw an exception.
ranged_hash_fn_base::notify_resized(new_size); ranged_hash_fn_base::notify_resized(new_size);
try try
{ {
// Following line might throw an exception. // Following line might throw an exception.
a_p_entries_resized = s_entry_pointer_allocator.allocate(new_size); a_p_entries_resized = s_entry_pointer_allocator.allocate(new_size);
m_num_e = new_size; m_num_e = new_size;
} }
catch(...) catch(...)
{ {
ranged_hash_fn_base::notify_resized(old_size); ranged_hash_fn_base::notify_resized(old_size);
throw; throw;
} }
// At this point no exceptions can be thrown. // At this point no exceptions can be thrown.
resize_imp_no_exceptions(new_size, a_p_entries_resized, old_size); resize_imp_no_exceptions(new_size, a_p_entries_resized, old_size);
Resize_Policy::notify_resized(new_size); Resize_Policy::notify_resized(new_size);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
resize_imp_no_exceptions(size_type new_size, entry_pointer_array a_p_entries_resized, size_type old_size) resize_imp_no_exceptions(size_type new_size, entry_pointer_array a_p_entries_resized, size_type old_size)
{ {
std::fill(a_p_entries_resized, a_p_entries_resized + m_num_e,(entry_pointer)NULL); std::fill(a_p_entries_resized, a_p_entries_resized + m_num_e,
entry_pointer(NULL));
for (size_type pos = 0; pos < old_size; ++pos) for (size_type pos = 0; pos < old_size; ++pos)
{ {
entry_pointer p_e = m_entries[pos]; entry_pointer p_e = m_entries[pos];
while (p_e != NULL) while (p_e != NULL)
p_e = resize_imp_no_exceptions_reassign_pointer(p_e, a_p_entries_resized, traits_base::m_store_extra_indicator); p_e = resize_imp_no_exceptions_reassign_pointer(p_e, a_p_entries_resized, traits_base::m_store_extra_indicator);
} }
m_num_e = new_size; m_num_e = new_size;
_GLIBCXX_DEBUG_ONLY(assert_entry_pointer_array_valid(a_p_entries_resized);) _GLIBCXX_DEBUG_ONLY(assert_entry_pointer_array_valid(a_p_entries_resized);)
s_entry_pointer_allocator.deallocate(m_entries, old_size);
s_entry_pointer_allocator.deallocate(m_entries, old_size);
m_entries = a_p_entries_resized; m_entries = a_p_entries_resized;
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
#include <ext/pb_ds/detail/cc_hash_table_map_/resize_no_store_hash_fn_imps.hpp> #include <ext/pb_ds/detail/cc_hash_table_map_/resize_no_store_hash_fn_imps.hpp>
#include <ext/pb_ds/detail/cc_hash_table_map_/resize_store_hash_fn_imps.hpp> #include <ext/pb_ds/detail/cc_hash_table_map_/resize_store_hash_fn_imps.hpp>

View File

@ -54,10 +54,7 @@ resize_imp_no_exceptions_reassign_pointer(entry_pointer p_e, entry_pointer_array
ranged_hash_fn_base::operator()(PB_DS_V2F(p_e->m_value)); ranged_hash_fn_base::operator()(PB_DS_V2F(p_e->m_value));
entry_pointer const p_next_e = p_e->m_p_next; entry_pointer const p_next_e = p_e->m_p_next;
p_e->m_p_next = a_p_entries_resized[hash_pos]; p_e->m_p_next = a_p_entries_resized[hash_pos];
a_p_entries_resized[hash_pos] = p_e; a_p_entries_resized[hash_pos] = p_e;
return p_next_e;
return (p_next_e);
} }

View File

@ -51,15 +51,10 @@ PB_DS_CLASS_C_DEC::
resize_imp_no_exceptions_reassign_pointer(entry_pointer p_e, entry_pointer_array a_p_entries_resized, store_hash_true_type) resize_imp_no_exceptions_reassign_pointer(entry_pointer p_e, entry_pointer_array a_p_entries_resized, store_hash_true_type)
{ {
const comp_hash pos_hash_pair = const comp_hash pos_hash_pair =
ranged_hash_fn_base::operator()( ranged_hash_fn_base::operator()(PB_DS_V2F(p_e->m_value), p_e->m_hash);
PB_DS_V2F(p_e->m_value),
p_e->m_hash);
entry_pointer const p_next_e = p_e->m_p_next; entry_pointer const p_next_e = p_e->m_p_next;
p_e->m_p_next = a_p_entries_resized[pos_hash_pair.first]; p_e->m_p_next = a_p_entries_resized[pos_hash_pair.first];
a_p_entries_resized[pos_hash_pair.first] = p_e; a_p_entries_resized[pos_hash_pair.first] = p_e;
return p_next_e;
return (p_next_e);
} }

View File

@ -49,23 +49,17 @@ PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
size() const size() const
{ { return m_num_used_e; }
return (m_num_used_e);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline bool inline bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
empty() const empty() const
{ { return (size() == 0); }
return (size() == 0);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
max_size() const max_size() const
{ { return s_entry_allocator.max_size(); }
return (s_entry_allocator.max_size());
}

View File

@ -51,15 +51,13 @@ void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
trace() const trace() const
{ {
std::cerr << static_cast<unsigned long>(m_num_e) << " " << std::cerr << static_cast<unsigned long>(m_num_e) << " "
static_cast<unsigned long>(m_num_used_e) << std::endl; << static_cast<unsigned long>(m_num_used_e) << std::endl;
for (size_type i = 0; i < m_num_e; ++i) for (size_type i = 0; i < m_num_e; ++i)
{ {
std::cerr << static_cast<unsigned long>(i) << " "; std::cerr << static_cast<unsigned long>(i) << " ";
trace_list(m_entries[i]); trace_list(m_entries[i]);
std::cerr << std::endl; std::cerr << std::endl;
} }
} }
@ -70,13 +68,11 @@ PB_DS_CLASS_C_DEC::
trace_list(const_entry_pointer p_l) const trace_list(const_entry_pointer p_l) const
{ {
size_type iterated_num_used_e = 0; size_type iterated_num_used_e = 0;
while (p_l != NULL) while (p_l != NULL)
{ {
std::cerr << PB_DS_V2F(p_l->m_value) << " "; std::cerr << PB_DS_V2F(p_l->m_value) << " ";
p_l = p_l->m_p_next; p_l = p_l->m_p_next;
} }
} }
#endif // #ifdef PB_DS_HT_MAP_TRACE_ #endif

View File

@ -161,7 +161,7 @@ PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC& other) :
new (m_entries + i) entry(other.m_entries[i]); new (m_entries + i) entry(other.m_entries[i]);
} }
} }
catch (...) catch(...)
{ {
deallocate_all(); deallocate_all();
throw; throw;

View File

@ -48,16 +48,12 @@
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
constructor_insert_new_imp(const_mapped_reference r_val, size_type pos, integral_constant<int,false>) constructor_insert_new_imp(const_mapped_reference r_val, size_type pos,
false_type)
{ {
_GLIBCXX_DEBUG_ASSERT(m_entries[pos].m_stat != valid_entry_status); _GLIBCXX_DEBUG_ASSERT(m_entries[pos].m_stat != valid_entry_status)k;
entry* const p_e = m_entries + pos; entry* const p_e = m_entries + pos;
new (&p_e->m_value) mapped_value_type(r_val); new (&p_e->m_value) mapped_value_type(r_val);
p_e->m_stat = valid_entry_status; p_e->m_stat = valid_entry_status;
_GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new(p_e->m_value.first);)
_GLIBCXX_DEBUG_ONLY(map_debug_base:: }
insert_new(p_e->m_value.first);)
}

View File

@ -42,25 +42,19 @@
/** /**
* @file constructor_destructor_store_hash_fn_imps.hpp * @file constructor_destructor_store_hash_fn_imps.hpp
* Contains implementations of gp_ht_map_'s constructors, destructor, * Contains implementations of gp_ht_map_'s constructors, destructor,
* and related functions. * and related functions.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
constructor_insert_new_imp(const_mapped_reference r_val, size_type pos, true_type) constructor_insert_new_imp(const_mapped_reference r_val, size_type pos,
true_type)
{ {
_GLIBCXX_DEBUG_ASSERT(m_entries[pos].m_stat != valid_entry_status); _GLIBCXX_DEBUG_ASSERT(m_entries[pos].m_stat != valid_entry_status);
entry* const p_e = m_entries + pos; entry* const p_e = m_entries + pos;
new (&p_e->m_value) mapped_value_type(r_val); new (&p_e->m_value) mapped_value_type(r_val);
p_e->m_hash = ranged_probe_fn_base::operator()(PB_DS_V2F(r_val)).second;
p_e->m_hash = ranged_probe_fn_base::operator()(
PB_DS_V2F(r_val)).second;
p_e->m_stat = valid_entry_status; p_e->m_stat = valid_entry_status;
_GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new(p_e->m_value.first);)
_GLIBCXX_DEBUG_ONLY(map_debug_base:: }
insert_new(p_e->m_value.first);)
}

View File

@ -52,11 +52,9 @@ PB_DS_CLASS_C_DEC::
assert_entry_array_valid(const entry_array a_entries, store_hash_false_type) const assert_entry_array_valid(const entry_array a_entries, store_hash_false_type) const
{ {
size_type iterated_num_used_e = 0; size_type iterated_num_used_e = 0;
for (size_type pos = 0; pos < m_num_e; ++pos) for (size_type pos = 0; pos < m_num_e; ++pos)
{ {
const_entry_pointer p_e =& a_entries[pos]; const_entry_pointer p_e = &a_entries[pos];
switch(p_e->m_stat) switch(p_e->m_stat)
{ {
case empty_entry_status: case empty_entry_status:
@ -64,20 +62,15 @@ assert_entry_array_valid(const entry_array a_entries, store_hash_false_type) con
break; break;
case valid_entry_status: case valid_entry_status:
{ {
const_key_reference r_key = const_key_reference r_key = PB_DS_V2F(p_e->m_value);
PB_DS_V2F(p_e->m_value);
map_debug_base::check_key_exists(r_key); map_debug_base::check_key_exists(r_key);
++iterated_num_used_e; ++iterated_num_used_e;
break; break;
} }
default: default:
_GLIBCXX_DEBUG_ASSERT(0); _GLIBCXX_DEBUG_ASSERT(0);
}; };
} }
_GLIBCXX_DEBUG_ASSERT(iterated_num_used_e == m_num_used_e); _GLIBCXX_DEBUG_ASSERT(iterated_num_used_e == m_num_used_e);
} }

View File

@ -41,8 +41,8 @@
/** /**
* @file erase_no_store_hash_fn_imps.hpp * @file erase_no_store_hash_fn_imps.hpp
* Contains implementations of gp_ht_map_'s erase related functions, when the hash * Contains implementations of gp_ht_map_'s erase related functions,
* value is not stored. * when the hash value is not stored.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -51,44 +51,31 @@ PB_DS_CLASS_C_DEC::
erase_imp(const_key_reference r_key, false_type) erase_imp(const_key_reference r_key, false_type)
{ {
_GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::assert_valid();) _GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::assert_valid();)
size_type hash = ranged_probe_fn_base::operator()(r_key);
size_type hash = ranged_probe_fn_base::operator()(r_key);
size_type i; size_type i;
resize_base::notify_erase_search_start(); resize_base::notify_erase_search_start();
for (i = 0; i < m_num_e; ++i) for (i = 0; i < m_num_e; ++i)
{ {
const size_type pos = const size_type pos = ranged_probe_fn_base::operator()(r_key, hash, i);
ranged_probe_fn_base::operator()( r_key, hash, i);
entry* const p_e = m_entries + pos; entry* const p_e = m_entries + pos;
switch(p_e->m_stat) switch(p_e->m_stat)
{ {
case empty_entry_status: case empty_entry_status:
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist( _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(
r_key)); r_key));
return false;
return (false);
} }
break; break;
case valid_entry_status: case valid_entry_status:
if (hash_eq_fn_base::operator()( if (hash_eq_fn_base::operator()(PB_DS_V2F(p_e->m_value), r_key))
PB_DS_V2F(p_e->m_value),
r_key))
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
erase_entry(p_e); erase_entry(p_e);
do_resize_if_needed_no_throw(); do_resize_if_needed_no_throw();
return true;
return (true);
} }
break; break;
case erased_entry_status: case erased_entry_status:
@ -96,12 +83,9 @@ erase_imp(const_key_reference r_key, false_type)
default: default:
_GLIBCXX_DEBUG_ASSERT(0); _GLIBCXX_DEBUG_ASSERT(0);
}; };
resize_base::notify_erase_search_collision(); resize_base::notify_erase_search_collision();
} }
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
return false;
return (false);
} }

View File

@ -41,54 +41,41 @@
/** /**
* @file erase_store_hash_fn_imps.hpp * @file erase_store_hash_fn_imps.hpp
* Contains implementations of gp_ht_map_'s erase related functions, when the hash * Contains implementations of gp_ht_map_'s erase related functions,
* value is stored. * when the hash value is stored.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline bool inline bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
erase_imp(const_key_reference r_key, true_type) erase_imp(const_key_reference r_key, true_type)
{ {
const comp_hash pos_hash_pair = const comp_hash pos_hash_pair = ranged_probe_fn_base::operator()(r_key);
ranged_probe_fn_base::operator()(r_key);
size_type i; size_type i;
resize_base::notify_erase_search_start(); resize_base::notify_erase_search_start();
for (i = 0; i < m_num_e; ++i) for (i = 0; i < m_num_e; ++i)
{ {
const size_type pos = ranged_probe_fn_base::operator()( r_key, pos_hash_pair.second, i); const size_type pos = ranged_probe_fn_base::operator()(r_key, pos_hash_pair.second, i);
entry* const p_e = m_entries + pos; entry* const p_e = m_entries + pos;
switch(p_e->m_stat) switch(p_e->m_stat)
{ {
case empty_entry_status: case empty_entry_status:
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist( _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(
r_key)); r_key));
return false;
return (false);
} }
break; break;
case valid_entry_status: case valid_entry_status:
if (hash_eq_fn_base::operator()( if (hash_eq_fn_base::operator()(PB_DS_V2F(p_e->m_value), p_e->m_hash,
PB_DS_V2F(p_e->m_value), r_key, pos_hash_pair.second))
p_e->m_hash,
r_key,
pos_hash_pair.second))
{ {
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
erase_entry(p_e); erase_entry(p_e);
do_resize_if_needed_no_throw(); do_resize_if_needed_no_throw();
return true;
return (true);
} }
break; break;
case erased_entry_status: case erased_entry_status:
@ -99,9 +86,7 @@ erase_imp(const_key_reference r_key, true_type)
resize_base::notify_erase_search_collision(); resize_base::notify_erase_search_collision();
} }
resize_base::notify_erase_search_end(); resize_base::notify_erase_search_end();
return false;
return (false);
} }

View File

@ -41,8 +41,8 @@
/** /**
* @file find_no_store_hash_fn_imps.hpp * @file find_no_store_hash_fn_imps.hpp
* Contains implementations of gp_ht_map_'s find related functions, when the hash * Contains implementations of gp_ht_map_'s find related functions,
* value is not stored. * when the hash value is not stored.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC

View File

@ -41,6 +41,6 @@
/** /**
* @file find_store_hash_fn_imps.hpp * @file find_store_hash_fn_imps.hpp
* Contains implementations of gp_ht_map_'s insert related functions, when the hash * Contains implementations of gp_ht_map_'s insert related functions,
* value is stored. * when the hash value is stored.
*/ */

View File

@ -457,8 +457,7 @@ namespace pb_ds
const size_type pos = find_ins_pos(key, const size_type pos = find_ins_pos(key,
traits_base::m_store_extra_indicator); traits_base::m_store_extra_indicator);
entry_pointer p_e =& m_entries[pos]; entry_pointer p_e = &m_entries[pos];
if (p_e->m_stat != valid_entry_status) if (p_e->m_stat != valid_entry_status)
return insert_new_imp(value_type(key, mapped_type()), pos)->second; return insert_new_imp(value_type(key, mapped_type()), pos)->second;

View File

@ -49,22 +49,16 @@ PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
size() const size() const
{ { return m_num_used_e; }
return (m_num_used_e);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
max_size() const max_size() const
{ { return s_entry_allocator.max_size(); }
return (s_entry_allocator.max_size());
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline bool inline bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
empty() const empty() const
{ { return (size() == 0); }
return (size() == 0);
}

View File

@ -41,8 +41,8 @@
/** /**
* @file insert_no_store_hash_fn_imps.hpp * @file insert_no_store_hash_fn_imps.hpp
* Contains implementations of gp_ht_map_'s insert related functions, when the hash * Contains implementations of gp_ht_map_'s insert related functions,
* value is not stored. * when the hash value is not stored.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -51,35 +51,25 @@ PB_DS_CLASS_C_DEC::
find_ins_pos(const_key_reference r_key, store_hash_false_type) find_ins_pos(const_key_reference r_key, store_hash_false_type)
{ {
size_type hash = ranged_probe_fn_base::operator()(r_key); size_type hash = ranged_probe_fn_base::operator()(r_key);
size_type i; size_type i;
/* The insertion position is initted to a non-legal value to indicate /* The insertion position is initted to a non-legal value to indicate
* that it has not been initted yet. * that it has not been initted yet.
*/ */
size_type ins_pos = m_num_e; size_type ins_pos = m_num_e;
resize_base::notify_insert_search_start(); resize_base::notify_insert_search_start();
for (i = 0; i < m_num_e; ++i) for (i = 0; i < m_num_e; ++i)
{ {
const size_type pos = const size_type pos = ranged_probe_fn_base::operator()(r_key, hash, i);
ranged_probe_fn_base::operator()(r_key, hash, i);
_GLIBCXX_DEBUG_ASSERT(pos < m_num_e); _GLIBCXX_DEBUG_ASSERT(pos < m_num_e);
entry* const p_e = m_entries + pos; entry* const p_e = m_entries + pos;
switch(p_e->m_stat) switch(p_e->m_stat)
{ {
case empty_entry_status: case empty_entry_status:
{ {
resize_base::notify_insert_search_end(); resize_base::notify_insert_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
_GLIBCXX_DEBUG_ONLY( return (ins_pos == m_num_e) ? pos : ins_pos;
map_debug_base::check_key_does_not_exist(r_key);)
return ((ins_pos == m_num_e)? pos : ins_pos);
} }
break; break;
case erased_entry_status: case erased_entry_status:
@ -87,14 +77,11 @@ find_ins_pos(const_key_reference r_key, store_hash_false_type)
ins_pos = pos; ins_pos = pos;
break; break;
case valid_entry_status: case valid_entry_status:
if (hash_eq_fn_base::operator()( if (hash_eq_fn_base::operator()(PB_DS_V2F(p_e->m_value), r_key))
PB_DS_V2F(p_e->m_value), r_key))
{ {
resize_base::notify_insert_search_end(); resize_base::notify_insert_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);)
return pos;
return (pos);
} }
break; break;
default: default:
@ -103,13 +90,10 @@ find_ins_pos(const_key_reference r_key, store_hash_false_type)
resize_base::notify_insert_search_collision(); resize_base::notify_insert_search_collision();
} }
resize_base::notify_insert_search_end(); resize_base::notify_insert_search_end();
if (ins_pos == m_num_e) if (ins_pos == m_num_e)
throw insert_error(); throw insert_error();
return ins_pos;
return (ins_pos);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -118,23 +102,16 @@ PB_DS_CLASS_C_DEC::
insert_imp(const_reference r_val, store_hash_false_type) insert_imp(const_reference r_val, store_hash_false_type)
{ {
const_key_reference r_key = PB_DS_V2F(r_val); const_key_reference r_key = PB_DS_V2F(r_val);
const size_type pos = find_ins_pos(r_key,
const size_type pos = traits_base::m_store_extra_indicator);
find_ins_pos(r_key, traits_base::m_store_extra_indicator);
if (m_entries[pos].m_stat == valid_entry_status) if (m_entries[pos].m_stat == valid_entry_status)
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);)
return std::make_pair(&(m_entries + pos)->m_value, false);
return (std::make_pair(
& (m_entries + pos)->m_value,
false));
} }
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key)); _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key));
return std::make_pair(insert_new_imp(r_val, pos), true);
return (std::make_pair(
insert_new_imp(r_val, pos),
true));
} }

View File

@ -41,8 +41,8 @@
/** /**
* @file insert_store_hash_fn_imps.hpp * @file insert_store_hash_fn_imps.hpp
* Contains implementations of gp_ht_map_'s find related functions, when the hash * Contains implementations of gp_ht_map_'s find related functions,
* value is stored. * when the hash value is stored.
*/ */
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -70,12 +70,11 @@ find_ins_pos(const_key_reference r_key, store_hash_true_type)
case empty_entry_status: case empty_entry_status:
{ {
resize_base::notify_insert_search_end(); resize_base::notify_insert_search_end();
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
return ((ins_pos == m_num_e) ? return ((ins_pos == m_num_e) ?
std::make_pair(pos, pos_hash_pair.second) : std::make_pair(pos, pos_hash_pair.second) :
std::make_pair(ins_pos, pos_hash_pair.second)); std::make_pair(ins_pos, pos_hash_pair.second));
} }
break; break;
case erased_entry_status: case erased_entry_status:

View File

@ -60,19 +60,15 @@ begin()
{ {
pointer_ p_value; pointer_ p_value;
size_type pos; size_type pos;
get_start_it_state(p_value, pos); get_start_it_state(p_value, pos);
return iterator(p_value, pos, this);
return (iterator(p_value, pos, this));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::iterator inline typename PB_DS_CLASS_C_DEC::iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
end() end()
{ { return s_end_it; }
return (s_end_it);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_iterator inline typename PB_DS_CLASS_C_DEC::const_iterator
@ -81,17 +77,13 @@ begin() const
{ {
const_pointer_ p_value; const_pointer_ p_value;
size_type pos; size_type pos;
get_start_it_state(p_value, pos); get_start_it_state(p_value, pos);
return const_iterator(p_value, pos, this);
return (const_iterator( p_value, pos, this));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_iterator inline typename PB_DS_CLASS_C_DEC::const_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
end() const end() const
{ { return s_const_end_it; }
return (s_const_end_it);
}

View File

@ -49,78 +49,58 @@ PB_DS_CLASS_T_DEC
Hash_Fn& Hash_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_hash_fn() get_hash_fn()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const Hash_Fn& const Hash_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_hash_fn() const get_hash_fn() const
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
Eq_Fn& Eq_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_eq_fn() get_eq_fn()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const Eq_Fn& const Eq_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_eq_fn() const get_eq_fn() const
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
Probe_Fn& Probe_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_probe_fn() get_probe_fn()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const Probe_Fn& const Probe_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_probe_fn() const get_probe_fn() const
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
Comb_Probe_Fn& Comb_Probe_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_comb_probe_fn() get_comb_probe_fn()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const Comb_Probe_Fn& const Comb_Probe_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_comb_probe_fn() const get_comb_probe_fn() const
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
Resize_Policy& Resize_Policy&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_resize_policy() get_resize_policy()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const Resize_Policy& const Resize_Policy&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_resize_policy() const get_resize_policy() const
{ { return *this; }
return (*this);
}

View File

@ -73,7 +73,7 @@ do_resize_if_needed_no_throw()
{ {
resize_imp(resize_base::get_new_size(m_num_e, m_num_used_e)); resize_imp(resize_base::get_new_size(m_num_e, m_num_used_e));
} }
catch (...) catch(...)
{ } { }
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
@ -108,7 +108,7 @@ resize_imp(size_type new_size)
{ {
resize_imp(a_entries_resized, old_size); resize_imp(a_entries_resized, old_size);
} }
catch (...) catch(...)
{ {
erase_all_valid_entries(a_entries_resized, new_size); erase_all_valid_entries(a_entries_resized, new_size);
m_num_e = old_size; m_num_e = old_size;

View File

@ -48,29 +48,21 @@
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
resize_imp_reassign(entry_pointer p_e, entry_array a_entries_resized, store_hash_false_type) resize_imp_reassign(entry_pointer p_e, entry_array a_entries_resized,
store_hash_false_type)
{ {
const_key_reference r_key = PB_DS_V2F(p_e->m_value); const_key_reference r_key = PB_DS_V2F(p_e->m_value);
size_type hash = ranged_probe_fn_base::operator()(r_key); size_type hash = ranged_probe_fn_base::operator()(r_key);
size_type i; size_type i;
for (i = 0; i < m_num_e; ++i) for (i = 0; i < m_num_e; ++i)
{ {
const size_type pos = const size_type pos = ranged_probe_fn_base::operator()(r_key, hash, i);
ranged_probe_fn_base::operator()(r_key, hash, i);
entry_pointer p_new_e = a_entries_resized + pos; entry_pointer p_new_e = a_entries_resized + pos;
switch(p_new_e->m_stat) switch(p_new_e->m_stat)
{ {
case empty_entry_status: case empty_entry_status:
new (&p_new_e->m_value) value_type(p_e->m_value); new (&p_new_e->m_value) value_type(p_e->m_value);
p_new_e->m_stat = valid_entry_status; p_new_e->m_stat = valid_entry_status;
return; return;
case erased_entry_status: case erased_entry_status:
_GLIBCXX_DEBUG_ASSERT(0); _GLIBCXX_DEBUG_ASSERT(0);
@ -81,7 +73,6 @@ resize_imp_reassign(entry_pointer p_e, entry_array a_entries_resized, store_hash
_GLIBCXX_DEBUG_ASSERT(0); _GLIBCXX_DEBUG_ASSERT(0);
}; };
} }
throw insert_error(); throw insert_error();
} }

View File

@ -48,32 +48,23 @@
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
resize_imp_reassign(entry_pointer p_e, entry_array a_entries_resized, store_hash_true_type) resize_imp_reassign(entry_pointer p_e, entry_array a_entries_resized,
store_hash_true_type)
{ {
const_key_reference r_key = PB_DS_V2F(p_e->m_value); const_key_reference r_key = PB_DS_V2F(p_e->m_value);
size_type hash = ranged_probe_fn_base::operator()(r_key, p_e->m_hash);
size_type hash =
ranged_probe_fn_base::operator()(r_key, p_e->m_hash);
size_type i; size_type i;
for (i = 0; i < m_num_e; ++i) for (i = 0; i < m_num_e; ++i)
{ {
const size_type pos = const size_type pos = ranged_probe_fn_base::operator()(r_key, hash, i);
ranged_probe_fn_base::operator()(r_key, hash, i);
entry_pointer p_new_e = a_entries_resized + pos; entry_pointer p_new_e = a_entries_resized + pos;
switch(p_new_e->m_stat) switch(p_new_e->m_stat)
{ {
case empty_entry_status: case empty_entry_status:
new (&p_new_e->m_value) value_type(p_e->m_value); new (&p_new_e->m_value) value_type(p_e->m_value);
p_new_e->m_hash = hash; p_new_e->m_hash = hash;
p_new_e->m_stat = valid_entry_status; p_new_e->m_stat = valid_entry_status;
return; return;
case erased_entry_status: case erased_entry_status:
_GLIBCXX_DEBUG_ASSERT(0); _GLIBCXX_DEBUG_ASSERT(0);
@ -84,7 +75,6 @@ resize_imp_reassign(entry_pointer p_e, entry_array a_entries_resized, store_hash
_GLIBCXX_DEBUG_ASSERT(0); _GLIBCXX_DEBUG_ASSERT(0);
}; };
} }
throw insert_error(); throw insert_error();
} }

View File

@ -63,4 +63,4 @@ namespace pb_ds
} // namespace detail } // namespace detail
} // namespace pb_ds } // namespace pb_ds
#endif // #ifndef PB_DS_LU_MAP_ENTRY_METADATA_BASE_HPP #endif

View File

@ -50,33 +50,26 @@ PB_DS_CLASS_C_DEC::
erase(const_key_reference r_key) erase(const_key_reference r_key)
{ {
_GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::assert_valid();) _GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::assert_valid();)
if (m_p_l == NULL)
if (m_p_l == NULL) return false;
return false;
if (s_eq_fn(r_key, PB_DS_V2F(m_p_l->m_value))) if (s_eq_fn(r_key, PB_DS_V2F(m_p_l->m_value)))
{ {
entry_pointer p_next = m_p_l->m_p_next; entry_pointer p_next = m_p_l->m_p_next;
actual_erase_entry(m_p_l); actual_erase_entry(m_p_l);
m_p_l = p_next; m_p_l = p_next;
return true; return true;
} }
entry_pointer p_l = m_p_l; entry_pointer p_l = m_p_l;
while (p_l->m_p_next != NULL) while (p_l->m_p_next != NULL)
if (s_eq_fn(r_key, PB_DS_V2F(p_l->m_p_next->m_value))) if (s_eq_fn(r_key, PB_DS_V2F(p_l->m_p_next->m_value)))
{ {
erase_next(p_l); erase_next(p_l);
return true; return true;
} }
else else
p_l = p_l->m_p_next; p_l = p_l->m_p_next;
return false; return false;
} }
@ -95,17 +88,12 @@ PB_DS_CLASS_C_DEC::
erase_if(Pred pred) erase_if(Pred pred)
{ {
_GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::assert_valid();) _GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::assert_valid();)
size_type num_ersd = 0;
size_type num_ersd = 0; while (m_p_l != NULL && pred(m_p_l->m_value))
while (m_p_l != NULL&& pred(m_p_l->m_value))
{ {
entry_pointer p_next = m_p_l->m_p_next; entry_pointer p_next = m_p_l->m_p_next;
++num_ersd; ++num_ersd;
actual_erase_entry(m_p_l); actual_erase_entry(m_p_l);
m_p_l = p_next; m_p_l = p_next;
} }
@ -113,13 +101,11 @@ erase_if(Pred pred)
return num_ersd; return num_ersd;
entry_pointer p_l = m_p_l; entry_pointer p_l = m_p_l;
while (p_l->m_p_next != NULL) while (p_l->m_p_next != NULL)
{ {
if (pred(p_l->m_p_next->m_value)) if (pred(p_l->m_p_next->m_value))
{ {
++num_ersd; ++num_ersd;
erase_next(p_l); erase_next(p_l);
} }
else else
@ -127,8 +113,7 @@ erase_if(Pred pred)
} }
_GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::assert_valid();) _GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::assert_valid();)
return num_ersd;
return (num_ersd);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -139,11 +124,8 @@ erase_next(entry_pointer p_l)
_GLIBCXX_DEBUG_ASSERT(p_l != NULL); _GLIBCXX_DEBUG_ASSERT(p_l != NULL);
_GLIBCXX_DEBUG_ASSERT(p_l != m_p_l); _GLIBCXX_DEBUG_ASSERT(p_l != m_p_l);
_GLIBCXX_DEBUG_ASSERT(p_l->m_p_next != NULL); _GLIBCXX_DEBUG_ASSERT(p_l->m_p_next != NULL);
entry_pointer p_next_l = p_l->m_p_next->m_p_next; entry_pointer p_next_l = p_l->m_p_next->m_p_next;
actual_erase_entry(p_l->m_p_next); actual_erase_entry(p_l->m_p_next);
p_l->m_p_next = p_next_l; p_l->m_p_next = p_next_l;
} }
@ -152,11 +134,8 @@ void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
actual_erase_entry(entry_pointer p_l) actual_erase_entry(entry_pointer p_l)
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::erase_existing( _GLIBCXX_DEBUG_ONLY(map_debug_base::erase_existing(PB_DS_V2F(p_l->m_value));)
PB_DS_V2F(p_l->m_value));) p_l->~entry();
p_l->~entry();
s_entry_allocator.deallocate(p_l, 1); s_entry_allocator.deallocate(p_l, 1);
} }

View File

@ -51,35 +51,26 @@ find_imp(const_key_reference r_key) const
{ {
if (m_p_l == NULL) if (m_p_l == NULL)
return NULL; return NULL;
if (s_eq_fn(r_key, PB_DS_V2F(m_p_l->m_value))) if (s_eq_fn(r_key, PB_DS_V2F(m_p_l->m_value)))
{ {
apply_update(m_p_l, s_metadata_type_indicator); apply_update(m_p_l, s_metadata_type_indicator);
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key);)
return m_p_l;
return m_p_l;
} }
entry_pointer p_l = m_p_l; entry_pointer p_l = m_p_l;
while (p_l->m_p_next != NULL) while (p_l->m_p_next != NULL)
{ {
entry_pointer p_next = p_l->m_p_next; entry_pointer p_next = p_l->m_p_next;
if (s_eq_fn(r_key, PB_DS_V2F(p_next->m_value))) if (s_eq_fn(r_key, PB_DS_V2F(p_next->m_value)))
{ {
if (apply_update(p_next, s_metadata_type_indicator)) if (apply_update(p_next, s_metadata_type_indicator))
{ {
p_l->m_p_next = p_next->m_p_next; p_l->m_p_next = p_next->m_p_next;
p_next->m_p_next = m_p_l; p_next->m_p_next = m_p_l;
m_p_l = p_next; m_p_l = p_next;
return m_p_l; return m_p_l;
} }
return p_next; return p_next;
} }
else else
@ -87,8 +78,7 @@ find_imp(const_key_reference r_key) const
} }
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
return NULL;
return NULL;
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -96,15 +86,11 @@ template<typename Metadata>
inline bool inline bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
apply_update(entry_pointer p_l, type_to_type<Metadata>) apply_update(entry_pointer p_l, type_to_type<Metadata>)
{ { return s_update_policy(p_l->m_update_metadata); }
return s_update_policy(p_l->m_update_metadata);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline bool inline bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
apply_update(entry_pointer, type_to_type<null_lu_metadata>) apply_update(entry_pointer, type_to_type<null_lu_metadata>)
{ { return s_update_policy(s_null_lu_metadata); }
return s_update_policy(s_null_lu_metadata);
}

View File

@ -48,22 +48,16 @@ PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
size() const size() const
{ { return std::distance(begin(), end()); }
return (std::distance(begin(), end()));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
max_size() const max_size() const
{ { return s_entry_allocator.max_size(); }
return (s_entry_allocator.max_size());
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline bool inline bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
empty() const empty() const
{ { return (m_p_l == NULL); }
return (m_p_l == NULL);
}

View File

@ -52,29 +52,21 @@ PB_DS_CLASS_C_DEC::
insert(const_reference r_val) insert(const_reference r_val)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
entry_pointer p_l = find_imp(PB_DS_V2F(r_val));
entry_pointer p_l = find_imp(PB_DS_V2F(r_val));
if (p_l != NULL) if (p_l != NULL)
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists( _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(PB_DS_V2F(r_val));)
PB_DS_V2F(r_val));) return std::make_pair(point_iterator(&p_l->m_value), false);
return std::make_pair(point_iterator(&p_l->m_value), false);
} }
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist( _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(PB_DS_V2F(r_val));)
PB_DS_V2F(r_val));)
p_l = allocate_new_entry(r_val, PB_DS_TYPES_TRAITS_C_DEC::m_no_throw_copies_indicator);
p_l = allocate_new_entry(r_val, traits_base::m_no_throw_copies_indicator);
p_l->m_p_next = m_p_l; p_l->m_p_next = m_p_l;
m_p_l = p_l; m_p_l = p_l;
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return std::make_pair(point_iterator(&p_l->m_value), true);
return std::make_pair(point_iterator(&p_l->m_value), true);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -83,20 +75,13 @@ PB_DS_CLASS_C_DEC::
allocate_new_entry(const_reference r_val, false_type) allocate_new_entry(const_reference r_val, false_type)
{ {
entry_pointer p_l = s_entry_allocator.allocate(1); entry_pointer p_l = s_entry_allocator.allocate(1);
cond_dealtor_t cond(p_l); cond_dealtor_t cond(p_l);
new (const_cast<void* >(static_cast<const void* >(&p_l->m_value)))
new (const_cast<void* >(
static_cast<const void* >(&p_l->m_value)))
value_type(r_val); value_type(r_val);
cond.set_no_action(); cond.set_no_action();
_GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new(PB_DS_V2F(r_val));)
_GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new( init_entry_metadata(p_l, s_metadata_type_indicator);
PB_DS_V2F(r_val));)
init_entry_metadata(p_l, s_metadata_type_indicator);
return p_l; return p_l;
} }
@ -106,14 +91,9 @@ PB_DS_CLASS_C_DEC::
allocate_new_entry(const_reference r_val, true_type) allocate_new_entry(const_reference r_val, true_type)
{ {
entry_pointer p_l = s_entry_allocator.allocate(1); entry_pointer p_l = s_entry_allocator.allocate(1);
new (&p_l->m_value) value_type(r_val); new (&p_l->m_value) value_type(r_val);
_GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new(PB_DS_V2F(r_val));)
_GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new( init_entry_metadata(p_l, s_metadata_type_indicator);
PB_DS_V2F(r_val));)
init_entry_metadata(p_l, s_metadata_type_indicator);
return p_l; return p_l;
} }
@ -122,9 +102,7 @@ template<typename Metadata>
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
init_entry_metadata(entry_pointer p_l, type_to_type<Metadata>) init_entry_metadata(entry_pointer p_l, type_to_type<Metadata>)
{ { new (&p_l->m_update_metadata) Metadata(s_update_policy()); }
new (&p_l->m_update_metadata) Metadata(s_update_policy());
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void

View File

@ -52,11 +52,9 @@ begin()
if (m_p_l == NULL) if (m_p_l == NULL)
{ {
_GLIBCXX_DEBUG_ASSERT(empty()); _GLIBCXX_DEBUG_ASSERT(empty());
return end();
return (end());
} }
return iterator(&m_p_l->m_value, m_p_l, this);
return (iterator(&m_p_l->m_value, m_p_l, this));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -67,28 +65,22 @@ begin() const
if (m_p_l == NULL) if (m_p_l == NULL)
{ {
_GLIBCXX_DEBUG_ASSERT(empty()); _GLIBCXX_DEBUG_ASSERT(empty());
return end();
return (end());
} }
return iterator(&m_p_l->m_value, m_p_l, const_cast<PB_DS_CLASS_C_DEC* >(this));
return (iterator(&m_p_l->m_value, m_p_l,
const_cast<PB_DS_CLASS_C_DEC* >(this)));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::iterator inline typename PB_DS_CLASS_C_DEC::iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
end() end()
{ { return iterator(NULL, NULL, this); }
return (iterator(NULL, NULL, this));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_iterator inline typename PB_DS_CLASS_C_DEC::const_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
end() const end() const
{ {
return (const_iterator(NULL, NULL, return const_iterator(NULL, NULL, const_cast<PB_DS_CLASS_C_DEC* const>(this));
const_cast<PB_DS_CLASS_C_DEC* const>(this)));
} }

View File

@ -113,47 +113,30 @@ namespace pb_ds
#endif #endif
public PB_DS_TYPES_TRAITS_C_DEC public PB_DS_TYPES_TRAITS_C_DEC
{ {
private: private:
typedef PB_DS_TYPES_TRAITS_C_DEC traits_base;
struct entry : public lu_map_entry_metadata_base<typename Update_Policy::metadata_type> struct entry
: public lu_map_entry_metadata_base<typename Update_Policy::metadata_type>
{ {
typename PB_DS_TYPES_TRAITS_C_DEC::value_type m_value; typename traits_base::value_type m_value;
typename Allocator::template rebind<entry>::other::pointer m_p_next; typename Allocator::template rebind<entry>::other::pointer m_p_next;
}; };
typedef typedef typename Allocator::template rebind<entry>::other entry_allocator;
typename Allocator::template rebind<entry>::other
entry_allocator;
typedef typename entry_allocator::pointer entry_pointer; typedef typename entry_allocator::pointer entry_pointer;
typedef typename entry_allocator::const_pointer const_entry_pointer; typedef typename entry_allocator::const_pointer const_entry_pointer;
typedef typename entry_allocator::reference entry_reference; typedef typename entry_allocator::reference entry_reference;
typedef typename entry_allocator::const_reference const_entry_reference; typedef typename entry_allocator::const_reference const_entry_reference;
typedef typedef typename Allocator::template rebind<entry_pointer>::other entry_pointer_allocator;
typename Allocator::template rebind<entry_pointer>::other
entry_pointer_allocator;
typedef typename entry_pointer_allocator::pointer entry_pointer_array; typedef typename entry_pointer_allocator::pointer entry_pointer_array;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::value_type value_type_; typedef typename traits_base::value_type value_type_;
typedef typename traits_base::pointer pointer_;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::pointer pointer_; typedef typename traits_base::const_pointer const_pointer_;
typedef typename traits_base::reference reference_;
typedef typedef typename traits_base::const_reference const_reference_;
typename PB_DS_TYPES_TRAITS_C_DEC::const_pointer
const_pointer_;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::reference reference_;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_reference
const_reference_;
#define PB_DS_GEN_POS entry_pointer #define PB_DS_GEN_POS entry_pointer
@ -164,63 +147,39 @@ namespace pb_ds
#undef PB_DS_GEN_POS #undef PB_DS_GEN_POS
#ifdef _GLIBCXX_DEBUG
typedef PB_DS_MAP_DEBUG_BASE_C_DEC map_debug_base;
#endif
typedef typename traits_base:: no_throw_copies_false_type no_throw_copies_false_type;
typedef typename traits_base:: no_throw_copies_true_type no_throw_copies_true_type;
typedef cond_dealtor<entry, Allocator> cond_dealtor_t;
public: public:
typedef typename Allocator::size_type size_type;
typedef typename Allocator::difference_type difference_type;
typedef Eq_Fn eq_fn;
typedef Allocator allocator; typedef Allocator allocator;
typedef typename Allocator::size_type size_type;
typedef typename Allocator::difference_type difference_type;
typedef Eq_Fn eq_fn;
typedef Update_Policy update_policy; typedef Update_Policy update_policy;
typedef typename Update_Policy::metadata_type update_metadata; typedef typename Update_Policy::metadata_type update_metadata;
typedef typename traits_base::key_type key_type;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::key_type key_type; typedef typename traits_base::key_pointer key_pointer;
typedef typename traits_base::const_key_pointer const_key_pointer;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::key_pointer key_pointer; typedef typename traits_base::key_reference key_reference;
typedef typename traits_base::const_key_reference const_key_reference;
typedef typedef typename traits_base::mapped_type mapped_type;
typename PB_DS_TYPES_TRAITS_C_DEC::const_key_pointer typedef typename traits_base::mapped_pointer mapped_pointer;
const_key_pointer; typedef typename traits_base::const_mapped_pointer const_mapped_pointer;
typedef typename traits_base::mapped_reference mapped_reference;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::key_reference key_reference; typedef typename traits_base::const_mapped_reference const_mapped_reference;
typedef typename traits_base::value_type value_type;
typedef typedef typename traits_base::pointer pointer;
typename PB_DS_TYPES_TRAITS_C_DEC::const_key_reference typedef typename traits_base::const_pointer const_pointer;
const_key_reference; typedef typename traits_base::reference reference;
typedef typename traits_base::const_reference const_reference;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::mapped_type mapped_type;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::mapped_pointer
mapped_pointer;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_mapped_pointer
const_mapped_pointer;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::mapped_reference
mapped_reference;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_mapped_reference
const_mapped_reference;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::value_type value_type;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::pointer pointer;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::const_pointer const_pointer;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::reference reference;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_reference
const_reference;
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
typedef point_iterator_ point_iterator; typedef point_iterator_ point_iterator;
@ -243,10 +202,9 @@ namespace pb_ds
typedef const_iterator_ const_iterator; typedef const_iterator_ const_iterator;
public: public:
PB_DS_CLASS_NAME(); PB_DS_CLASS_NAME();
PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC& other); PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC&);
virtual virtual
~PB_DS_CLASS_NAME(); ~PB_DS_CLASS_NAME();
@ -255,7 +213,7 @@ namespace pb_ds
PB_DS_CLASS_NAME(It first_it, It last_it); PB_DS_CLASS_NAME(It first_it, It last_it);
void void
swap(PB_DS_CLASS_C_DEC& other); swap(PB_DS_CLASS_C_DEC&);
inline size_type inline size_type
size() const; size() const;
@ -279,7 +237,7 @@ namespace pb_ds
} }
inline std::pair<point_iterator, bool> inline std::pair<point_iterator, bool>
insert(const_reference r_val); insert(const_reference);
inline point_iterator inline point_iterator
find(const_key_reference r_key) find(const_key_reference r_key)
@ -298,11 +256,11 @@ namespace pb_ds
} }
inline bool inline bool
erase(const_key_reference r_key); erase(const_key_reference);
template<typename Pred> template<typename Pred>
inline size_type inline size_type
erase_if(Pred pred); erase_if(Pred);
void void
clear(); clear();
@ -329,90 +287,65 @@ namespace pb_ds
trace() const; trace() const;
#endif #endif
private:
typedef PB_DS_TYPES_TRAITS_C_DEC traits_base;
#ifdef _GLIBCXX_DEBUG
typedef PB_DS_MAP_DEBUG_BASE_C_DEC map_debug_base;
#endif
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::
no_throw_copies_false_type
no_throw_copies_false_type;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::
no_throw_copies_true_type
no_throw_copies_true_type;
protected: protected:
template<typename It> template<typename It>
void void
copy_from_range(It first_it, It last_it); copy_from_range(It, It);
private: private:
inline entry_pointer
allocate_new_entry(const_reference r_val, false_type);
inline entry_pointer
allocate_new_entry(const_reference r_val, true_type);
template<typename Metadata>
inline static void
init_entry_metadata(entry_pointer p_l, type_to_type<Metadata>);
inline static void
init_entry_metadata(entry_pointer p_l, type_to_type<null_lu_metadata>);
void
deallocate_all();
void
erase_next(entry_pointer p_l);
void
actual_erase_entry(entry_pointer p_l);
void
inc_it_state(const_pointer& r_p_value, entry_pointer& r_pos) const
{
r_pos = r_pos->m_p_next;
r_p_value = (r_pos == NULL)? NULL :& r_pos->m_value;
}
template<typename Metadata>
inline static bool
apply_update(entry_pointer p_l, type_to_type<Metadata>);
inline static bool
apply_update(entry_pointer p_l, type_to_type<null_lu_metadata>);
inline entry_pointer
find_imp(const_key_reference r_key) const;
private:
mutable entry_pointer m_p_l;
typedef cond_dealtor< entry, Allocator> cond_dealtor_t;
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
friend class iterator_; friend class iterator_;
#endif #endif
friend class const_iterator_; friend class const_iterator_;
inline entry_pointer
allocate_new_entry(const_reference, false_type);
inline entry_pointer
allocate_new_entry(const_reference, true_type);
template<typename Metadata>
inline static void
init_entry_metadata(entry_pointer, type_to_type<Metadata>);
inline static void
init_entry_metadata(entry_pointer, type_to_type<null_lu_metadata>);
void
deallocate_all();
void
erase_next(entry_pointer);
void
actual_erase_entry(entry_pointer);
void
inc_it_state(const_pointer& r_p_value, entry_pointer& r_pos) const
{
r_pos = r_pos->m_p_next;
r_p_value = (r_pos == NULL) ? NULL : &r_pos->m_value;
}
template<typename Metadata>
inline static bool
apply_update(entry_pointer, type_to_type<Metadata>);
inline static bool
apply_update(entry_pointer, type_to_type<null_lu_metadata>);
inline entry_pointer
find_imp(const_key_reference) const;
static entry_allocator s_entry_allocator; static entry_allocator s_entry_allocator;
static Eq_Fn s_eq_fn; static Eq_Fn s_eq_fn;
static Update_Policy s_update_policy; static Update_Policy s_update_policy;
static type_to_type<update_metadata> s_metadata_type_indicator; static type_to_type<update_metadata> s_metadata_type_indicator;
static null_lu_metadata s_null_lu_metadata; static null_lu_metadata s_null_lu_metadata;
mutable entry_pointer m_p_l;
}; };
#include <ext/pb_ds/detail/list_update_map_/constructor_destructor_fn_imps.hpp> #include <ext/pb_ds/detail/list_update_map_/constructor_destructor_fn_imps.hpp>
@ -426,10 +359,9 @@ namespace pb_ds
#undef PB_DS_CLASS_T_DEC #undef PB_DS_CLASS_T_DEC
#undef PB_DS_CLASS_C_DEC #undef PB_DS_CLASS_C_DEC
#undef PB_DS_TYPES_TRAITS_C_DEC #undef PB_DS_TYPES_TRAITS_C_DEC
#undef PB_DS_MAP_DEBUG_BASE_C_DEC #undef PB_DS_MAP_DEBUG_BASE_C_DEC
#undef PB_DS_CLASS_NAME #undef PB_DS_CLASS_NAME
#undef PB_DS_V2F #undef PB_DS_V2F
#undef PB_DS_EP2VP #undef PB_DS_EP2VP
#undef PB_DS_V2S #undef PB_DS_V2S

View File

@ -52,18 +52,14 @@ PB_DS_CLASS_C_DEC::
trace() const trace() const
{ {
std::cerr << m_p_l << std::endl << std::endl; std::cerr << m_p_l << std::endl << std::endl;
const_entry_pointer p_l = m_p_l; const_entry_pointer p_l = m_p_l;
while (p_l != NULL) while (p_l != NULL)
{ {
std::cerr << PB_DS_V2F(p_l->m_value) << std::endl; std::cerr << PB_DS_V2F(p_l->m_value) << std::endl;
p_l = p_l->m_p_next; p_l = p_l->m_p_next;
} }
std::cerr << std::endl; std::cerr << std::endl;
} }
#endif // #ifdef PB_DS_LU_MAP_TRACE_ #endif

View File

@ -54,7 +54,7 @@ assert_valid() const
std::cout << "av1" << std::endl; std::cout << "av1" << std::endl;
if (m_a_values == NULL || m_end_it == NULL || m_size == 0) if (m_a_values == NULL || m_end_it == NULL || m_size == 0)
_GLIBCXX_DEBUG_ASSERT(m_a_values == NULL&& m_end_it == NULL && m_size == 0); _GLIBCXX_DEBUG_ASSERT(m_a_values == NULL && m_end_it == NULL && m_size == 0);
std::cout << "av2" << std::endl; std::cout << "av2" << std::endl;
assert_iterators(); assert_iterators();

View File

@ -50,30 +50,23 @@ PB_DS_CLASS_C_DEC::
clear() clear()
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
if (m_size == 0)
if (m_size == 0) {
{ _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(assert_valid();) return;
}
return; else
} {
else reallocate_metadata((node_update* )this, 0);
{ cond_dtor<size_type> cd(m_a_values, m_end_it, m_size);
reallocate_metadata((node_update* )this, 0); }
cond_dtor<size_type> cd(m_a_values, m_end_it, m_size);
}
_GLIBCXX_DEBUG_ONLY(map_debug_base::clear();) _GLIBCXX_DEBUG_ONLY(map_debug_base::clear();)
m_a_values = NULL;
m_a_values = NULL;
m_size = 0; m_size = 0;
m_end_it = m_a_values; m_end_it = m_a_values;
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
template<typename Pred> template<typename Pred>
@ -85,14 +78,11 @@ erase_if(Pred pred)
#ifdef PB_DS_REGRESSION #ifdef PB_DS_REGRESSION
typename Allocator::group_throw_prob_adjustor adjust(m_size); typename Allocator::group_throw_prob_adjustor adjust(m_size);
#endif // #ifdef PB_DS_REGRESSION #endif
size_type new_size = 0; size_type new_size = 0;
size_type num_val_ersd = 0; size_type num_val_ersd = 0;
iterator source_it = m_a_values; iterator source_it = m_a_values;
for (source_it = begin(); source_it != m_end_it; ++source_it) for (source_it = begin(); source_it != m_end_it; ++source_it)
if (!pred(*source_it)) if (!pred(*source_it))
++new_size; ++new_size;
@ -102,35 +92,26 @@ erase_if(Pred pred)
if (new_size == 0) if (new_size == 0)
{ {
clear(); clear();
return num_val_ersd;
return (num_val_ersd);
} }
value_vector a_new_values = s_value_alloc.allocate(new_size); value_vector a_new_values = s_value_alloc.allocate(new_size);
iterator target_it = a_new_values; iterator target_it = a_new_values;
cond_dtor<size_type> cd(a_new_values, target_it, new_size); cond_dtor<size_type> cd(a_new_values, target_it, new_size);
_GLIBCXX_DEBUG_ONLY(map_debug_base::clear()); _GLIBCXX_DEBUG_ONLY(map_debug_base::clear());
for (source_it = begin(); source_it != m_end_it; ++source_it) for (source_it = begin(); source_it != m_end_it; ++source_it)
{ {
if (!pred(*source_it)) if (!pred(*source_it))
{ {
new (const_cast<void* >( new (const_cast<void*>(static_cast<const void* >(target_it)))
static_cast<const void* >(target_it)))
value_type(*source_it); value_type(*source_it);
_GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new( _GLIBCXX_DEBUG_ONLY(map_debug_base::insert_new(PB_DS_V2F(*source_it)));
PB_DS_V2F(*source_it)));
++target_it; ++target_it;
} }
} }
reallocate_metadata((node_update* )this, new_size); reallocate_metadata((node_update* )this, new_size);
cd.set_no_action(); cd.set_no_action();
{ {
@ -138,16 +119,11 @@ erase_if(Pred pred)
} }
m_a_values = a_new_values; m_a_values = a_new_values;
m_size = new_size; m_size = new_size;
m_end_it = target_it; m_end_it = target_it;
update(node_begin(), (node_update* )this); update(node_begin(), (node_update* )this);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return num_val_ersd;
return (num_val_ersd);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -157,21 +133,17 @@ PB_DS_CLASS_C_DEC::
erase_imp(It it) erase_imp(It it)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
if (it == end())
return end();
if (it == end()) _GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::check_key_exists(PB_DS_V2F(*it));)
return end();
_GLIBCXX_DEBUG_ONLY(
PB_DS_CLASS_C_DEC::check_key_exists(PB_DS_V2F(*it));)
#ifdef PB_DS_REGRESSION #ifdef PB_DS_REGRESSION
typename Allocator::group_throw_prob_adjustor adjust(m_size); typename Allocator::group_throw_prob_adjustor adjust(m_size);
#endif // #ifdef PB_DS_REGRESSION #endif
_GLIBCXX_DEBUG_ASSERT(m_size > 0); _GLIBCXX_DEBUG_ASSERT(m_size > 0);
value_vector a_values = s_value_alloc.allocate(m_size - 1); value_vector a_values = s_value_alloc.allocate(m_size - 1);
iterator source_it = begin(); iterator source_it = begin();
iterator source_end_it = end(); iterator source_end_it = end();
iterator target_it = a_values; iterator target_it = a_values;
@ -181,48 +153,36 @@ erase_imp(It it)
_GLIBCXX_DEBUG_ONLY(size_type cnt = 0;) _GLIBCXX_DEBUG_ONLY(size_type cnt = 0;)
while (source_it != source_end_it) while (source_it != source_end_it)
{ {
if (source_it != it) if (source_it != it)
{ {
_GLIBCXX_DEBUG_ONLY(++cnt;) _GLIBCXX_DEBUG_ONLY(++cnt;)
_GLIBCXX_DEBUG_ASSERT(cnt != m_size); _GLIBCXX_DEBUG_ASSERT(cnt != m_size);
new (const_cast<void* >(static_cast<const void* >(target_it)))
new (const_cast<void* >(
static_cast<const void* >(target_it)))
value_type(*source_it); value_type(*source_it);
++target_it; ++target_it;
} }
else else
ret_it = target_it; ret_it = target_it;
++source_it;
++source_it;
}
_GLIBCXX_DEBUG_ASSERT(m_size > 0);
reallocate_metadata((node_update* )this, m_size - 1);
cd.set_no_action();
_GLIBCXX_DEBUG_ONLY(
PB_DS_CLASS_C_DEC::erase_existing(PB_DS_V2F(*it));)
{
cond_dtor<size_type> cd1(m_a_values, m_end_it, m_size);
} }
_GLIBCXX_DEBUG_ASSERT(m_size > 0);
reallocate_metadata((node_update* )this, m_size - 1);
cd.set_no_action();
_GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::erase_existing(PB_DS_V2F(*it));)
{
cond_dtor<size_type> cd1(m_a_values, m_end_it, m_size);
}
m_a_values = a_values; m_a_values = a_values;
--m_size; --m_size;
m_end_it = m_a_values + m_size; m_end_it = m_a_values + m_size;
update(node_begin(), (node_update* )this); update(node_begin(), (node_update* )this);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return It(ret_it);
return (It(ret_it));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -231,12 +191,9 @@ PB_DS_CLASS_C_DEC::
erase(const_key_reference r_key) erase(const_key_reference r_key)
{ {
point_iterator it = find(r_key); point_iterator it = find(r_key);
if (it == end()) if (it == end())
return (false); return false;
erase(it); erase(it);
return true;
return (true);
} }

View File

@ -50,22 +50,17 @@ PB_DS_CLASS_C_DEC::
size() const size() const
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return m_size;
return (m_size);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
max_size() const max_size() const
{ { return s_value_alloc.max_size(); }
return (s_value_alloc.max_size());
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline bool inline bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
empty() const empty() const
{ { return size() == 0; }
return (size() == 0);
}

View File

@ -56,16 +56,14 @@ void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
reallocate_metadata(Node_Update_* , size_type new_size) reallocate_metadata(Node_Update_* , size_type new_size)
{ {
metadata_pointer a_new_metadata_vec =(new_size == 0)? NULL : s_metadata_alloc.allocate(new_size); metadata_pointer a_new_metadata_vec =(new_size == 0) ? NULL : s_metadata_alloc.allocate(new_size);
if (m_a_metadata != NULL) if (m_a_metadata != NULL)
{ {
for (size_type i = 0; i < m_size; ++i) for (size_type i = 0; i < m_size; ++i)
m_a_metadata[i].~metadata_type(); m_a_metadata[i].~metadata_type();
s_metadata_alloc.deallocate(m_a_metadata, m_size); s_metadata_alloc.deallocate(m_a_metadata, m_size);
} }
std::swap(m_a_metadata, a_new_metadata_vec); std::swap(m_a_metadata, a_new_metadata_vec);
} }

View File

@ -48,45 +48,36 @@ PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_node_iterator inline typename PB_DS_CLASS_C_DEC::const_node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
node_begin() const node_begin() const
{ { return PB_DS_node_begin_imp(); }
return (PB_DS_node_begin_imp());
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_node_iterator inline typename PB_DS_CLASS_C_DEC::const_node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
node_end() const node_end() const
{ { return PB_DS_node_end_imp(); }
return (PB_DS_node_end_imp());
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::node_iterator inline typename PB_DS_CLASS_C_DEC::node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
node_begin() node_begin()
{ { return PB_DS_node_begin_imp(); }
return (PB_DS_node_begin_imp());
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::node_iterator inline typename PB_DS_CLASS_C_DEC::node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
node_end() node_end()
{ { return PB_DS_node_end_imp(); }
return (PB_DS_node_end_imp());
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_node_iterator inline typename PB_DS_CLASS_C_DEC::const_node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_node_begin_imp() const PB_DS_node_begin_imp() const
{ {
return (const_node_iterator( return const_node_iterator(const_cast<pointer>(mid_pointer(begin(), end())),
const_cast<pointer>(mid_pointer(begin(), end())),
const_cast<pointer>(begin()), const_cast<pointer>(begin()),
const_cast<pointer>(end()),(m_a_metadata == NULL)? const_cast<pointer>(end()),(m_a_metadata == NULL)?
NULL : NULL :
mid_pointer(m_a_metadata, m_a_metadata + m_size))); mid_pointer(m_a_metadata, m_a_metadata + m_size));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -94,12 +85,8 @@ inline typename PB_DS_CLASS_C_DEC::const_node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_node_end_imp() const PB_DS_node_end_imp() const
{ {
return (const_node_iterator( return const_node_iterator(end(), end(), end(),
end(), (m_a_metadata == NULL) ? NULL : m_a_metadata + m_size);
end(),
end(),(m_a_metadata == NULL)?
NULL :
m_a_metadata + m_size));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -107,12 +94,8 @@ inline typename PB_DS_CLASS_C_DEC::node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_node_begin_imp() PB_DS_node_begin_imp()
{ {
return (node_iterator( return node_iterator(mid_pointer(begin(), end()), begin(), end(),
mid_pointer(begin(), end()), (m_a_metadata == NULL) ? NULL : mid_pointer(m_a_metadata, m_a_metadata + m_size));
begin(),
end(),(m_a_metadata == NULL)?
NULL :
mid_pointer(m_a_metadata, m_a_metadata + m_size)));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -120,11 +103,7 @@ inline typename PB_DS_CLASS_C_DEC::node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_node_end_imp() PB_DS_node_end_imp()
{ {
return (node_iterator( return node_iterator(end(), end(),
end(), end(),(m_a_metadata == NULL) ? NULL : m_a_metadata + m_size);
end(),
end(),(m_a_metadata == NULL)?
NULL :
m_a_metadata + m_size));
} }

View File

@ -55,7 +55,6 @@ namespace pb_ds
{ {
namespace detail namespace detail
{ {
#define PB_DS_STATIC_ASSERT(UNIQUE, E) \ #define PB_DS_STATIC_ASSERT(UNIQUE, E) \
typedef \ typedef \
static_assert_dumclass<sizeof(static_assert<(bool)(E)>)> \ static_assert_dumclass<sizeof(static_assert<(bool)(E)>)> \

View File

@ -64,7 +64,6 @@ namespace pb_ds
{ {
namespace detail namespace detail
{ {
#define PB_DS_CLASS_T_DEC \ #define PB_DS_CLASS_T_DEC \
template<typename Key, typename Mapped, class Cmp_Fn, \ template<typename Key, typename Mapped, class Cmp_Fn, \
class Node_And_It_Traits, class Allocator> class Node_And_It_Traits, class Allocator>
@ -128,21 +127,14 @@ namespace pb_ds
public Node_And_It_Traits::node_update, public Node_And_It_Traits::node_update,
public PB_DS_TYPES_TRAITS_C_DEC public PB_DS_TYPES_TRAITS_C_DEC
{ {
private: private:
typedef typedef PB_DS_TYPES_TRAITS_C_DEC traits_base;
typename remove_const<
typename PB_DS_TYPES_TRAITS_C_DEC::value_type>::type
non_const_value_type;
typedef typedef typename remove_const<typename traits_base::value_type>::type non_const_value_type;
typename Allocator::template rebind<
non_const_value_type>::other
value_allocator;
typedef typename Allocator::template rebind<non_const_value_type>::other value_allocator;
typedef typename value_allocator::pointer value_vector; typedef typename value_allocator::pointer value_vector;
typedef PB_DS_TYPES_TRAITS_C_DEC traits_base;
typedef Cmp_Fn cmp_fn_base; typedef Cmp_Fn cmp_fn_base;
@ -150,25 +142,14 @@ namespace pb_ds
typedef PB_DS_MAP_DEBUG_BASE_C_DEC map_debug_base; typedef PB_DS_MAP_DEBUG_BASE_C_DEC map_debug_base;
#endif #endif
typedef typename PB_DS_TYPES_TRAITS_C_DEC::pointer mapped_pointer_; typedef typename traits_base::pointer mapped_pointer_;
typedef typename traits_base::const_pointer const_mapped_pointer_;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_pointer
const_mapped_pointer_;
typedef typename Node_And_It_Traits::metadata_type metadata_type; typedef typename Node_And_It_Traits::metadata_type metadata_type;
typedef typedef typename Allocator::template rebind<metadata_type>::other metadata_allocator;
typename Allocator::template rebind<
metadata_type>::other
metadata_allocator;
typedef typename metadata_allocator::pointer metadata_pointer; typedef typename metadata_allocator::pointer metadata_pointer;
typedef typename metadata_allocator::const_reference const_metadata_reference;
typedef
typename metadata_allocator::const_reference
const_metadata_reference;
typedef typename metadata_allocator::reference metadata_reference; typedef typename metadata_allocator::reference metadata_reference;
typedef typedef
@ -177,59 +158,29 @@ namespace pb_ds
public: public:
typedef Allocator allocator;
typedef typename Allocator::size_type size_type; typedef typename Allocator::size_type size_type;
typedef typename Allocator::difference_type difference_type; typedef typename Allocator::difference_type difference_type;
typedef Cmp_Fn cmp_fn; typedef Cmp_Fn cmp_fn;
typedef typename Node_And_It_Traits::node_update node_update; typedef typename Node_And_It_Traits::node_update node_update;
typedef Allocator allocator; typedef typename traits_base::key_type key_type;
typedef typename traits_base::key_pointer key_pointer;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::key_type key_type; typedef typename traits_base::const_key_pointer const_key_pointer;
typedef typename traits_base::key_reference key_reference;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::key_pointer key_pointer; typedef typename traits_base::const_key_reference const_key_reference;
typedef typename traits_base::mapped_type mapped_type;
typedef typedef typename traits_base::mapped_pointer mapped_pointer;
typename PB_DS_TYPES_TRAITS_C_DEC::const_key_pointer typedef typename traits_base::const_mapped_pointer const_mapped_pointer;
const_key_pointer; typedef typename traits_base::mapped_reference mapped_reference;
typedef typename traits_base::const_mapped_reference const_mapped_reference;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::key_reference key_reference; typedef typename traits_base::value_type value_type;
typedef typename traits_base::pointer pointer;
typedef typedef typename traits_base::const_pointer const_pointer;
typename PB_DS_TYPES_TRAITS_C_DEC::const_key_reference typedef typename traits_base::reference reference;
const_key_reference; typedef typename traits_base::const_reference const_reference;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::mapped_type mapped_type;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::mapped_pointer
mapped_pointer;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_mapped_pointer
const_mapped_pointer;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::mapped_reference
mapped_reference;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_mapped_reference
const_mapped_reference;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::value_type value_type;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::pointer pointer;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::const_pointer const_pointer;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::reference reference;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_reference
const_reference;
typedef const_pointer const_point_iterator; typedef const_pointer const_point_iterator;
@ -255,20 +206,20 @@ namespace pb_ds
PB_DS_OV_TREE_CLASS_NAME(); PB_DS_OV_TREE_CLASS_NAME();
PB_DS_OV_TREE_CLASS_NAME(const Cmp_Fn& r_cmp_fn); PB_DS_OV_TREE_CLASS_NAME(const Cmp_Fn&);
PB_DS_OV_TREE_CLASS_NAME(const Cmp_Fn& r_cmp_fn, const node_update& r_node_update); PB_DS_OV_TREE_CLASS_NAME(const Cmp_Fn&, const node_update&);
PB_DS_OV_TREE_CLASS_NAME(const PB_DS_CLASS_C_DEC& other); PB_DS_OV_TREE_CLASS_NAME(const PB_DS_CLASS_C_DEC&);
~PB_DS_OV_TREE_CLASS_NAME(); ~PB_DS_OV_TREE_CLASS_NAME();
void void
swap(PB_DS_CLASS_C_DEC& other); swap(PB_DS_CLASS_C_DEC&);
template<typename It> template<typename It>
void void
copy_from_range(It first_it, It last_it); copy_from_range(It, It);
inline size_type inline size_type
max_size() const; max_size() const;
@ -342,9 +293,7 @@ namespace pb_ds
inline const_point_iterator inline const_point_iterator
lower_bound(const_key_reference r_key) const lower_bound(const_key_reference r_key) const
{ { return const_cast<PB_DS_CLASS_C_DEC& >(*this).lower_bound(r_key); }
return (const_cast<PB_DS_CLASS_C_DEC& >(*this).lower_bound(r_key));
}
inline point_iterator inline point_iterator
upper_bound(const_key_reference r_key) upper_bound(const_key_reference r_key)
@ -384,11 +333,11 @@ namespace pb_ds
{ return (const_cast<PB_DS_CLASS_C_DEC& >(*this).find(r_key)); } { return (const_cast<PB_DS_CLASS_C_DEC& >(*this).find(r_key)); }
bool bool
erase(const_key_reference r_key); erase(const_key_reference);
template<typename Pred> template<typename Pred>
inline size_type inline size_type
erase_if(Pred pred); erase_if(Pred);
inline iterator inline iterator
erase(iterator it) erase(iterator it)
@ -398,10 +347,10 @@ namespace pb_ds
clear(); clear();
void void
join(PB_DS_CLASS_C_DEC& other); join(PB_DS_CLASS_C_DEC&);
void void
split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other); split(const_key_reference, PB_DS_CLASS_C_DEC&);
inline iterator inline iterator
begin() begin()
@ -438,25 +387,25 @@ namespace pb_ds
template<typename Node_Update> template<typename Node_Update>
void void
update(node_iterator it, Node_Update* p_update); update(node_iterator, Node_Update*);
void void
reallocate_metadata(null_node_update_pointer, size_type); reallocate_metadata(null_node_update_pointer, size_type);
template<typename Node_Update_> template<typename Node_Update_>
void void
reallocate_metadata(Node_Update_* p_update, size_type new_size); reallocate_metadata(Node_Update_*, size_type);
template<typename It> template<typename It>
void void
copy_from_ordered_range(It first_it, It last_it); copy_from_ordered_range(It, It);
void void
value_swap(PB_DS_CLASS_C_DEC& other); value_swap(PB_DS_CLASS_C_DEC&);
template<typename It> template<typename It>
void void
copy_from_ordered_range(It first_it, It last_it, It other_first_it, It other_last_it); copy_from_ordered_range(It, It, It, It);
template<typename Ptr> template<typename Ptr>
inline static Ptr inline static Ptr
@ -543,16 +492,12 @@ namespace pb_ds
PB_DS_node_end_imp(); PB_DS_node_end_imp();
private: private:
value_vector m_a_values;
static value_allocator s_value_alloc; static value_allocator s_value_alloc;
metadata_pointer m_a_metadata;
static metadata_allocator s_metadata_alloc; static metadata_allocator s_metadata_alloc;
value_vector m_a_values;
metadata_pointer m_a_metadata;
iterator m_end_it; iterator m_end_it;
size_type m_size; size_type m_size;
}; };
@ -577,7 +522,6 @@ namespace pb_ds
#undef PB_DS_V2F #undef PB_DS_V2F
#undef PB_DS_EP2VP #undef PB_DS_EP2VP
#undef PB_DS_V2S #undef PB_DS_V2S
#undef PB_DS_CONST_NODE_ITERATOR_NAME #undef PB_DS_CONST_NODE_ITERATOR_NAME
} // namespace detail } // namespace detail

View File

@ -48,14 +48,10 @@ PB_DS_CLASS_T_DEC
Cmp_Fn& Cmp_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_cmp_fn() get_cmp_fn()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const Cmp_Fn& const Cmp_Fn&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_cmp_fn() const get_cmp_fn() const
{ { return *this; }
return (*this);
}

View File

@ -50,77 +50,55 @@ PB_DS_CLASS_C_DEC::
split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other) split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
if (m_size == 0) if (m_size == 0)
{ {
other.clear(); other.clear();
_GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) return;
}
return;
}
if (Cmp_Fn::operator()(r_key, PB_DS_V2F(*begin()))) if (Cmp_Fn::operator()(r_key, PB_DS_V2F(*begin())))
{ {
value_swap(other); value_swap(other);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
return;
return;
} }
if (!Cmp_Fn::operator()( if (!Cmp_Fn::operator()(r_key, PB_DS_V2F(*(end() - 1))))
r_key,
PB_DS_V2F(*(end() - 1))))
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
return;
return;
} }
if (m_size == 1) if (m_size == 1)
{ {
value_swap(other); value_swap(other);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
return;
return;
} }
_GLIBCXX_DEBUG_ONLY(map_debug_base::join(other);) _GLIBCXX_DEBUG_ONLY(map_debug_base::join(other);)
iterator it = upper_bound(r_key);
iterator it = upper_bound(r_key);
PB_DS_CLASS_C_DEC new_other(other, other); PB_DS_CLASS_C_DEC new_other(other, other);
new_other.copy_from_ordered_range(it, end()); new_other.copy_from_ordered_range(it, end());
PB_DS_CLASS_C_DEC new_this(*this, * this); PB_DS_CLASS_C_DEC new_this(*this, * this);
new_this.copy_from_ordered_range(begin(), it); new_this.copy_from_ordered_range(begin(), it);
// No exceptions from this point. // No exceptions from this point.
_GLIBCXX_DEBUG_ONLY(map_debug_base::split(r_key,(Cmp_Fn& )(*this), other);)
_GLIBCXX_DEBUG_ONLY(map_debug_base::split( other.update(other.node_begin(), (node_update* )(&other));
r_key,(Cmp_Fn& )(*this),
other);)
other.update(other.node_begin(), (node_update* )(&other));
update(node_begin(), (node_update* )this); update(node_begin(), (node_update* )this);
other.value_swap(new_other); other.value_swap(new_other);
value_swap(new_this); value_swap(new_this);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
@ -128,52 +106,38 @@ PB_DS_CLASS_C_DEC::
join(PB_DS_CLASS_C_DEC& other) join(PB_DS_CLASS_C_DEC& other)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
if (other.m_size == 0)
if (other.m_size == 0) return;
return;
if (m_size == 0) if (m_size == 0)
{ {
value_swap(other); value_swap(other);
return; return;
} }
const bool greater = Cmp_Fn::operator()( const bool greater = Cmp_Fn::operator()(PB_DS_V2F(*(end() - 1)),
PB_DS_V2F(*(end() - 1)),
PB_DS_V2F(*other.begin())); PB_DS_V2F(*other.begin()));
const bool lesser = Cmp_Fn::operator()( const bool lesser = Cmp_Fn::operator()(PB_DS_V2F(*(other.end() - 1)),
PB_DS_V2F(*(other.end() - 1)),
PB_DS_V2F(*begin())); PB_DS_V2F(*begin()));
if (!greater&& !lesser) if (!greater&& !lesser)
throw join_error(); throw join_error();
PB_DS_CLASS_C_DEC new_this(*this, * this); PB_DS_CLASS_C_DEC new_this(*this, *this);
if (greater) if (greater)
new_this.copy_from_ordered_range( new_this.copy_from_ordered_range(begin(), end(),
begin(), other.begin(), other.end());
end(),
other.begin(),
other.end());
else else
new_this.copy_from_ordered_range( new_this.copy_from_ordered_range(other.begin(), other.end(),
other.begin(), begin(), end());
other.end(),
begin(),
end());
// No exceptions from this point. // No exceptions from this point.
_GLIBCXX_DEBUG_ONLY(map_debug_base::join(other);) _GLIBCXX_DEBUG_ONLY(map_debug_base::join(other);)
value_swap(new_this);
value_swap(new_this);
other.clear(); other.clear();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
} }

View File

@ -48,64 +48,52 @@ struct iterator : public const_iterator
{ {
public: public:
typedef std::forward_iterator_tag iterator_category; typedef std::forward_iterator_tag iterator_category;
typedef typename Allocator::difference_type difference_type; typedef typename Allocator::difference_type difference_type;
typedef node_pointer value_type; typedef node_pointer value_type;
typedef node_pointer_pointer pointer; typedef node_pointer_pointer pointer;
typedef node_pointer_reference reference; typedef node_pointer_reference reference;
public:
inline inline
iterator(node_pointer_pointer p_p_cur = NULL, node_pointer_pointer p_p_end = NULL) : const_iterator(p_p_cur, p_p_end) iterator(node_pointer_pointer p_p_cur = NULL,
node_pointer_pointer p_p_end = NULL)
: const_iterator(p_p_cur, p_p_end)
{ } { }
inline bool inline bool
operator==(const iterator& other) const operator==(const iterator& other) const
{ { return const_iterator::m_p_p_cur == other.m_p_p_cur; }
return (const_iterator::m_p_p_cur == other.m_p_p_cur);
}
inline bool inline bool
operator!=(const iterator& other) const operator!=(const iterator& other) const
{ { return const_iterator::m_p_p_cur != other.m_p_p_cur; }
return (const_iterator::m_p_p_cur != other.m_p_p_cur);
}
inline iterator& inline iterator&
operator++() operator++()
{ {
const_iterator::operator++(); const_iterator::operator++();
return *this;
return (*this);
} }
inline iterator inline iterator
operator++(int) operator++(int)
{ {
iterator ret_it(*this); iterator ret_it(*this);
operator++(); operator++();
return ret_it;
return (ret_it);
} }
node_pointer_pointer node_pointer_pointer
operator->() operator->()
{ {
_GLIBCXX_DEBUG_ONLY(const_iterator::assert_referencible();) _GLIBCXX_DEBUG_ONLY(const_iterator::assert_referencible();)
return const_iterator::m_p_p_cur;
return (const_iterator::m_p_p_cur);
} }
node_pointer node_pointer
operator*() operator*()
{ {
_GLIBCXX_DEBUG_ONLY(const_iterator::assert_referencible();) _GLIBCXX_DEBUG_ONLY(const_iterator::assert_referencible();)
return *const_iterator::m_p_p_cur;
return (*const_iterator::m_p_p_cur);
} }
}; };

View File

@ -79,9 +79,7 @@ public:
protected: protected:
leaf_pointer m_p_nd; leaf_pointer m_p_nd;
bool m_no_action_dtor; bool m_no_action_dtor;
bool m_call_destructor; bool m_call_destructor;
}; };

View File

@ -50,34 +50,23 @@ PB_DS_CLASS_C_DEC::
erase(const_key_reference r_key) erase(const_key_reference r_key)
{ {
node_pointer p_nd = find_imp(r_key); node_pointer p_nd = find_imp(r_key);
if (p_nd == NULL || p_nd->m_type == pat_trie_internal_node_type) if (p_nd == NULL || p_nd->m_type == pat_trie_internal_node_type)
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist( _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key));
r_key)); return false;
return (false);
} }
_GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_leaf_node_type); _GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_leaf_node_type);
if (!synth_e_access_traits::equal_keys(PB_DS_V2F(reinterpret_cast<leaf_pointer>(p_nd)->value()), r_key))
if (!synth_e_access_traits::equal_keys(
PB_DS_V2F(reinterpret_cast<leaf_pointer>(p_nd)->value()),
r_key))
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist( _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key));
r_key)); return false;
return (false);
} }
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key)); _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key));
erase_leaf(static_cast<leaf_pointer>(p_nd)); erase_leaf(static_cast<leaf_pointer>(p_nd));
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return true;
return (true);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -86,19 +75,15 @@ PB_DS_CLASS_C_DEC::
erase_fixup(internal_node_pointer p_nd) erase_fixup(internal_node_pointer p_nd)
{ {
_GLIBCXX_DEBUG_ASSERT(std::distance(p_nd->begin(), p_nd->end()) >= 1); _GLIBCXX_DEBUG_ASSERT(std::distance(p_nd->begin(), p_nd->end()) >= 1);
if (std::distance(p_nd->begin(), p_nd->end()) == 1) if (std::distance(p_nd->begin(), p_nd->end()) == 1)
{ {
node_pointer p_parent = p_nd->m_p_parent; node_pointer p_parent = p_nd->m_p_parent;
if (p_parent == m_p_head) if (p_parent == m_p_head)
m_p_head->m_p_parent =* p_nd->begin(); m_p_head->m_p_parent =* p_nd->begin();
else else
{ {
_GLIBCXX_DEBUG_ASSERT(p_parent->m_type == pat_trie_internal_node_type); _GLIBCXX_DEBUG_ASSERT(p_parent->m_type == pat_trie_internal_node_type);
node_pointer p_new_child =* p_nd->begin(); node_pointer p_new_child =* p_nd->begin();
static_cast<internal_node_pointer>(p_parent)->replace_child( static_cast<internal_node_pointer>(p_parent)->replace_child(
p_new_child, p_new_child,
pref_begin(p_new_child), pref_begin(p_new_child),
@ -106,31 +91,24 @@ erase_fixup(internal_node_pointer p_nd)
this); this);
} }
(*p_nd->begin())->m_p_parent = p_nd->m_p_parent; (*p_nd->begin())->m_p_parent = p_nd->m_p_parent;
p_nd->~internal_node(); p_nd->~internal_node();
s_internal_node_allocator.deallocate(p_nd, 1); s_internal_node_allocator.deallocate(p_nd, 1);
if (p_parent == m_p_head) if (p_parent == m_p_head)
return; return;
_GLIBCXX_DEBUG_ASSERT(p_parent->m_type == pat_trie_internal_node_type); _GLIBCXX_DEBUG_ASSERT(p_parent->m_type == pat_trie_internal_node_type);
p_nd = static_cast<internal_node_pointer>(p_parent); p_nd = static_cast<internal_node_pointer>(p_parent);
} }
while (true) while (true)
{ {
_GLIBCXX_DEBUG_ASSERT(std::distance(p_nd->begin(), p_nd->end()) > 1); _GLIBCXX_DEBUG_ASSERT(std::distance(p_nd->begin(), p_nd->end()) > 1);
p_nd->update_prefixes(this); p_nd->update_prefixes(this);
apply_update(p_nd, (node_update* )this); apply_update(p_nd, (node_update* )this);
_GLIBCXX_DEBUG_ONLY(p_nd->assert_valid(this);) _GLIBCXX_DEBUG_ONLY(p_nd->assert_valid(this);)
if (p_nd->m_p_parent->m_type == pat_trie_head_node_type)
if (p_nd->m_p_parent->m_type == pat_trie_head_node_type) return;
return;
_GLIBCXX_DEBUG_ASSERT(p_nd->m_p_parent->m_type == _GLIBCXX_DEBUG_ASSERT(p_nd->m_p_parent->m_type ==
pat_trie_internal_node_type); pat_trie_internal_node_type);
@ -146,11 +124,8 @@ actual_erase_leaf(leaf_pointer p_l)
{ {
_GLIBCXX_DEBUG_ASSERT(m_size > 0); _GLIBCXX_DEBUG_ASSERT(m_size > 0);
--m_size; --m_size;
_GLIBCXX_DEBUG_ONLY(erase_existing(PB_DS_V2F(p_l->value()))); _GLIBCXX_DEBUG_ONLY(erase_existing(PB_DS_V2F(p_l->value())));
p_l->~leaf(); p_l->~leaf();
s_leaf_allocator.deallocate(p_l, 1); s_leaf_allocator.deallocate(p_l, 1);
} }
@ -160,20 +135,15 @@ PB_DS_CLASS_C_DEC::
clear() clear()
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
if (empty())
if (empty()) return;
return;
clear_imp(m_p_head->m_p_parent); clear_imp(m_p_head->m_p_parent);
m_size = 0; m_size = 0;
initialize(); initialize();
_GLIBCXX_DEBUG_ONLY(map_debug_base::clear();) _GLIBCXX_DEBUG_ONLY(map_debug_base::clear();)
_GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(assert_valid();) }
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
@ -183,29 +153,21 @@ clear_imp(node_pointer p_nd)
if (p_nd->m_type == pat_trie_internal_node_type) if (p_nd->m_type == pat_trie_internal_node_type)
{ {
_GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_internal_node_type); _GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_internal_node_type);
for (typename internal_node::iterator it = for (typename internal_node::iterator it =
static_cast<internal_node_pointer>(p_nd)->begin(); static_cast<internal_node_pointer>(p_nd)->begin();
it != static_cast<internal_node_pointer>(p_nd)->end(); it != static_cast<internal_node_pointer>(p_nd)->end();
++it) ++it)
{ {
node_pointer p_child =* it; node_pointer p_child =* it;
clear_imp(p_child); clear_imp(p_child);
} }
s_internal_node_allocator.deallocate(static_cast<internal_node_pointer>(p_nd), 1);
s_internal_node_allocator.deallocate(
static_cast<internal_node_pointer>(p_nd), 1);
return; return;
} }
_GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_leaf_node_type); _GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_leaf_node_type);
static_cast<leaf_pointer>(p_nd)->~leaf(); static_cast<leaf_pointer>(p_nd)->~leaf();
s_leaf_allocator.deallocate(static_cast<leaf_pointer>(p_nd), 1);
s_leaf_allocator.deallocate(
static_cast<leaf_pointer>(p_nd), 1);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -216,19 +178,14 @@ erase(const_iterator it)
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
if (it == end()) if (it == end())
return (it); return it;
const_iterator ret_it = it; const_iterator ret_it = it;
++ret_it; ++ret_it;
_GLIBCXX_DEBUG_ASSERT(it.m_p_nd->m_type == pat_trie_leaf_node_type); _GLIBCXX_DEBUG_ASSERT(it.m_p_nd->m_type == pat_trie_leaf_node_type);
erase_leaf(static_cast<leaf_pointer>(it.m_p_nd)); erase_leaf(static_cast<leaf_pointer>(it.m_p_nd));
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
return ret_it;
return (ret_it);
} }
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
@ -240,19 +197,13 @@ erase(iterator it)
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
if (it == end()) if (it == end())
return (it); return it;
iterator ret_it = it; iterator ret_it = it;
++ret_it; ++ret_it;
_GLIBCXX_DEBUG_ASSERT(it.m_p_nd->m_type == pat_trie_leaf_node_type); _GLIBCXX_DEBUG_ASSERT(it.m_p_nd->m_type == pat_trie_leaf_node_type);
erase_leaf(static_cast<leaf_pointer>(it.m_p_nd)); erase_leaf(static_cast<leaf_pointer>(it.m_p_nd));
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
return ret_it;
return (ret_it);
} }
#endif // #ifdef PB_DS_DATA_TRUE_INDICATOR #endif // #ifdef PB_DS_DATA_TRUE_INDICATOR
@ -264,19 +215,14 @@ erase(const_reverse_iterator it)
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
if (it.m_p_nd == m_p_head) if (it.m_p_nd == m_p_head)
return (it); return it;
const_reverse_iterator ret_it = it; const_reverse_iterator ret_it = it;
++ret_it; ++ret_it;
_GLIBCXX_DEBUG_ASSERT(it.m_p_nd->m_type == pat_trie_leaf_node_type); _GLIBCXX_DEBUG_ASSERT(it.m_p_nd->m_type == pat_trie_leaf_node_type);
erase_leaf(static_cast<leaf_pointer>(it.m_p_nd)); erase_leaf(static_cast<leaf_pointer>(it.m_p_nd));
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
return ret_it;
return (ret_it);
} }
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
@ -288,19 +234,14 @@ erase(reverse_iterator it)
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
if (it.m_p_nd == m_p_head) if (it.m_p_nd == m_p_head)
return (it); return it;
reverse_iterator ret_it = it; reverse_iterator ret_it = it;
++ret_it; ++ret_it;
_GLIBCXX_DEBUG_ASSERT(it.m_p_nd->m_type == pat_trie_leaf_node_type); _GLIBCXX_DEBUG_ASSERT(it.m_p_nd->m_type == pat_trie_leaf_node_type);
erase_leaf(static_cast<leaf_pointer>(it.m_p_nd)); erase_leaf(static_cast<leaf_pointer>(it.m_p_nd));
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
return ret_it;
return (ret_it);
} }
#endif // #ifdef PB_DS_DATA_TRUE_INDICATOR #endif // #ifdef PB_DS_DATA_TRUE_INDICATOR
@ -311,19 +252,15 @@ PB_DS_CLASS_C_DEC::
erase_if(Pred pred) erase_if(Pred pred)
{ {
size_type num_ersd = 0; size_type num_ersd = 0;
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
iterator it = begin(); iterator it = begin();
while (it != end()) while (it != end())
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
if (pred(*it)) if (pred(*it))
{ {
++num_ersd; ++num_ersd;
it = erase(it); it = erase(it);
} }
else else
@ -331,8 +268,7 @@ erase_if(Pred pred)
} }
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return num_ersd;
return (num_ersd);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -341,18 +277,14 @@ PB_DS_CLASS_C_DEC::
erase_leaf(leaf_pointer p_l) erase_leaf(leaf_pointer p_l)
{ {
update_min_max_for_erased_leaf(p_l); update_min_max_for_erased_leaf(p_l);
if (p_l->m_p_parent->m_type == pat_trie_head_node_type) if (p_l->m_p_parent->m_type == pat_trie_head_node_type)
{ {
_GLIBCXX_DEBUG_ASSERT(size() == 1); _GLIBCXX_DEBUG_ASSERT(size() == 1);
clear(); clear();
return; return;
} }
_GLIBCXX_DEBUG_ASSERT(size() > 1); _GLIBCXX_DEBUG_ASSERT(size() > 1);
_GLIBCXX_DEBUG_ASSERT(p_l->m_p_parent->m_type == _GLIBCXX_DEBUG_ASSERT(p_l->m_p_parent->m_type ==
pat_trie_internal_node_type); pat_trie_internal_node_type);
@ -360,9 +292,7 @@ erase_leaf(leaf_pointer p_l)
static_cast<internal_node_pointer>(p_l->m_p_parent); static_cast<internal_node_pointer>(p_l->m_p_parent);
p_parent->remove_child(p_l); p_parent->remove_child(p_l);
erase_fixup(p_parent); erase_fixup(p_parent);
actual_erase_leaf(p_l); actual_erase_leaf(p_l);
} }
@ -375,27 +305,21 @@ update_min_max_for_erased_leaf(leaf_pointer p_l)
{ {
m_p_head->m_p_min = m_p_head; m_p_head->m_p_min = m_p_head;
m_p_head->m_p_max = m_p_head; m_p_head->m_p_max = m_p_head;
return; return;
} }
if (p_l == static_cast<const_leaf_pointer>(m_p_head->m_p_min)) if (p_l == static_cast<const_leaf_pointer>(m_p_head->m_p_min))
{ {
iterator it(p_l); iterator it(p_l);
++it; ++it;
m_p_head->m_p_min = it.m_p_nd; m_p_head->m_p_min = it.m_p_nd;
return; return;
} }
if (p_l == static_cast<const_leaf_pointer>(m_p_head->m_p_max)) if (p_l == static_cast<const_leaf_pointer>(m_p_head->m_p_max))
{ {
iterator it(p_l); iterator it(p_l);
--it; --it;
m_p_head->m_p_max = it.m_p_nd; m_p_head->m_p_max = it.m_p_nd;
} }
} }

View File

@ -50,28 +50,22 @@ PB_DS_CLASS_C_DEC::
find(const_key_reference r_key) find(const_key_reference r_key)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
node_pointer p_nd = find_imp(r_key);
node_pointer p_nd = find_imp(r_key);
if (p_nd == NULL || p_nd->m_type != pat_trie_leaf_node_type) if (p_nd == NULL || p_nd->m_type != pat_trie_leaf_node_type)
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
return end();
return (end());
} }
if (synth_e_access_traits::equal_keys( if (synth_e_access_traits::equal_keys(PB_DS_V2F(static_cast<leaf_pointer>(p_nd)->value()), r_key))
PB_DS_V2F(static_cast<leaf_pointer>(p_nd)->value()),
r_key))
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key)); _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key));
return iterator(p_nd);
return (iterator(p_nd));
} }
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
return end();
return (end());
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -81,29 +75,22 @@ find(const_key_reference r_key) const
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
const_node_pointer p_nd = const_node_pointer p_nd = const_cast<PB_DS_CLASS_C_DEC* >(this)->find_imp(r_key);
const_cast<PB_DS_CLASS_C_DEC* >(this)->find_imp(r_key);
if (p_nd == NULL || p_nd->m_type != pat_trie_leaf_node_type) if (p_nd == NULL || p_nd->m_type != pat_trie_leaf_node_type)
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
return end();
return (end());
} }
if (synth_e_access_traits::equal_keys( if (synth_e_access_traits::equal_keys(PB_DS_V2F(static_cast<const_leaf_pointer>(p_nd)->value()), r_key))
PB_DS_V2F(static_cast<const_leaf_pointer>(p_nd)->value()),
r_key))
{ {
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists( _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_exists(r_key));
r_key)); return const_iterator(const_cast<node_pointer>(p_nd));
return (const_iterator(const_cast<node_pointer>(p_nd)));
} }
_GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);) _GLIBCXX_DEBUG_ONLY(map_debug_base::check_key_does_not_exist(r_key);)
return end();
return (end());
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -125,17 +112,13 @@ find_imp(const_key_reference r_key)
while (p_nd->m_type != pat_trie_leaf_node_type) while (p_nd->m_type != pat_trie_leaf_node_type)
{ {
_GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_internal_node_type); _GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_internal_node_type);
node_pointer p_next_nd = static_cast<internal_node_pointer>(p_nd)->get_child_node(b_it, e_it, this);
node_pointer p_next_nd =
static_cast<internal_node_pointer>(p_nd)->get_child_node( b_it, e_it, this);
if (p_next_nd == NULL) if (p_next_nd == NULL)
return (p_nd); return p_nd;
p_nd = p_next_nd; p_nd = p_next_nd;
} }
return p_nd;
return (p_nd);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -156,31 +139,23 @@ lower_bound_imp(const_key_reference r_key)
synth_e_access_traits::end(r_key); synth_e_access_traits::end(r_key);
size_type checked_ind = 0; size_type checked_ind = 0;
while (true) while (true)
{ {
if (p_nd->m_type == pat_trie_leaf_node_type) if (p_nd->m_type == pat_trie_leaf_node_type)
{ {
if (!synth_e_access_traits::cmp_keys( if (!synth_e_access_traits::cmp_keys(PB_DS_V2F(static_cast<const_leaf_pointer>(p_nd)->value()), r_key))
PB_DS_V2F(static_cast<const_leaf_pointer>(p_nd)->value()), return p_nd;
r_key))
return (p_nd);
iterator it(p_nd); iterator it(p_nd);
++it; ++it;
return it.m_p_nd;
return (it.m_p_nd);
} }
_GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_internal_node_type); _GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_internal_node_type);
const size_type new_checked_ind = const size_type new_checked_ind =
static_cast<internal_node_pointer>(p_nd)->get_e_ind(); static_cast<internal_node_pointer>(p_nd)->get_e_ind();
p_nd = p_nd =
static_cast<internal_node_pointer>(p_nd)->get_lower_bound_child_node( b_it, e_it, checked_ind, this); static_cast<internal_node_pointer>(p_nd)->get_lower_bound_child_node( b_it, e_it, checked_ind, this);
checked_ind = new_checked_ind; checked_ind = new_checked_ind;
} }
} }
@ -189,17 +164,14 @@ PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::point_iterator inline typename PB_DS_CLASS_C_DEC::point_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
lower_bound(const_key_reference r_key) lower_bound(const_key_reference r_key)
{ { return point_iterator(lower_bound_imp(r_key)); }
return (point_iterator(lower_bound_imp(r_key)));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_point_iterator inline typename PB_DS_CLASS_C_DEC::const_point_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
lower_bound(const_key_reference r_key) const lower_bound(const_key_reference r_key) const
{ {
return (const_point_iterator( return const_point_iterator(const_cast<PB_DS_CLASS_C_DEC* >(this)->lower_bound_imp(r_key));
const_cast<PB_DS_CLASS_C_DEC* >(this)->lower_bound_imp(r_key)));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -210,17 +182,14 @@ upper_bound(const_key_reference r_key)
point_iterator l_bound_it = lower_bound(r_key); point_iterator l_bound_it = lower_bound(r_key);
_GLIBCXX_DEBUG_ASSERT(l_bound_it == end() || _GLIBCXX_DEBUG_ASSERT(l_bound_it == end() ||
!synth_e_access_traits::cmp_keys( !synth_e_access_traits::cmp_keys(PB_DS_V2F(*l_bound_it),
PB_DS_V2F(*l_bound_it),
r_key)); r_key));
if (l_bound_it == end() || if (l_bound_it == end() ||
synth_e_access_traits::cmp_keys( synth_e_access_traits::cmp_keys(r_key, PB_DS_V2F(*l_bound_it)))
r_key, return l_bound_it;
PB_DS_V2F(*l_bound_it)))
return (l_bound_it);
return (++l_bound_it); return ++l_bound_it;
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -231,17 +200,13 @@ upper_bound(const_key_reference r_key) const
const_point_iterator l_bound_it = lower_bound(r_key); const_point_iterator l_bound_it = lower_bound(r_key);
_GLIBCXX_DEBUG_ASSERT(l_bound_it == end() || _GLIBCXX_DEBUG_ASSERT(l_bound_it == end() ||
!synth_e_access_traits::cmp_keys( !synth_e_access_traits::cmp_keys(PB_DS_V2F(*l_bound_it),
PB_DS_V2F(*l_bound_it),
r_key)); r_key));
if (l_bound_it == end() || if (l_bound_it == end() ||
synth_e_access_traits::cmp_keys( synth_e_access_traits::cmp_keys(r_key, PB_DS_V2F(*l_bound_it)))
r_key, return l_bound_it;
PB_DS_V2F(*l_bound_it))) return ++l_bound_it;
return (l_bound_it);
return (++l_bound_it);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -250,12 +215,10 @@ PB_DS_CLASS_C_DEC::
pref_begin(const_node_pointer p_nd) pref_begin(const_node_pointer p_nd)
{ {
if (p_nd->m_type == pat_trie_leaf_node_type) if (p_nd->m_type == pat_trie_leaf_node_type)
return (synth_e_access_traits::begin( return (synth_e_access_traits::begin(PB_DS_V2F(static_cast<const_leaf_pointer>(p_nd)->value())));
PB_DS_V2F(static_cast<const_leaf_pointer>(p_nd)->value())));
_GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_internal_node_type); _GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_internal_node_type);
return static_cast<const_internal_node_pointer>(p_nd)->pref_b_it();
return (static_cast<const_internal_node_pointer>(p_nd)->pref_b_it());
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -264,12 +227,10 @@ PB_DS_CLASS_C_DEC::
pref_end(const_node_pointer p_nd) pref_end(const_node_pointer p_nd)
{ {
if (p_nd->m_type == pat_trie_leaf_node_type) if (p_nd->m_type == pat_trie_leaf_node_type)
return (synth_e_access_traits::end( return (synth_e_access_traits::end(PB_DS_V2F(static_cast<const_leaf_pointer>(p_nd)->value())));
PB_DS_V2F(static_cast<const_leaf_pointer>(p_nd)->value())));
_GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_internal_node_type); _GLIBCXX_DEBUG_ASSERT(p_nd->m_type == pat_trie_internal_node_type);
return static_cast<const_internal_node_pointer>(p_nd)->pref_e_it();
return (static_cast<const_internal_node_pointer>(p_nd)->pref_e_it());
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -278,9 +239,8 @@ PB_DS_CLASS_C_DEC::
leftmost_descendant(const_node_pointer p_nd) leftmost_descendant(const_node_pointer p_nd)
{ {
if (p_nd->m_type == pat_trie_leaf_node_type) if (p_nd->m_type == pat_trie_leaf_node_type)
return (static_cast<const_leaf_pointer>(p_nd)); return static_cast<const_leaf_pointer>(p_nd);
return static_cast<const_internal_node_pointer>(p_nd)->leftmost_descendant();
return (static_cast<const_internal_node_pointer>(p_nd)->leftmost_descendant());
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -289,9 +249,8 @@ PB_DS_CLASS_C_DEC::
leftmost_descendant(node_pointer p_nd) leftmost_descendant(node_pointer p_nd)
{ {
if (p_nd->m_type == pat_trie_leaf_node_type) if (p_nd->m_type == pat_trie_leaf_node_type)
return (static_cast<leaf_pointer>(p_nd)); return static_cast<leaf_pointer>(p_nd);
return static_cast<internal_node_pointer>(p_nd)->leftmost_descendant();
return (static_cast<internal_node_pointer>(p_nd)->leftmost_descendant());
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -300,9 +259,8 @@ PB_DS_CLASS_C_DEC::
rightmost_descendant(const_node_pointer p_nd) rightmost_descendant(const_node_pointer p_nd)
{ {
if (p_nd->m_type == pat_trie_leaf_node_type) if (p_nd->m_type == pat_trie_leaf_node_type)
return (static_cast<const_leaf_pointer>(p_nd)); return static_cast<const_leaf_pointer>(p_nd);
return static_cast<const_internal_node_pointer>(p_nd)->rightmost_descendant();
return (static_cast<const_internal_node_pointer>(p_nd)->rightmost_descendant());
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -311,8 +269,7 @@ PB_DS_CLASS_C_DEC::
rightmost_descendant(node_pointer p_nd) rightmost_descendant(node_pointer p_nd)
{ {
if (p_nd->m_type == pat_trie_leaf_node_type) if (p_nd->m_type == pat_trie_leaf_node_type)
return (static_cast<leaf_pointer>(p_nd)); return static_cast<leaf_pointer>(p_nd);
return static_cast<internal_node_pointer>(p_nd)->rightmost_descendant();
return (static_cast<internal_node_pointer>(p_nd)->rightmost_descendant());
} }

View File

@ -54,32 +54,20 @@ namespace pb_ds
{ {
namespace detail namespace detail
{ {
#define PB_DS_CLASS_T_DEC \
template<typename Type_Traits, typename E_Access_Traits, \
typename Metadata, typename Allocator>
#define PB_DS_CLASS_T_DEC \ #define PB_DS_CLASS_C_DEC \
template< \ pat_trie_head<Type_Traits, E_Access_Traits, Metadata, Allocator>
class Type_Traits, \
class E_Access_Traits, \
class Metadata, \
class Allocator>
#define PB_DS_CLASS_C_DEC \ #define PB_DS_BASE_C_DEC \
pat_trie_head< \ pat_trie_node_base<Type_Traits, E_Access_Traits, Metadata, Allocator>
Type_Traits, \
E_Access_Traits, \
Metadata, \
Allocator>
#define PB_DS_BASE_C_DEC \
pat_trie_node_base< \
Type_Traits, \
E_Access_Traits, \
Metadata, \
Allocator>
template<typename Type_Traits, template<typename Type_Traits,
class E_Access_Traits, typename E_Access_Traits,
class Metadata, typename Metadata,
class Allocator> typename Allocator>
struct pat_trie_head : public PB_DS_BASE_C_DEC struct pat_trie_head : public PB_DS_BASE_C_DEC
{ {
private: private:

View File

@ -48,23 +48,17 @@ PB_DS_CLASS_T_DEC
inline bool inline bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
empty() const empty() const
{ { return (m_size == 0); }
return (m_size == 0);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
size() const size() const
{ { return m_size; }
return (m_size);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::size_type inline typename PB_DS_CLASS_C_DEC::size_type
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
max_size() const max_size() const
{ { return s_internal_node_allocator.max_size(); }
return (s_internal_node_allocator.max_size());
}

View File

@ -48,33 +48,25 @@ PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::iterator inline typename PB_DS_CLASS_C_DEC::iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
begin() begin()
{ { return iterator(m_p_head->m_p_min); }
return (iterator(m_p_head->m_p_min));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_iterator inline typename PB_DS_CLASS_C_DEC::const_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
begin() const begin() const
{ { return const_iterator(m_p_head->m_p_min); }
return (const_iterator(m_p_head->m_p_min));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::iterator inline typename PB_DS_CLASS_C_DEC::iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
end() end()
{ { return iterator(m_p_head); }
return (iterator(m_p_head));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_iterator inline typename PB_DS_CLASS_C_DEC::const_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
end() const end() const
{ { return const_iterator(m_p_head); }
return (const_iterator(m_p_head));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_reverse_iterator inline typename PB_DS_CLASS_C_DEC::const_reverse_iterator
@ -82,9 +74,8 @@ PB_DS_CLASS_C_DEC::
rbegin() const rbegin() const
{ {
if (empty()) if (empty())
return (rend()); return rend();
return --end();
return (--end());
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -93,56 +84,43 @@ PB_DS_CLASS_C_DEC::
rbegin() rbegin()
{ {
if (empty()) if (empty())
return (rend()); return rend();
return --end();
return (--end());
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::reverse_iterator inline typename PB_DS_CLASS_C_DEC::reverse_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
rend() rend()
{ { return reverse_iterator(m_p_head); }
return (reverse_iterator(m_p_head));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_reverse_iterator inline typename PB_DS_CLASS_C_DEC::const_reverse_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
rend() const rend() const
{ { return const_reverse_iterator(m_p_head); }
return (const_reverse_iterator(m_p_head));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_node_iterator inline typename PB_DS_CLASS_C_DEC::const_node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
node_begin() const node_begin() const
{ { return const_node_iterator(m_p_head->m_p_parent, this); }
return (const_node_iterator(m_p_head->m_p_parent, this));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::node_iterator inline typename PB_DS_CLASS_C_DEC::node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
node_begin() node_begin()
{ { return node_iterator(m_p_head->m_p_parent, this); }
return (node_iterator(m_p_head->m_p_parent, this));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::const_node_iterator inline typename PB_DS_CLASS_C_DEC::const_node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
node_end() const node_end() const
{ { return const_node_iterator(NULL, this); }
return (const_node_iterator(NULL, this));
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline typename PB_DS_CLASS_C_DEC::node_iterator inline typename PB_DS_CLASS_C_DEC::node_iterator
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
node_end() node_end()
{ { return node_iterator(NULL, this); }
return (node_iterator(NULL, this));
}

View File

@ -127,7 +127,6 @@ namespace pb_ds
private: private:
pat_trie_leaf(const PB_DS_CLASS_C_DEC& other); pat_trie_leaf(const PB_DS_CLASS_C_DEC& other);
private:
value_type m_value; value_type m_value;
}; };

View File

@ -53,26 +53,15 @@ namespace pb_ds
{ {
namespace detail namespace detail
{ {
#define PB_DS_CLASS_T_DEC \
template<typename Type_Traits, typename E_Access_Traits, \
typename Metadata, typename Allocator>
#define PB_DS_CLASS_T_DEC \ #define PB_DS_CLASS_C_DEC \
template< \ pat_trie_node_base<Type_Traits, E_Access_Traits, Metadata, Allocator>
class Type_Traits, \
class E_Access_Traits, \
class Metadata, \
class Allocator>
#define PB_DS_CLASS_C_DEC \ #define PB_DS_PAT_TRIE_SUBTREE_DEBUG_INFO_C_DEC \
pat_trie_node_base< \ pat_trie_subtree_debug_info<Type_Traits, E_Access_Traits, Allocator>
Type_Traits, \
E_Access_Traits, \
Metadata, \
Allocator>
#define PB_DS_PAT_TRIE_SUBTREE_DEBUG_INFO_C_DEC \
pat_trie_subtree_debug_info< \
Type_Traits, \
E_Access_Traits, \
Allocator>
enum pat_trie_node_type enum pat_trie_node_type
{ {
@ -82,9 +71,9 @@ namespace pb_ds
}; };
template<typename Type_Traits, template<typename Type_Traits,
class E_Access_Traits, typename E_Access_Traits,
class Metadata, typename Metadata,
class Allocator> typename Allocator>
struct pat_trie_node_base : public pat_trie_node_metadata_base< struct pat_trie_node_base : public pat_trie_node_metadata_base<
Metadata, Metadata,
Allocator> Allocator>
@ -108,7 +97,6 @@ namespace pb_ds
subtree_debug_info; subtree_debug_info;
#endif #endif
public:
pat_trie_node_base(pat_trie_node_type type); pat_trie_node_base(pat_trie_node_type type);
#ifdef _GLIBCXX_DEBUG #ifdef _GLIBCXX_DEBUG
@ -119,9 +107,7 @@ namespace pb_ds
assert_valid_imp(const_e_access_traits_pointer p_traits) const = 0; assert_valid_imp(const_e_access_traits_pointer p_traits) const = 0;
#endif #endif
public:
node_pointer m_p_parent; node_pointer m_p_parent;
const pat_trie_node_type m_type; const pat_trie_node_type m_type;
}; };

View File

@ -87,7 +87,6 @@ namespace pb_ds
class Allocator> class Allocator>
class pat_trie_const_node_it_ class pat_trie_const_node_it_
{ {
protected: protected:
typedef typedef
typename Allocator::template rebind< typename Allocator::template rebind<
@ -181,14 +180,11 @@ namespace pb_ds
metadata_type>::other::const_reference metadata_type>::other::const_reference
const_metadata_reference; const_metadata_reference;
public:
// Default constructor. // Default constructor.
/* /*
inline inline
pat_trie_const_node_it_() pat_trie_const_node_it_()
*/ */
inline inline
pat_trie_const_node_it_(node_pointer p_nd = NULL, pat_trie_const_node_it_(node_pointer p_nd = NULL,
const_e_access_traits_pointer p_traits = NULL) const_e_access_traits_pointer p_traits = NULL)
@ -219,7 +215,7 @@ namespace pb_ds
num_children() const num_children() const
{ {
if (m_p_nd->m_type == pat_trie_leaf_node_type) if (m_p_nd->m_type == pat_trie_leaf_node_type)
return (0); return 0;
_GLIBCXX_DEBUG_ASSERT(m_p_nd->m_type == pat_trie_internal_node_type); _GLIBCXX_DEBUG_ASSERT(m_p_nd->m_type == pat_trie_internal_node_type);
return std::distance(static_cast<internal_node_pointer>(m_p_nd)->begin(), static_cast<internal_node_pointer>(m_p_nd)->end()); return std::distance(static_cast<internal_node_pointer>(m_p_nd)->begin(), static_cast<internal_node_pointer>(m_p_nd)->end());
} }
@ -270,7 +266,6 @@ namespace pb_ds
public PB_DS_PAT_TRIE_CONST_NODE_ITERATOR_C_DEC public PB_DS_PAT_TRIE_CONST_NODE_ITERATOR_C_DEC
{ {
private: private:
typedef typedef
typename Allocator::template rebind< typename Allocator::template rebind<
@ -303,8 +298,6 @@ namespace pb_ds
// __Iterator's __const reference type. // __Iterator's __const reference type.
typedef value_type const_reference; typedef value_type const_reference;
public:
// Default constructor. // Default constructor.
/* /*
inline inline
@ -328,8 +321,7 @@ namespace pb_ds
PB_DS_PAT_TRIE_NODE_ITERATOR_C_DEC PB_DS_PAT_TRIE_NODE_ITERATOR_C_DEC
get_child(size_type i) const get_child(size_type i) const
{ {
_GLIBCXX_DEBUG_ASSERT(base_type::m_p_nd->m_type == _GLIBCXX_DEBUG_ASSERT(base_type::m_p_nd->m_type == pat_trie_internal_node_type);
pat_trie_internal_node_type);
typename Internal_Node::iterator it = typename Internal_Node::iterator it =
static_cast<internal_node_pointer>(base_type::m_p_nd)->begin(); static_cast<internal_node_pointer>(base_type::m_p_nd)->begin();

View File

@ -75,37 +75,26 @@ namespace pb_ds
{ {
namespace detail namespace detail
{ {
#define PB_DS_CLASS_T_DEC \
#define PB_DS_CLASS_T_DEC \ template<typename Key, typename Mapped, typename Node_And_It_Traits, \
template<typename Key, typename Mapped, class Node_And_It_Traits, \ typename Allocator>
class Allocator>
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
#define PB_DS_CLASS_NAME \ #define PB_DS_CLASS_NAME pat_trie_data_
pat_trie_data_
#endif #endif
#ifdef PB_DS_DATA_FALSE_INDICATOR #ifdef PB_DS_DATA_FALSE_INDICATOR
#define PB_DS_CLASS_NAME \ #define PB_DS_CLASS_NAME pat_trie_no_data_
pat_trie_no_data_
#endif #endif
#define PB_DS_CLASS_C_DEC \ #define PB_DS_CLASS_C_DEC \
PB_DS_CLASS_NAME< \ PB_DS_CLASS_NAME<Key, Mapped, Node_And_It_Traits, Allocator>
Key, \
Mapped, \
Node_And_It_Traits, \
Allocator>
#define PB_DS_TYPES_TRAITS_C_DEC \ #define PB_DS_TYPES_TRAITS_C_DEC \
types_traits< \ types_traits<Key, Mapped, Allocator, false>
Key, \
Mapped, \
Allocator, \
false>
#ifdef _GLIBCXX_DEBUG #ifdef _GLIBCXX_DEBUG
#define PB_DS_MAP_DEBUG_BASE_C_DEC \ #define PB_DS_MAP_DEBUG_BASE_C_DEC \
map_debug_base<Key, eq_by_less<Key, \ map_debug_base<Key, eq_by_less<Key, \
std::less<Key> >, typename Allocator::template rebind<Key>::other::const_reference> std::less<Key> >, typename Allocator::template rebind<Key>::other::const_reference>
#endif #endif
@ -122,10 +111,8 @@ namespace pb_ds
#define PB_DS_EP2VP(X)& ((X)->m_value.first) #define PB_DS_EP2VP(X)& ((X)->m_value.first)
#endif #endif
#define PB_DS_STATIC_ASSERT(UNIQUE, E) \ #define PB_DS_STATIC_ASSERT(UNIQUE, E) \
typedef \ typedef static_assert_dumclass<sizeof(static_assert<(bool)(E)>)> \
static_assert_dumclass< \
sizeof(static_assert<(bool)(E)>)> \
UNIQUE##static_assert_type UNIQUE##static_assert_type
/** /**
@ -133,8 +120,8 @@ namespace pb_ds
**/ **/
template<typename Key, template<typename Key,
typename Mapped, typename Mapped,
class Node_And_It_Traits, typename Node_And_It_Traits,
class Allocator> typename Allocator>
class PB_DS_CLASS_NAME : class PB_DS_CLASS_NAME :
#ifdef _GLIBCXX_DEBUG #ifdef _GLIBCXX_DEBUG
public PB_DS_MAP_DEBUG_BASE_C_DEC, public PB_DS_MAP_DEBUG_BASE_C_DEC,
@ -143,70 +130,31 @@ namespace pb_ds
public Node_And_It_Traits::node_update, public Node_And_It_Traits::node_update,
public PB_DS_TYPES_TRAITS_C_DEC public PB_DS_TYPES_TRAITS_C_DEC
{ {
private: private:
typedef PB_DS_TYPES_TRAITS_C_DEC traits_base;
typedef typedef typename Node_And_It_Traits::synth_e_access_traits synth_e_access_traits;
typename Node_And_It_Traits::synth_e_access_traits typedef typename Allocator::template rebind<synth_e_access_traits>::other::const_pointer const_e_access_traits_pointer;
synth_e_access_traits; typedef typename synth_e_access_traits::const_iterator const_e_iterator;
typedef
typename Allocator::template rebind<
synth_e_access_traits>::other::const_pointer
const_e_access_traits_pointer;
typedef
typename synth_e_access_traits::const_iterator
const_e_iterator;
typedef typename Node_And_It_Traits::node node; typedef typename Node_And_It_Traits::node node;
typedef typename Allocator::template rebind<node>::other::const_pointer const_node_pointer;
typedef typedef typename Allocator::template rebind<node>::other::pointer node_pointer;
typename Allocator::template rebind<
node>::other::const_pointer
const_node_pointer;
typedef
typename Allocator::template rebind<
node>::other::pointer
node_pointer;
typedef typename Node_And_It_Traits::head head; typedef typename Node_And_It_Traits::head head;
typedef typename Allocator::template rebind<head>::other head_allocator;
typedef
typename Allocator::template rebind<
head>::other
head_allocator;
typedef typename head_allocator::pointer head_pointer; typedef typename head_allocator::pointer head_pointer;
typedef typename Node_And_It_Traits::leaf leaf; typedef typename Node_And_It_Traits::leaf leaf;
typedef typename Allocator::template rebind<leaf>::other leaf_allocator;
typedef
typename Allocator::template rebind<
leaf>::other
leaf_allocator;
typedef typename leaf_allocator::const_pointer const_leaf_pointer; typedef typename leaf_allocator::const_pointer const_leaf_pointer;
typedef typename leaf_allocator::pointer leaf_pointer; typedef typename leaf_allocator::pointer leaf_pointer;
typedef typename Node_And_It_Traits::internal_node internal_node; typedef typename Node_And_It_Traits::internal_node internal_node;
typedef typename Allocator::template rebind<internal_node>::other internal_node_allocator;
typedef typedef typename internal_node_allocator::const_pointer const_internal_node_pointer;
typename Allocator::template rebind< typedef typename internal_node_allocator::pointer internal_node_pointer;
internal_node>::other
internal_node_allocator;
typedef
typename internal_node_allocator::const_pointer
const_internal_node_pointer;
typedef
typename internal_node_allocator::pointer
internal_node_pointer;
typedef PB_DS_TYPES_TRAITS_C_DEC traits_base;
#include <ext/pb_ds/detail/pat_trie_/cond_dtor_entry_dealtor.hpp> #include <ext/pb_ds/detail/pat_trie_/cond_dtor_entry_dealtor.hpp>
@ -216,99 +164,50 @@ namespace pb_ds
#include <ext/pb_ds/detail/pat_trie_/split_join_branch_bag.hpp> #include <ext/pb_ds/detail/pat_trie_/split_join_branch_bag.hpp>
typedef typedef typename Node_And_It_Traits::null_node_update_pointer null_node_update_pointer;
typename Node_And_It_Traits::null_node_update_pointer
null_node_update_pointer;
public: public:
typedef pat_trie_tag container_category; typedef pat_trie_tag container_category;
typedef Allocator allocator;
typedef typename Allocator::size_type size_type; typedef typename Allocator::size_type size_type;
typedef typename Allocator::difference_type difference_type; typedef typename Allocator::difference_type difference_type;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::key_type key_type; typedef typename traits_base::key_type key_type;
typedef typename traits_base::key_pointer key_pointer;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::key_pointer key_pointer; typedef typename traits_base::const_key_pointer const_key_pointer;
typedef typename traits_base::key_reference key_reference;
typedef typedef typename traits_base::const_key_reference const_key_reference;
typename PB_DS_TYPES_TRAITS_C_DEC::const_key_pointer typedef typename traits_base::mapped_type mapped_type;
const_key_pointer; typedef typename traits_base::mapped_pointer mapped_pointer;
typedef typename traits_base::const_mapped_pointer const_mapped_pointer;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::key_reference key_reference; typedef typename traits_base::mapped_reference mapped_reference;
typedef typename traits_base::const_mapped_reference const_mapped_reference;
typedef typedef typename traits_base::value_type value_type;
typename PB_DS_TYPES_TRAITS_C_DEC::const_key_reference typedef typename traits_base::pointer pointer;
const_key_reference; typedef typename traits_base::const_pointer const_pointer;
typedef typename traits_base::reference reference;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::mapped_type mapped_type; typedef typename traits_base::const_reference const_reference;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::mapped_pointer
mapped_pointer;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_mapped_pointer
const_mapped_pointer;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::mapped_reference
mapped_reference;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_mapped_reference
const_mapped_reference;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::value_type value_type;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::pointer pointer;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::const_pointer const_pointer;
typedef typename PB_DS_TYPES_TRAITS_C_DEC::reference reference;
typedef
typename PB_DS_TYPES_TRAITS_C_DEC::const_reference
const_reference;
typedef
typename Node_And_It_Traits::const_iterator
const_point_iterator;
typedef typename Node_And_It_Traits::const_iterator const_point_iterator;
typedef typename Node_And_It_Traits::iterator point_iterator; typedef typename Node_And_It_Traits::iterator point_iterator;
typedef const_point_iterator const_iterator; typedef const_point_iterator const_iterator;
typedef point_iterator iterator; typedef point_iterator iterator;
typedef typedef typename Node_And_It_Traits::const_reverse_iterator const_reverse_iterator;
typename Node_And_It_Traits::const_reverse_iterator
const_reverse_iterator;
typedef typename Node_And_It_Traits::reverse_iterator reverse_iterator; typedef typename Node_And_It_Traits::reverse_iterator reverse_iterator;
typedef typename Node_And_It_Traits::const_node_iterator const_node_iterator;
typedef
typename Node_And_It_Traits::const_node_iterator
const_node_iterator;
typedef typename Node_And_It_Traits::node_iterator node_iterator; typedef typename Node_And_It_Traits::node_iterator node_iterator;
typedef typename Node_And_It_Traits::e_access_traits e_access_traits; typedef typename Node_And_It_Traits::e_access_traits e_access_traits;
typedef typename Node_And_It_Traits::node_update node_update; typedef typename Node_And_It_Traits::node_update node_update;
typedef Allocator allocator;
public:
PB_DS_CLASS_NAME(); PB_DS_CLASS_NAME();
PB_DS_CLASS_NAME(const e_access_traits& r_e_access_traits); PB_DS_CLASS_NAME(const e_access_traits&);
PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC& other); PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC&);
void void
swap(PB_DS_CLASS_C_DEC& other); swap(PB_DS_CLASS_C_DEC&);
~PB_DS_CLASS_NAME(); ~PB_DS_CLASS_NAME();
@ -333,74 +232,69 @@ namespace pb_ds
const node_update& const node_update&
get_node_update() const; get_node_update() const;
inline std::pair< inline std::pair<point_iterator, bool>
point_iterator, insert(const_reference);
bool>
insert(const_reference r_val);
inline mapped_reference inline mapped_reference
operator[](const_key_reference r_key) operator[](const_key_reference r_key)
{ {
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
return (insert(std::make_pair( return insert(std::make_pair(r_key, mapped_type())).first->second;
r_key, #else
mapped_type())).first->second);
#else // #ifdef PB_DS_DATA_TRUE_INDICATOR
insert(r_key); insert(r_key);
return traits_base::s_null_mapped;
return (traits_base::s_null_mapped); #endif
#endif // #ifdef PB_DS_DATA_TRUE
} }
inline point_iterator inline point_iterator
find(const_key_reference r_key); find(const_key_reference);
inline const_point_iterator inline const_point_iterator
find(const_key_reference r_key) const; find(const_key_reference) const;
inline point_iterator inline point_iterator
lower_bound(const_key_reference r_key); lower_bound(const_key_reference);
inline const_point_iterator inline const_point_iterator
lower_bound(const_key_reference r_key) const; lower_bound(const_key_reference) const;
inline point_iterator inline point_iterator
upper_bound(const_key_reference r_key); upper_bound(const_key_reference);
inline const_point_iterator inline const_point_iterator
upper_bound(const_key_reference r_key) const; upper_bound(const_key_reference) const;
void void
clear(); clear();
inline bool inline bool
erase(const_key_reference r_key); erase(const_key_reference);
inline const_iterator inline const_iterator
erase(const_iterator it); erase(const_iterator);
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
inline iterator inline iterator
erase(iterator it); erase(iterator);
#endif // #ifdef PB_DS_DATA_TRUE_INDICATOR #endif
inline const_reverse_iterator inline const_reverse_iterator
erase(const_reverse_iterator it); erase(const_reverse_iterator);
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
inline reverse_iterator inline reverse_iterator
erase(reverse_iterator it); erase(reverse_iterator);
#endif // #ifdef PB_DS_DATA_TRUE_INDICATOR #endif
template<typename Pred> template<typename Pred>
inline size_type inline size_type
erase_if(Pred pred); erase_if(Pred);
void void
join(PB_DS_CLASS_C_DEC& other); join(PB_DS_CLASS_C_DEC&);
void void
split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other); split(const_key_reference, PB_DS_CLASS_C_DEC&);
inline iterator inline iterator
begin(); begin();
@ -439,23 +333,21 @@ namespace pb_ds
node_end(); node_end();
#ifdef PB_DS_PAT_TRIE_TRACE_ #ifdef PB_DS_PAT_TRIE_TRACE_
void void
trace() const; trace() const;
#endif
#endif // #ifdef PB_DS_PAT_TRIE_TRACE_
protected: protected:
template<typename It> template<typename It>
void void
copy_from_range(It first_it, It last_it); copy_from_range(It, It);
void void
value_swap(PB_DS_CLASS_C_DEC& other); value_swap(PB_DS_CLASS_C_DEC&);
node_pointer node_pointer
recursive_copy_node(const_node_pointer p_other_nd); recursive_copy_node(const_node_pointer);
private: private:
@ -463,95 +355,103 @@ namespace pb_ds
initialize(); initialize();
inline void inline void
apply_update(node_pointer p_nd, null_node_update_pointer); apply_update(node_pointer, null_node_update_pointer);
template<typename Node_Update_> template<typename Node_Update_>
inline void inline void
apply_update(node_pointer p_nd, Node_Update_* p_update); apply_update(node_pointer, Node_Update_*);
bool bool
join_prep(PB_DS_CLASS_C_DEC& other, split_join_branch_bag& r_bag); join_prep(PB_DS_CLASS_C_DEC&, split_join_branch_bag&);
void void
rec_join_prep(const_node_pointer p_l, const_node_pointer p_r, split_join_branch_bag& r_bag); rec_join_prep(const_node_pointer, const_node_pointer,
split_join_branch_bag&);
void void
rec_join_prep(const_leaf_pointer p_l, const_leaf_pointer p_r, split_join_branch_bag& r_bag); rec_join_prep(const_leaf_pointer, const_leaf_pointer,
split_join_branch_bag&);
void void
rec_join_prep(const_leaf_pointer p_l, const_internal_node_pointer p_r, split_join_branch_bag& r_bag); rec_join_prep(const_leaf_pointer, const_internal_node_pointer,
split_join_branch_bag&);
void void
rec_join_prep(const_internal_node_pointer p_l, const_leaf_pointer p_r, split_join_branch_bag& r_bag); rec_join_prep(const_internal_node_pointer, const_leaf_pointer,
split_join_branch_bag&);
void void
rec_join_prep(const_internal_node_pointer p_l, const_internal_node_pointer p_r, split_join_branch_bag& r_bag); rec_join_prep(const_internal_node_pointer, const_internal_node_pointer,
split_join_branch_bag&);
node_pointer node_pointer
rec_join(node_pointer p_l, node_pointer p_r, size_type checked_ind, split_join_branch_bag& r_bag); rec_join(node_pointer, node_pointer, size_type, split_join_branch_bag&);
node_pointer node_pointer
rec_join(leaf_pointer p_l, leaf_pointer p_r, split_join_branch_bag& r_bag); rec_join(leaf_pointer, leaf_pointer, split_join_branch_bag&);
node_pointer node_pointer
rec_join(leaf_pointer p_l, internal_node_pointer p_r, size_type checked_ind, split_join_branch_bag& r_bag); rec_join(leaf_pointer, internal_node_pointer, size_type,
split_join_branch_bag&);
node_pointer node_pointer
rec_join(internal_node_pointer p_l, leaf_pointer p_r, size_type checked_ind, split_join_branch_bag& r_bag); rec_join(internal_node_pointer, leaf_pointer, size_type,
split_join_branch_bag&);
node_pointer node_pointer
rec_join(internal_node_pointer p_l, internal_node_pointer p_r, split_join_branch_bag& r_bag); rec_join(internal_node_pointer, internal_node_pointer,
split_join_branch_bag&);
size_type size_type
keys_diff_ind(typename e_access_traits::const_iterator b_l, typename e_access_traits::const_iterator e_l, typename e_access_traits::const_iterator b_r, typename e_access_traits::const_iterator e_r); keys_diff_ind(typename e_access_traits::const_iterator, typename e_access_traits::const_iterator, typename e_access_traits::const_iterator, typename e_access_traits::const_iterator);
internal_node_pointer internal_node_pointer
insert_branch(node_pointer p_left_nd, node_pointer p_right_nd, split_join_branch_bag& r_bag); insert_branch(node_pointer, node_pointer, split_join_branch_bag&);
void void
update_min_max_for_inserted_leaf(leaf_pointer p_l); update_min_max_for_inserted_leaf(leaf_pointer);
void void
erase_leaf(leaf_pointer p_l); erase_leaf(leaf_pointer);
inline void inline void
actual_erase_leaf(leaf_pointer p_lf); actual_erase_leaf(leaf_pointer);
void void
clear_imp(node_pointer p_nd); clear_imp(node_pointer);
void void
erase_fixup(internal_node_pointer p_nd); erase_fixup(internal_node_pointer);
void void
update_min_max_for_erased_leaf(leaf_pointer p_l); update_min_max_for_erased_leaf(leaf_pointer);
static inline const_e_iterator static inline const_e_iterator
pref_begin(const_node_pointer p_nd); pref_begin(const_node_pointer);
static inline const_e_iterator static inline const_e_iterator
pref_end(const_node_pointer p_nd); pref_end(const_node_pointer);
inline node_pointer inline node_pointer
find_imp(const_key_reference r_key); find_imp(const_key_reference);
inline node_pointer inline node_pointer
lower_bound_imp(const_key_reference r_key); lower_bound_imp(const_key_reference);
inline node_pointer inline node_pointer
upper_bound_imp(const_key_reference r_key); upper_bound_imp(const_key_reference);
inline static const_leaf_pointer inline static const_leaf_pointer
leftmost_descendant(const_node_pointer p_nd); leftmost_descendant(const_node_pointer);
inline static leaf_pointer inline static leaf_pointer
leftmost_descendant(node_pointer p_nd); leftmost_descendant(node_pointer);
inline static const_leaf_pointer inline static const_leaf_pointer
rightmost_descendant(const_node_pointer p_nd); rightmost_descendant(const_node_pointer);
inline static leaf_pointer inline static leaf_pointer
rightmost_descendant(node_pointer p_nd); rightmost_descendant(node_pointer);
#ifdef _GLIBCXX_DEBUG #ifdef _GLIBCXX_DEBUG
void void
@ -564,45 +464,39 @@ namespace pb_ds
assert_reverse_iterators() const; assert_reverse_iterators() const;
static size_type static size_type
recursive_count_leafs(const_node_pointer p_nd); recursive_count_leafs(const_node_pointer);
#endif #endif
#ifdef PB_DS_PAT_TRIE_TRACE_ #ifdef PB_DS_PAT_TRIE_TRACE_
static void static void
trace_node(const_node_pointer p_nd, size_type level); trace_node(const_node_pointer, size_type);
template<typename Metadata_> template<typename Metadata_>
static void static void
trace_node_metadata(const_node_pointer p_nd, type_to_type<Metadata_>); trace_node_metadata(const_node_pointer, type_to_type<Metadata_>);
static void static void
trace_node_metadata(const_node_pointer, trace_node_metadata(const_node_pointer, type_to_type<null_node_metadata>);
type_to_type<null_node_metadata>);
#endif #endif
leaf_pointer leaf_pointer
split_prep(const_key_reference r_key, PB_DS_CLASS_C_DEC& other, split_prep(const_key_reference, PB_DS_CLASS_C_DEC&,
split_join_branch_bag& r_bag); split_join_branch_bag&);
node_pointer node_pointer
rec_split(node_pointer p_nd, const_e_iterator b_it, rec_split(node_pointer, const_e_iterator, const_e_iterator,
const_e_iterator e_it, PB_DS_CLASS_C_DEC& other, PB_DS_CLASS_C_DEC&, split_join_branch_bag&);
split_join_branch_bag& r_bag);
void void
split_insert_branch(size_type e_ind, const_e_iterator b_it, split_insert_branch(size_type, const_e_iterator,
typename internal_node::iterator child_b_it, typename internal_node::iterator,
size_type num_children, split_join_branch_bag&); size_type, split_join_branch_bag&);
private:
static head_allocator s_head_allocator; static head_allocator s_head_allocator;
static internal_node_allocator s_internal_node_allocator; static internal_node_allocator s_internal_node_allocator;
static leaf_allocator s_leaf_allocator; static leaf_allocator s_leaf_allocator;
head_pointer m_p_head; head_pointer m_p_head;
size_type m_size; size_type m_size;
}; };
@ -623,11 +517,9 @@ namespace pb_ds
#undef PB_DS_CLASS_NAME #undef PB_DS_CLASS_NAME
#undef PB_DS_TYPES_TRAITS_C_DEC #undef PB_DS_TYPES_TRAITS_C_DEC
#undef PB_DS_MAP_DEBUG_BASE_C_DEC #undef PB_DS_MAP_DEBUG_BASE_C_DEC
#undef PB_DS_V2F #undef PB_DS_V2F
#undef PB_DS_EP2VP #undef PB_DS_EP2VP
#undef PB_DS_V2S #undef PB_DS_V2S
#undef PB_DS_STATIC_ASSERT #undef PB_DS_STATIC_ASSERT
} // namespace detail } // namespace detail

View File

@ -164,7 +164,7 @@ namespace pb_ds
operator=(const PB_DS_CONST_IT_C_DEC& other) operator=(const PB_DS_CONST_IT_C_DEC& other)
{ {
m_p_nd = other.m_p_nd; m_p_nd = other.m_p_nd;
return (*this); return *this;
} }
inline inline
@ -172,52 +172,44 @@ namespace pb_ds
operator=(const PB_DS_CONST_ODIR_IT_C_DEC& other) operator=(const PB_DS_CONST_ODIR_IT_C_DEC& other)
{ {
m_p_nd = other.m_p_nd; m_p_nd = other.m_p_nd;
return (*this); return *this;
} }
inline const_pointer inline const_pointer
operator->() const operator->() const
{ {
_GLIBCXX_DEBUG_ASSERT(m_p_nd->m_type == pat_trie_leaf_node_type); _GLIBCXX_DEBUG_ASSERT(m_p_nd->m_type == pat_trie_leaf_node_type);
return (&static_cast<leaf_pointer>(m_p_nd)->value()); return &static_cast<leaf_pointer>(m_p_nd)->value();
} }
inline const_reference inline const_reference
operator*() const operator*() const
{ {
_GLIBCXX_DEBUG_ASSERT(m_p_nd->m_type == pat_trie_leaf_node_type); _GLIBCXX_DEBUG_ASSERT(m_p_nd->m_type == pat_trie_leaf_node_type);
return (static_cast<leaf_pointer>(m_p_nd)->value()); return static_cast<leaf_pointer>(m_p_nd)->value();
} }
inline bool inline bool
operator==(const PB_DS_CONST_IT_C_DEC& other) const operator==(const PB_DS_CONST_IT_C_DEC& other) const
{ { return (m_p_nd == other.m_p_nd); }
return (m_p_nd == other.m_p_nd);
}
inline bool inline bool
operator==(const PB_DS_CONST_ODIR_IT_C_DEC& other) const operator==(const PB_DS_CONST_ODIR_IT_C_DEC& other) const
{ { return (m_p_nd == other.m_p_nd); }
return (m_p_nd == other.m_p_nd);
}
inline bool inline bool
operator!=(const PB_DS_CONST_IT_C_DEC& other) const operator!=(const PB_DS_CONST_IT_C_DEC& other) const
{ { return (m_p_nd != other.m_p_nd); }
return (m_p_nd != other.m_p_nd);
}
inline bool inline bool
operator!=(const PB_DS_CONST_ODIR_IT_C_DEC& other) const operator!=(const PB_DS_CONST_ODIR_IT_C_DEC& other) const
{ { return (m_p_nd != other.m_p_nd); }
return (m_p_nd != other.m_p_nd);
}
inline PB_DS_CONST_IT_C_DEC& inline PB_DS_CONST_IT_C_DEC&
operator++() operator++()
{ {
inc(integral_constant<int,Is_Forward_Iterator>()); inc(integral_constant<int,Is_Forward_Iterator>());
return (*this); return *this;
} }
inline PB_DS_CONST_IT_C_DEC inline PB_DS_CONST_IT_C_DEC
@ -225,14 +217,14 @@ namespace pb_ds
{ {
PB_DS_CONST_IT_C_DEC ret_it(m_p_nd); PB_DS_CONST_IT_C_DEC ret_it(m_p_nd);
operator++(); operator++();
return (ret_it); return ret_it;
} }
inline PB_DS_CONST_IT_C_DEC& inline PB_DS_CONST_IT_C_DEC&
operator--() operator--()
{ {
dec(integral_constant<int,Is_Forward_Iterator>()); dec(integral_constant<int,Is_Forward_Iterator>());
return (*this); return *this;
} }
inline PB_DS_CONST_IT_C_DEC inline PB_DS_CONST_IT_C_DEC
@ -240,7 +232,7 @@ namespace pb_ds
{ {
PB_DS_CONST_IT_C_DEC ret_it(m_p_nd); PB_DS_CONST_IT_C_DEC ret_it(m_p_nd);
operator--(); operator--();
return (ret_it); return ret_it;
} }
protected: protected:
@ -345,17 +337,16 @@ namespace pb_ds
leftmost_descendant(node_pointer p_nd) leftmost_descendant(node_pointer p_nd)
{ {
if (p_nd->m_type == pat_trie_leaf_node_type) if (p_nd->m_type == pat_trie_leaf_node_type)
return (static_cast<leaf_pointer>(p_nd)); return static_cast<leaf_pointer>(p_nd);
return static_cast<internal_node_pointer>(p_nd)->leftmost_descendant();
return (static_cast<internal_node_pointer>(p_nd)->leftmost_descendant());
} }
inline static leaf_pointer inline static leaf_pointer
rightmost_descendant(node_pointer p_nd) rightmost_descendant(node_pointer p_nd)
{ {
if (p_nd->m_type == pat_trie_leaf_node_type) if (p_nd->m_type == pat_trie_leaf_node_type)
return (static_cast<leaf_pointer>(p_nd)); return static_cast<leaf_pointer>(p_nd);
return (static_cast<internal_node_pointer>(p_nd)->rightmost_descendant()); return static_cast<internal_node_pointer>(p_nd)->rightmost_descendant();
} }
public: public:
@ -374,7 +365,6 @@ namespace pb_ds
public PB_DS_CONST_IT_C_DEC public PB_DS_CONST_IT_C_DEC
{ {
private: private:
typedef typedef
typename Allocator::template rebind< typename Allocator::template rebind<
@ -412,8 +402,6 @@ namespace pb_ds
typedef typename Type_Traits::reference reference; typedef typename Type_Traits::reference reference;
public:
inline inline
pat_trie_it_(node_pointer p_nd = NULL) : PB_DS_CONST_IT_C_DEC((node_pointer)p_nd) pat_trie_it_(node_pointer p_nd = NULL) : PB_DS_CONST_IT_C_DEC((node_pointer)p_nd)
{ } { }
@ -427,7 +415,7 @@ namespace pb_ds
operator=(const PB_DS_IT_C_DEC& other) operator=(const PB_DS_IT_C_DEC& other)
{ {
base_it_type::m_p_nd = other.m_p_nd; base_it_type::m_p_nd = other.m_p_nd;
return (*this); return *this;
} }
inline inline
@ -435,23 +423,22 @@ namespace pb_ds
operator=(const PB_DS_ODIR_IT_C_DEC& other) operator=(const PB_DS_ODIR_IT_C_DEC& other)
{ {
base_it_type::m_p_nd = other.m_p_nd; base_it_type::m_p_nd = other.m_p_nd;
return (*this); return *this;
} }
inline pointer inline pointer
operator->() const operator->() const
{ {
_GLIBCXX_DEBUG_ASSERT(base_it_type::m_p_nd->m_type == _GLIBCXX_DEBUG_ASSERT(base_it_type::m_p_nd->m_type == pat_trie_leaf_node_type);
pat_trie_leaf_node_type);
return (&static_cast<leaf_pointer>(base_it_type::m_p_nd)->value()); return &static_cast<leaf_pointer>(base_it_type::m_p_nd)->value();
} }
inline reference inline reference
operator*() const operator*() const
{ {
_GLIBCXX_DEBUG_ASSERT(base_it_type::m_p_nd->m_type == pat_trie_leaf_node_type); _GLIBCXX_DEBUG_ASSERT(base_it_type::m_p_nd->m_type == pat_trie_leaf_node_type);
return (static_cast<leaf_pointer>(base_it_type::m_p_nd)->value()); return static_cast<leaf_pointer>(base_it_type::m_p_nd)->value();
} }
inline PB_DS_IT_C_DEC& inline PB_DS_IT_C_DEC&
@ -459,7 +446,7 @@ namespace pb_ds
{ {
PB_DS_CONST_IT_C_DEC:: PB_DS_CONST_IT_C_DEC::
operator++(); operator++();
return (*this); return *this;
} }
inline PB_DS_IT_C_DEC inline PB_DS_IT_C_DEC
@ -467,14 +454,14 @@ namespace pb_ds
{ {
PB_DS_IT_C_DEC ret_it(base_it_type::m_p_nd); PB_DS_IT_C_DEC ret_it(base_it_type::m_p_nd);
operator++(); operator++();
return (ret_it); return ret_it;
} }
inline PB_DS_IT_C_DEC& inline PB_DS_IT_C_DEC&
operator--() operator--()
{ {
PB_DS_CONST_IT_C_DEC::operator--(); PB_DS_CONST_IT_C_DEC::operator--();
return (*this); return *this;
} }
inline PB_DS_IT_C_DEC inline PB_DS_IT_C_DEC
@ -482,7 +469,7 @@ namespace pb_ds
{ {
PB_DS_IT_C_DEC ret_it(base_it_type::m_p_nd); PB_DS_IT_C_DEC ret_it(base_it_type::m_p_nd);
operator--(); operator--();
return (ret_it); return ret_it;
} }
protected: protected:

View File

@ -48,30 +48,22 @@ PB_DS_CLASS_T_DEC
typename PB_DS_CLASS_C_DEC::e_access_traits& typename PB_DS_CLASS_C_DEC::e_access_traits&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_e_access_traits() get_e_access_traits()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const typename PB_DS_CLASS_C_DEC::e_access_traits& const typename PB_DS_CLASS_C_DEC::e_access_traits&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_e_access_traits() const get_e_access_traits() const
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
typename PB_DS_CLASS_C_DEC::node_update& typename PB_DS_CLASS_C_DEC::node_update&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_node_update() get_node_update()
{ { return *this; }
return (*this);
}
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
const typename PB_DS_CLASS_C_DEC::node_update& const typename PB_DS_CLASS_C_DEC::node_update&
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
get_node_update() const get_node_update() const
{ { return *this; }
return (*this);
}

View File

@ -60,7 +60,6 @@ public:
add_branch() add_branch()
{ {
internal_node_pointer p_nd = s_internal_node_allocator.allocate(1); internal_node_pointer p_nd = s_internal_node_allocator.allocate(1);
try try
{ {
m_bag.push_back(p_nd); m_bag.push_back(p_nd);
@ -68,7 +67,6 @@ public:
catch(...) catch(...)
{ {
s_internal_node_allocator.deallocate(p_nd, 1); s_internal_node_allocator.deallocate(p_nd, 1);
throw; throw;
} }
} }
@ -77,12 +75,9 @@ public:
get_branch() get_branch()
{ {
_GLIBCXX_DEBUG_ASSERT(!m_bag.empty()); _GLIBCXX_DEBUG_ASSERT(!m_bag.empty());
internal_node_pointer p_nd =* m_bag.begin(); internal_node_pointer p_nd =* m_bag.begin();
m_bag.pop_front(); m_bag.pop_front();
return p_nd;
return (p_nd);
} }
~split_join_branch_bag() ~split_join_branch_bag()
@ -90,18 +85,14 @@ public:
while (!m_bag.empty()) while (!m_bag.empty())
{ {
internal_node_pointer p_nd =* m_bag.begin(); internal_node_pointer p_nd =* m_bag.begin();
s_internal_node_allocator.deallocate(p_nd, 1); s_internal_node_allocator.deallocate(p_nd, 1);
m_bag.pop_front(); m_bag.pop_front();
} }
} }
inline bool inline bool
empty() const empty() const
{ { return m_bag.empty(); }
return (m_bag.empty());
}
private: private:
bag_t m_bag; bag_t m_bag;

View File

@ -52,12 +52,9 @@ PB_DS_CLASS_C_DEC::
trace() const trace() const
{ {
std::cerr << std::endl; std::cerr << std::endl;
if (m_p_head->m_p_parent == NULL) if (m_p_head->m_p_parent == NULL)
return; return;
trace_node(m_p_head->m_p_parent, 0); trace_node(m_p_head->m_p_parent, 0);
std::cerr << std::endl; std::cerr << std::endl;
} }
@ -68,29 +65,20 @@ trace_node(const_node_pointer p_nd, size_type level)
{ {
for (size_type i = 0; i < level; ++i) for (size_type i = 0; i < level; ++i)
std::cerr << ' '; std::cerr << ' ';
std::cerr << p_nd << " "; std::cerr << p_nd << " ";
std::cerr << ((p_nd->m_type == pat_trie_leaf_node_type) ? "l " : "i ");
std::cerr << ((p_nd->m_type == pat_trie_leaf_node_type)?
"l " :
"i ");
trace_node_metadata(p_nd, type_to_type<typename node::metadata_type>()); trace_node_metadata(p_nd, type_to_type<typename node::metadata_type>());
typename e_access_traits::const_iterator el_it = pref_begin(p_nd);
typename e_access_traits::const_iterator el_it =
pref_begin(p_nd);
while (el_it != pref_end(p_nd)) while (el_it != pref_end(p_nd))
{ {
std::cerr <<* el_it; std::cerr <<* el_it;
++el_it; ++el_it;
} }
if (p_nd->m_type == pat_trie_leaf_node_type) if (p_nd->m_type == pat_trie_leaf_node_type)
{ {
std::cerr << std::endl; std::cerr << std::endl;
return; return;
} }
@ -100,8 +88,7 @@ trace_node(const_node_pointer p_nd, size_type level)
std::cerr << " " << std::cerr << " " <<
static_cast<unsigned long>(p_internal->get_e_ind()) << std::endl; static_cast<unsigned long>(p_internal->get_e_ind()) << std::endl;
const size_type num_children = std::distance( const size_type num_children = std::distance(p_internal->begin(),
p_internal->begin(),
p_internal->end()); p_internal->end());
for (size_type child_i = 0; child_i < num_children; ++child_i) for (size_type child_i = 0; child_i < num_children; ++child_i)
@ -109,7 +96,6 @@ trace_node(const_node_pointer p_nd, size_type level)
typename internal_node::const_iterator child_it = typename internal_node::const_iterator child_it =
p_internal->begin(); p_internal->begin();
std::advance(child_it, num_children - child_i - 1); std::advance(child_it, num_children - child_i - 1);
trace_node(*child_it, level + 1); trace_node(*child_it, level + 1);
} }
} }
@ -120,8 +106,7 @@ void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
trace_node_metadata(const_node_pointer p_nd, type_to_type<Metadata_>) trace_node_metadata(const_node_pointer p_nd, type_to_type<Metadata_>)
{ {
std::cerr << "(" << std::cerr << "(" << static_cast<unsigned long>(p_nd->get_metadata()) << ") ";
static_cast<unsigned long>(p_nd->get_metadata()) << ") ";
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -130,5 +115,5 @@ PB_DS_CLASS_C_DEC::
trace_node_metadata(const_node_pointer, type_to_type<null_node_metadata>) trace_node_metadata(const_node_pointer, type_to_type<null_node_metadata>)
{ } { }
#endif // #ifdef PB_DS_PAT_TRIE_TRACE_ #endif

View File

@ -56,7 +56,6 @@ inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
apply_update(node_pointer p_nd, Node_Update_* /*p_update*/) apply_update(node_pointer p_nd, Node_Update_* /*p_update*/)
{ {
Node_Update_::operator()( Node_Update_::operator()(node_iterator(p_nd, this),
node_iterator(p_nd, this), const_node_iterator(NULL, this));
const_node_iterator(NULL, this));
} }

View File

@ -59,39 +59,35 @@ PB_DS_CLASS_C_DEC::
PB_DS_CLASS_NAME() PB_DS_CLASS_NAME()
{ {
initialize(); initialize();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn) : PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn) :
PB_DS_BASE_C_DEC(r_cmp_fn) base_type(r_cmp_fn)
{ {
initialize(); initialize();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn, const node_update& r_node_update) : PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn, const node_update& r_node_update) :
PB_DS_BASE_C_DEC(r_cmp_fn, r_node_update) base_type(r_cmp_fn, r_node_update)
{ {
initialize(); initialize();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC& other) : PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC& other) :
PB_DS_BASE_C_DEC(other) base_type(other)
{ {
initialize(); initialize();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
@ -99,16 +95,12 @@ PB_DS_CLASS_C_DEC::
swap(PB_DS_CLASS_C_DEC& other) swap(PB_DS_CLASS_C_DEC& other)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
base_type::swap(other);
PB_DS_BASE_C_DEC::swap(other);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
initialize() initialize()
{ { base_type::m_p_head->m_red = true; }
PB_DS_BASE_C_DEC::m_p_head->m_red = true;
}

View File

@ -52,7 +52,7 @@ PB_DS_CLASS_C_DEC::
assert_node_consistent(const node_pointer p_nd) const assert_node_consistent(const node_pointer p_nd) const
{ {
if (p_nd == NULL) if (p_nd == NULL)
return (1); return 1;
const size_type l_height = assert_node_consistent(p_nd->m_p_left); const size_type l_height = assert_node_consistent(p_nd->m_p_left);
const size_type r_height = assert_node_consistent(p_nd->m_p_right); const size_type r_height = assert_node_consistent(p_nd->m_p_right);
@ -62,7 +62,7 @@ assert_node_consistent(const node_pointer p_nd) const
_GLIBCXX_DEBUG_ASSERT(is_effectively_black(p_nd->m_p_right)); _GLIBCXX_DEBUG_ASSERT(is_effectively_black(p_nd->m_p_right));
} }
_GLIBCXX_DEBUG_ASSERT(l_height == r_height); _GLIBCXX_DEBUG_ASSERT(l_height == r_height);
return ((p_nd->m_red? 0 : 1) + l_height); return (p_nd->m_red ? 0 : 1) + l_height;
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -70,8 +70,8 @@ void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
assert_valid() const assert_valid() const
{ {
PB_DS_BASE_C_DEC::assert_valid(); base_type::assert_valid();
const node_pointer p_head = PB_DS_BASE_C_DEC::m_p_head; const node_pointer p_head = base_type::m_p_head;
_GLIBCXX_DEBUG_ASSERT(p_head->m_red); _GLIBCXX_DEBUG_ASSERT(p_head->m_red);
if (p_head->m_p_parent != NULL) if (p_head->m_p_parent != NULL)
{ {

View File

@ -50,13 +50,10 @@ PB_DS_CLASS_C_DEC::
erase(const_key_reference r_key) erase(const_key_reference r_key)
{ {
point_iterator it = find(r_key); point_iterator it = find(r_key);
if (it == base_type::end())
if (it == PB_DS_BASE_C_DEC::end()) return false;
return (false);
erase(it); erase(it);
return true;
return (true);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -65,19 +62,14 @@ PB_DS_CLASS_C_DEC::
erase(iterator it) erase(iterator it)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
if (it == base_type::end())
if (it == PB_DS_BASE_C_DEC::end()) return it;
return (it);
iterator ret_it = it; iterator ret_it = it;
++ret_it; ++ret_it;
erase_node(it.m_p_nd); erase_node(it.m_p_nd);
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
return ret_it;
return (ret_it);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -86,19 +78,14 @@ PB_DS_CLASS_C_DEC::
erase(reverse_iterator it) erase(reverse_iterator it)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
if (it.m_p_nd == base_type::m_p_head)
if (it.m_p_nd == PB_DS_BASE_C_DEC::m_p_head) return it;
return (it);
reverse_iterator ret_it = it; reverse_iterator ret_it = it;
++ret_it; ++ret_it;
erase_node(it.m_p_nd); erase_node(it.m_p_nd);
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
return ret_it;
return (ret_it);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -108,17 +95,13 @@ PB_DS_CLASS_C_DEC::
erase_if(Pred pred) erase_if(Pred pred)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
size_type num_ersd = 0;
size_type num_ersd = 0; iterator it = base_type::begin();
while (it != base_type::end())
iterator it = PB_DS_BASE_C_DEC::begin();
while (it != PB_DS_BASE_C_DEC::end())
{ {
if (pred(*it)) if (pred(*it))
{ {
++num_ersd; ++num_ersd;
it = erase(it); it = erase(it);
} }
else else
@ -126,8 +109,7 @@ erase_if(Pred pred)
} }
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return num_ersd;
return (num_ersd);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -136,9 +118,7 @@ PB_DS_CLASS_C_DEC::
erase_node(node_pointer p_nd) erase_node(node_pointer p_nd)
{ {
remove_node(p_nd); remove_node(p_nd);
base_type::actual_erase_node(p_nd);
PB_DS_BASE_C_DEC::actual_erase_node(p_nd);
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
} }
@ -148,11 +128,8 @@ PB_DS_CLASS_C_DEC::
remove_node(node_pointer p_z) remove_node(node_pointer p_z)
{ {
update_min_max_for_erased_node(p_z); update_min_max_for_erased_node(p_z);
node_pointer p_y = p_z; node_pointer p_y = p_z;
node_pointer p_x = NULL; node_pointer p_x = NULL;
node_pointer p_new_x_parent = NULL; node_pointer p_new_x_parent = NULL;
if (p_y->m_p_left == NULL) if (p_y->m_p_left == NULL)
@ -162,68 +139,55 @@ remove_node(node_pointer p_z)
else else
{ {
p_y = p_y->m_p_right; p_y = p_y->m_p_right;
while (p_y->m_p_left != NULL) while (p_y->m_p_left != NULL)
p_y = p_y->m_p_left; p_y = p_y->m_p_left;
p_x = p_y->m_p_right; p_x = p_y->m_p_right;
} }
if (p_y == p_z) if (p_y == p_z)
{ {
p_new_x_parent = p_y->m_p_parent; p_new_x_parent = p_y->m_p_parent;
if (p_x != NULL) if (p_x != NULL)
p_x->m_p_parent = p_y->m_p_parent; p_x->m_p_parent = p_y->m_p_parent;
if (PB_DS_BASE_C_DEC::m_p_head->m_p_parent == p_z) if (base_type::m_p_head->m_p_parent == p_z)
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = p_x; base_type::m_p_head->m_p_parent = p_x;
else if (p_z->m_p_parent->m_p_left == p_z) else if (p_z->m_p_parent->m_p_left == p_z)
{ {
p_y->m_p_left = p_z->m_p_parent; p_y->m_p_left = p_z->m_p_parent;
p_z->m_p_parent->m_p_left = p_x; p_z->m_p_parent->m_p_left = p_x;
} }
else else
{ {
p_y->m_p_left = NULL; p_y->m_p_left = NULL;
p_z->m_p_parent->m_p_right = p_x; p_z->m_p_parent->m_p_right = p_x;
} }
} }
else else
{ {
p_z->m_p_left->m_p_parent = p_y; p_z->m_p_left->m_p_parent = p_y;
p_y->m_p_left = p_z->m_p_left; p_y->m_p_left = p_z->m_p_left;
if (p_y != p_z->m_p_right) if (p_y != p_z->m_p_right)
{ {
p_new_x_parent = p_y->m_p_parent; p_new_x_parent = p_y->m_p_parent;
if (p_x != NULL) if (p_x != NULL)
p_x->m_p_parent = p_y->m_p_parent; p_x->m_p_parent = p_y->m_p_parent;
p_y->m_p_parent->m_p_left = p_x; p_y->m_p_parent->m_p_left = p_x;
p_y->m_p_right = p_z->m_p_right; p_y->m_p_right = p_z->m_p_right;
p_z->m_p_right->m_p_parent = p_y; p_z->m_p_right->m_p_parent = p_y;
} }
else else
p_new_x_parent = p_y; p_new_x_parent = p_y;
if (PB_DS_BASE_C_DEC::m_p_head->m_p_parent == p_z) if (base_type::m_p_head->m_p_parent == p_z)
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = p_y; base_type::m_p_head->m_p_parent = p_y;
else if (p_z->m_p_parent->m_p_left == p_z) else if (p_z->m_p_parent->m_p_left == p_z)
p_z->m_p_parent->m_p_left = p_y; p_z->m_p_parent->m_p_left = p_y;
else else
p_z->m_p_parent->m_p_right = p_y; p_z->m_p_parent->m_p_right = p_y;
p_y->m_p_parent = p_z->m_p_parent; p_y->m_p_parent = p_z->m_p_parent;
std::swap(p_y->m_red, p_z->m_red); std::swap(p_y->m_red, p_z->m_red);
p_y = p_z; p_y = p_z;
} }
@ -242,30 +206,23 @@ remove_fixup(node_pointer p_x, node_pointer p_new_x_parent)
{ {
_GLIBCXX_DEBUG_ASSERT(p_x == NULL || p_x->m_p_parent == p_new_x_parent); _GLIBCXX_DEBUG_ASSERT(p_x == NULL || p_x->m_p_parent == p_new_x_parent);
while (p_x != PB_DS_BASE_C_DEC::m_p_head->m_p_parent&& while (p_x != base_type::m_p_head->m_p_parent && is_effectively_black(p_x))
is_effectively_black(p_x))
if (p_x == p_new_x_parent->m_p_left) if (p_x == p_new_x_parent->m_p_left)
{ {
node_pointer p_w = p_new_x_parent->m_p_right; node_pointer p_w = p_new_x_parent->m_p_right;
if (p_w->m_red) if (p_w->m_red)
{ {
p_w->m_red = false; p_w->m_red = false;
p_new_x_parent->m_red = true; p_new_x_parent->m_red = true;
base_type::rotate_left(p_new_x_parent);
PB_DS_BASE_C_DEC::rotate_left(p_new_x_parent);
p_w = p_new_x_parent->m_p_right; p_w = p_new_x_parent->m_p_right;
} }
if (is_effectively_black(p_w->m_p_left)&& if (is_effectively_black(p_w->m_p_left)
is_effectively_black(p_w->m_p_right)) && is_effectively_black(p_w->m_p_right))
{ {
p_w->m_red = true; p_w->m_red = true;
p_x = p_new_x_parent; p_x = p_new_x_parent;
p_new_x_parent = p_new_x_parent->m_p_parent; p_new_x_parent = p_new_x_parent->m_p_parent;
} }
else else
@ -276,48 +233,37 @@ remove_fixup(node_pointer p_x, node_pointer p_new_x_parent)
p_w->m_p_left->m_red = false; p_w->m_p_left->m_red = false;
p_w->m_red = true; p_w->m_red = true;
base_type::rotate_right(p_w);
PB_DS_BASE_C_DEC::rotate_right(p_w);
p_w = p_new_x_parent->m_p_right; p_w = p_new_x_parent->m_p_right;
} }
p_w->m_red = p_new_x_parent->m_red; p_w->m_red = p_new_x_parent->m_red;
p_new_x_parent->m_red = false; p_new_x_parent->m_red = false;
if (p_w->m_p_right != NULL) if (p_w->m_p_right != NULL)
p_w->m_p_right->m_red = false; p_w->m_p_right->m_red = false;
PB_DS_BASE_C_DEC::rotate_left(p_new_x_parent); base_type::rotate_left(p_new_x_parent);
update_to_top(p_new_x_parent, (node_update* )this); update_to_top(p_new_x_parent, (node_update* )this);
break; break;
} }
} }
else else
{ {
node_pointer p_w = p_new_x_parent->m_p_left; node_pointer p_w = p_new_x_parent->m_p_left;
if (p_w->m_red == true) if (p_w->m_red == true)
{ {
p_w->m_red = false; p_w->m_red = false;
p_new_x_parent->m_red = true; p_new_x_parent->m_red = true;
base_type::rotate_right(p_new_x_parent);
PB_DS_BASE_C_DEC::rotate_right(p_new_x_parent);
p_w = p_new_x_parent->m_p_left; p_w = p_new_x_parent->m_p_left;
} }
if (is_effectively_black(p_w->m_p_right)&& if (is_effectively_black(p_w->m_p_right)
is_effectively_black(p_w->m_p_left)) && is_effectively_black(p_w->m_p_left))
{ {
p_w->m_red = true; p_w->m_red = true;
p_x = p_new_x_parent; p_x = p_new_x_parent;
p_new_x_parent = p_new_x_parent->m_p_parent; p_new_x_parent = p_new_x_parent->m_p_parent;
} }
else else
@ -328,23 +274,18 @@ remove_fixup(node_pointer p_x, node_pointer p_new_x_parent)
p_w->m_p_right->m_red = false; p_w->m_p_right->m_red = false;
p_w->m_red = true; p_w->m_red = true;
base_type::rotate_left(p_w);
PB_DS_BASE_C_DEC::rotate_left(p_w);
p_w = p_new_x_parent->m_p_left; p_w = p_new_x_parent->m_p_left;
} }
p_w->m_red = p_new_x_parent->m_red; p_w->m_red = p_new_x_parent->m_red;
p_new_x_parent->m_red = false; p_new_x_parent->m_red = false;
if (p_w->m_p_left != NULL) if (p_w->m_p_left != NULL)
p_w->m_p_left->m_red = false; p_w->m_p_left->m_red = false;
PB_DS_BASE_C_DEC::rotate_right(p_new_x_parent); base_type::rotate_right(p_new_x_parent);
update_to_top(p_new_x_parent, (node_update* )this); update_to_top(p_new_x_parent, (node_update* )this);
break; break;
} }
} }

View File

@ -48,7 +48,5 @@ PB_DS_CLASS_T_DEC
inline bool inline bool
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
is_effectively_black(const node_pointer p_nd) is_effectively_black(const node_pointer p_nd)
{ { return (p_nd == NULL || !p_nd->m_red); }
return (p_nd == NULL || !p_nd->m_red);
}

View File

@ -50,22 +50,16 @@ PB_DS_CLASS_C_DEC::
insert(const_reference r_value) insert(const_reference r_value)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
std::pair<point_iterator, bool> ins_pair = base_type::insert_leaf(r_value);
std::pair<point_iterator, bool> ins_pair =
PB_DS_BASE_C_DEC::insert_leaf(r_value);
if (ins_pair.second == true) if (ins_pair.second == true)
{ {
ins_pair.first.m_p_nd->m_red = true; ins_pair.first.m_p_nd->m_red = true;
_GLIBCXX_DEBUG_ONLY(this->structure_only_assert_valid();) _GLIBCXX_DEBUG_ONLY(this->structure_only_assert_valid();)
insert_fixup(ins_pair.first.m_p_nd);
insert_fixup(ins_pair.first.m_p_nd);
} }
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return ins_pair;
return (ins_pair);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -74,22 +68,16 @@ PB_DS_CLASS_C_DEC::
insert_fixup(node_pointer p_nd) insert_fixup(node_pointer p_nd)
{ {
_GLIBCXX_DEBUG_ASSERT(p_nd->m_red == true); _GLIBCXX_DEBUG_ASSERT(p_nd->m_red == true);
while (p_nd != base_type::m_p_head->m_p_parent && p_nd->m_p_parent->m_red)
while (p_nd != PB_DS_BASE_C_DEC::m_p_head->m_p_parent&&
p_nd->m_p_parent->m_red)
{ {
if (p_nd->m_p_parent == p_nd->m_p_parent->m_p_parent->m_p_left) if (p_nd->m_p_parent == p_nd->m_p_parent->m_p_parent->m_p_left)
{ {
node_pointer p_y = p_nd->m_p_parent->m_p_parent->m_p_right; node_pointer p_y = p_nd->m_p_parent->m_p_parent->m_p_right;
if (p_y != NULL && p_y->m_red)
if (p_y != NULL&& p_y->m_red)
{ {
p_nd->m_p_parent->m_red = false; p_nd->m_p_parent->m_red = false;
p_y->m_red = false; p_y->m_red = false;
p_nd->m_p_parent->m_p_parent->m_red = true; p_nd->m_p_parent->m_p_parent->m_red = true;
p_nd = p_nd->m_p_parent->m_p_parent; p_nd = p_nd->m_p_parent->m_p_parent;
} }
else else
@ -97,30 +85,21 @@ insert_fixup(node_pointer p_nd)
if (p_nd == p_nd->m_p_parent->m_p_right) if (p_nd == p_nd->m_p_parent->m_p_right)
{ {
p_nd = p_nd->m_p_parent; p_nd = p_nd->m_p_parent;
base_type::rotate_left(p_nd);
PB_DS_BASE_C_DEC::rotate_left(p_nd);
} }
p_nd->m_p_parent->m_red = false; p_nd->m_p_parent->m_red = false;
p_nd->m_p_parent->m_p_parent->m_red = true; p_nd->m_p_parent->m_p_parent->m_red = true;
base_type::rotate_right(p_nd->m_p_parent->m_p_parent);
PB_DS_BASE_C_DEC::rotate_right(
p_nd->m_p_parent->m_p_parent);
} }
} }
else else
{ {
node_pointer p_y = p_nd->m_p_parent->m_p_parent->m_p_left; node_pointer p_y = p_nd->m_p_parent->m_p_parent->m_p_left;
if (p_y != NULL && p_y->m_red)
if (p_y != NULL&& p_y->m_red)
{ {
p_nd->m_p_parent->m_red = false; p_nd->m_p_parent->m_red = false;
p_y->m_red = false; p_y->m_red = false;
p_nd->m_p_parent->m_p_parent->m_red = true; p_nd->m_p_parent->m_p_parent->m_red = true;
p_nd = p_nd->m_p_parent->m_p_parent; p_nd = p_nd->m_p_parent->m_p_parent;
} }
else else
@ -128,21 +107,15 @@ insert_fixup(node_pointer p_nd)
if (p_nd == p_nd->m_p_parent->m_p_left) if (p_nd == p_nd->m_p_parent->m_p_left)
{ {
p_nd = p_nd->m_p_parent; p_nd = p_nd->m_p_parent;
base_type::rotate_right(p_nd);
PB_DS_BASE_C_DEC::rotate_right(p_nd);
} }
p_nd->m_p_parent->m_red = false; p_nd->m_p_parent->m_red = false;
p_nd->m_p_parent->m_p_parent->m_red = true; p_nd->m_p_parent->m_p_parent->m_red = true;
base_type::rotate_left(p_nd->m_p_parent->m_p_parent);
PB_DS_BASE_C_DEC::rotate_left(
p_nd->m_p_parent->m_p_parent);
} }
} }
} }
PB_DS_BASE_C_DEC::update_to_top(p_nd, (node_update* )this); base_type::update_to_top(p_nd, (node_update* )this);
base_type::m_p_head->m_p_parent->m_red = false;
PB_DS_BASE_C_DEC::m_p_head->m_p_parent->m_red = false;
} }

View File

@ -53,11 +53,13 @@ namespace pb_ds
{ {
namespace detail namespace detail
{ {
template<typename Value_Type, class Metadata, class Allocator> template<typename Value_Type, class Metadata, class Allocator>
struct rb_tree_node_ struct rb_tree_node_
{ {
public: public:
typedef Value_Type value_type;
typedef Metadata metadata_type;
typedef typedef
typename Allocator::template rebind< typename Allocator::template rebind<
rb_tree_node_< rb_tree_node_<
@ -66,10 +68,6 @@ namespace pb_ds
Allocator> >::other::pointer Allocator> >::other::pointer
node_pointer; node_pointer;
typedef Value_Type value_type;
typedef Metadata metadata_type;
typedef typedef
typename Allocator::template rebind< typename Allocator::template rebind<
metadata_type>::other::reference metadata_type>::other::reference
@ -80,55 +78,42 @@ namespace pb_ds
metadata_type>::other::const_reference metadata_type>::other::const_reference
const_metadata_reference; const_metadata_reference;
public:
inline bool inline bool
special() const special() const
{ { return m_red; }
return (m_red);
}
inline const_metadata_reference inline const_metadata_reference
get_metadata() const get_metadata() const
{ { return m_metadata; }
return (m_metadata);
}
inline metadata_reference inline metadata_reference
get_metadata() get_metadata()
{ { return m_metadata; }
return (m_metadata);
}
#ifdef PB_DS_BIN_SEARCH_TREE_TRACE_ #ifdef PB_DS_BIN_SEARCH_TREE_TRACE_
void void
trace() const trace() const
{ {
std::cout << PB_DS_V2F(m_value) <<(m_red? " <r> " : " <b> ") << std::cout << PB_DS_V2F(m_value) <<(m_red? " <r> " : " <b> ")
"(" << m_metadata << ")"; << "(" << m_metadata << ")";
} }
#endif // #ifdef PB_DS_BIN_SEARCH_TREE_TRACE_ #endif
public:
node_pointer m_p_left; node_pointer m_p_left;
node_pointer m_p_right; node_pointer m_p_right;
node_pointer m_p_parent; node_pointer m_p_parent;
value_type m_value; value_type m_value;
bool m_red; bool m_red;
metadata_type m_metadata; metadata_type m_metadata;
}; };
template<typename Value_Type, class Allocator> template<typename Value_Type, class Allocator>
struct rb_tree_node_< struct rb_tree_node_<Value_Type, null_node_metadata, Allocator>
Value_Type,
null_node_metadata,
Allocator>
{ {
public: public:
typedef Value_Type value_type;
typedef null_node_metadata metadata_type;
typedef typedef
typename Allocator::template rebind< typename Allocator::template rebind<
rb_tree_node_< rb_tree_node_<
@ -137,38 +122,23 @@ namespace pb_ds
Allocator> >::other::pointer Allocator> >::other::pointer
node_pointer; node_pointer;
typedef Value_Type value_type;
typedef null_node_metadata metadata_type;
public:
inline bool inline bool
special() const special() const
{ { return m_red; }
return (m_red);
}
#ifdef PB_DS_BIN_SEARCH_TREE_TRACE_ #ifdef PB_DS_BIN_SEARCH_TREE_TRACE_
void void
trace() const trace() const
{ { std::cout << PB_DS_V2F(m_value) <<(m_red? " <r> " : " <b> "); }
std::cout << PB_DS_V2F(m_value) <<(m_red? " <r> " : " <b> "); #endif
}
#endif // #ifdef PB_DS_BIN_SEARCH_TREE_TRACE_
public:
node_pointer m_p_left; node_pointer m_p_left;
node_pointer m_p_right; node_pointer m_p_right;
node_pointer m_p_parent; node_pointer m_p_parent;
value_type m_value; value_type m_value;
bool m_red; bool m_red;
}; };
} // namespace detail } // namespace detail
} // namespace pb_ds } // namespace pb_ds
#endif // #ifndef PB_DS_RB_TREE_NODE_HPP #endif

View File

@ -73,50 +73,31 @@ namespace pb_ds
{ {
namespace detail namespace detail
{ {
#define PB_DS_CLASS_T_DEC \
#define PB_DS_CLASS_T_DEC \ template<typename Key, typename Mapped, typename Cmp_Fn, \
template< \ typename Node_And_It_Traits, typename Allocator>
typename Key, \
typename Mapped, \
class Cmp_Fn, \
class Node_And_It_Traits, \
class Allocator>
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
#define PB_DS_CLASS_NAME \ #define PB_DS_CLASS_NAME rb_tree_data_
rb_tree_data_
#endif #endif
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
#define PB_DS_BASE_CLASS_NAME \ #define PB_DS_BASE_CLASS_NAME bin_search_tree_data_
bin_search_tree_data_
#endif #endif
#ifdef PB_DS_DATA_FALSE_INDICATOR #ifdef PB_DS_DATA_FALSE_INDICATOR
#define PB_DS_CLASS_NAME \ #define PB_DS_CLASS_NAME rb_tree_no_data_
rb_tree_no_data_
#endif #endif
#ifdef PB_DS_DATA_FALSE_INDICATOR #ifdef PB_DS_DATA_FALSE_INDICATOR
#define PB_DS_BASE_CLASS_NAME \ #define PB_DS_BASE_CLASS_NAME bin_search_tree_no_data_
bin_search_tree_no_data_
#endif #endif
#define PB_DS_CLASS_C_DEC \ #define PB_DS_CLASS_C_DEC \
PB_DS_CLASS_NAME< \ PB_DS_CLASS_NAME<Key, Mapped, Cmp_Fn, Node_And_It_Traits, Allocator>
Key, \
Mapped, \
Cmp_Fn, \
Node_And_It_Traits, \
Allocator>
#define PB_DS_BASE_C_DEC \ #define PB_DS_BASE_C_DEC \
PB_DS_BASE_CLASS_NAME< \ PB_DS_BASE_CLASS_NAME<Key, Mapped, Cmp_Fn, Node_And_It_Traits, Allocator>
Key, \
Mapped, \
Cmp_Fn, \
Node_And_It_Traits, \
Allocator>
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
#define PB_DS_V2F(X) (X).first #define PB_DS_V2F(X) (X).first
@ -132,96 +113,61 @@ namespace pb_ds
template<typename Key, template<typename Key,
typename Mapped, typename Mapped,
class Cmp_Fn, typename Cmp_Fn,
class Node_And_It_Traits, typename Node_And_It_Traits,
class Allocator> typename Allocator>
class PB_DS_CLASS_NAME : public PB_DS_BASE_C_DEC class PB_DS_CLASS_NAME : public PB_DS_BASE_C_DEC
{ {
private: private:
typedef typename PB_DS_BASE_C_DEC::node_pointer node_pointer; typedef PB_DS_BASE_C_DEC base_type;
typedef typename base_type::node_pointer node_pointer;
public: public:
typedef typename Allocator::size_type size_type;
typedef typename Allocator::difference_type difference_type;
typedef typename PB_DS_BASE_C_DEC::key_type key_type;
typedef typename PB_DS_BASE_C_DEC::key_pointer key_pointer;
typedef typename PB_DS_BASE_C_DEC::const_key_pointer const_key_pointer;
typedef typename PB_DS_BASE_C_DEC::key_reference key_reference;
typedef
typename PB_DS_BASE_C_DEC::const_key_reference
const_key_reference;
typedef typename PB_DS_BASE_C_DEC::mapped_type mapped_type;
typedef typename PB_DS_BASE_C_DEC::mapped_pointer mapped_pointer;
typedef
typename PB_DS_BASE_C_DEC::const_mapped_pointer
const_mapped_pointer;
typedef typename PB_DS_BASE_C_DEC::mapped_reference mapped_reference;
typedef
typename PB_DS_BASE_C_DEC::const_mapped_reference
const_mapped_reference;
typedef typename PB_DS_BASE_C_DEC::value_type value_type;
typedef typename PB_DS_BASE_C_DEC::pointer pointer;
typedef typename PB_DS_BASE_C_DEC::const_pointer const_pointer;
typedef typename PB_DS_BASE_C_DEC::reference reference;
typedef typename PB_DS_BASE_C_DEC::const_reference const_reference;
typedef typename PB_DS_BASE_C_DEC::point_iterator point_iterator;
typedef typename PB_DS_BASE_C_DEC::const_iterator const_point_iterator;
typedef typename PB_DS_BASE_C_DEC::iterator iterator;
typedef typename PB_DS_BASE_C_DEC::const_iterator const_iterator;
typedef typename PB_DS_BASE_C_DEC::reverse_iterator reverse_iterator;
typedef
typename PB_DS_BASE_C_DEC::const_reverse_iterator
const_reverse_iterator;
typedef Cmp_Fn cmp_fn; typedef Cmp_Fn cmp_fn;
typedef Allocator allocator; typedef Allocator allocator;
typedef typename Allocator::size_type size_type;
typedef typename Allocator::difference_type difference_type;
typedef typename base_type::key_type key_type;
typedef typename base_type::key_pointer key_pointer;
typedef typename base_type::const_key_pointer const_key_pointer;
typedef typename base_type::key_reference key_reference;
typedef typename base_type::const_key_reference const_key_reference;
typedef typename base_type::mapped_type mapped_type;
typedef typename base_type::mapped_pointer mapped_pointer;
typedef typename base_type::const_mapped_pointer const_mapped_pointer;
typedef typename base_type::mapped_reference mapped_reference;
typedef typename base_type::const_mapped_reference const_mapped_reference;
typedef typename base_type::value_type value_type;
typedef typename base_type::pointer pointer;
typedef typename base_type::const_pointer const_pointer;
typedef typename base_type::reference reference;
typedef typename base_type::const_reference const_reference;
typedef typename base_type::point_iterator point_iterator;
typedef typename base_type::const_iterator const_point_iterator;
typedef typename base_type::iterator iterator;
typedef typename base_type::const_iterator const_iterator;
typedef typename base_type::reverse_iterator reverse_iterator;
typedef typename base_type::const_reverse_iterator const_reverse_iterator;
typedef typename base_type::node_update node_update;
typedef typename PB_DS_BASE_C_DEC::node_update node_update;
public:
PB_DS_CLASS_NAME(); PB_DS_CLASS_NAME();
PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn); PB_DS_CLASS_NAME(const Cmp_Fn&);
PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn, const node_update& r_node_update); PB_DS_CLASS_NAME(const Cmp_Fn&, const node_update&);
PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC& other); PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC&);
void void
swap(PB_DS_CLASS_C_DEC& other); swap(PB_DS_CLASS_C_DEC&);
template<typename It> template<typename It>
void void
copy_from_range(It first_it, It last_it); copy_from_range(It, It);
inline std::pair<point_iterator, bool> inline std::pair<point_iterator, bool>
insert(const_reference r_value); insert(const_reference);
inline mapped_reference inline mapped_reference
operator[](const_key_reference r_key) operator[](const_key_reference r_key)
@ -229,7 +175,7 @@ namespace pb_ds
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
std::pair<point_iterator, bool> ins_pair = std::pair<point_iterator, bool> ins_pair =
PB_DS_BASE_C_DEC::insert_leaf(value_type(r_key, mapped_type())); base_type::insert_leaf(value_type(r_key, mapped_type()));
if (ins_pair.second == true) if (ins_pair.second == true)
{ {
@ -238,32 +184,31 @@ namespace pb_ds
insert_fixup(ins_pair.first.m_p_nd); insert_fixup(ins_pair.first.m_p_nd);
} }
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return ins_pair.first.m_p_nd->m_value.second;
return (ins_pair.first.m_p_nd->m_value.second);
#else #else
insert(r_key); insert(r_key);
return (PB_DS_BASE_C_DEC::s_null_mapped); return base_type::s_null_mapped;
#endif #endif
} }
inline bool inline bool
erase(const_key_reference r_key); erase(const_key_reference);
inline iterator inline iterator
erase(iterator it); erase(iterator);
inline reverse_iterator inline reverse_iterator
erase(reverse_iterator it); erase(reverse_iterator);
template<typename Pred> template<typename Pred>
inline size_type inline size_type
erase_if(Pred pred); erase_if(Pred);
void void
join(PB_DS_CLASS_C_DEC& other); join(PB_DS_CLASS_C_DEC&);
void void
split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other); split(const_key_reference, PB_DS_CLASS_C_DEC&);
protected: protected:
@ -274,29 +219,29 @@ namespace pb_ds
assert_valid() const; assert_valid() const;
size_type size_type
assert_node_consistent(const node_pointer p_nd) const; assert_node_consistent(const node_pointer) const;
#endif #endif
inline static bool inline static bool
is_effectively_black(const node_pointer p_nd); is_effectively_black(const node_pointer);
void void
initialize(); initialize();
void void
insert_fixup(node_pointer p_nd); insert_fixup(node_pointer);
void void
erase_node(node_pointer p_nd); erase_node(node_pointer);
void void
remove_node(node_pointer p_nd); remove_node(node_pointer);
void void
remove_fixup(node_pointer p_x, node_pointer p_new_x_parent); remove_fixup(node_pointer, node_pointer);
void void
split_imp(node_pointer p_nd, PB_DS_CLASS_C_DEC& other); split_imp(node_pointer, PB_DS_CLASS_C_DEC&);
inline node_pointer inline node_pointer
split_min(); split_min();
@ -305,20 +250,19 @@ namespace pb_ds
split_min_imp(); split_min_imp();
void void
join_imp(node_pointer p_x, node_pointer p_r); join_imp(node_pointer, node_pointer);
std::pair<node_pointer, node_pointer> std::pair<node_pointer, node_pointer>
find_join_pos_right(node_pointer p_l, size_type h_l, size_type h_r); find_join_pos_right(node_pointer, size_type, size_type);
std::pair<node_pointer, node_pointer> std::pair<node_pointer, node_pointer>
find_join_pos_left(node_pointer p_r, size_type h_l, size_type h_r); find_join_pos_left(node_pointer, size_type, size_type);
inline size_type inline size_type
black_height(node_pointer p_nd); black_height(node_pointer);
void void
split_at_node(node_pointer p_nd, PB_DS_CLASS_C_DEC& other); split_at_node(node_pointer, PB_DS_CLASS_C_DEC&);
}; };
#include <ext/pb_ds/detail/rb_tree_map_/constructors_destructor_fn_imps.hpp> #include <ext/pb_ds/detail/rb_tree_map_/constructors_destructor_fn_imps.hpp>
@ -333,7 +277,6 @@ namespace pb_ds
#undef PB_DS_CLASS_NAME #undef PB_DS_CLASS_NAME
#undef PB_DS_BASE_CLASS_NAME #undef PB_DS_BASE_CLASS_NAME
#undef PB_DS_BASE_C_DEC #undef PB_DS_BASE_C_DEC
#undef PB_DS_V2F #undef PB_DS_V2F
#undef PB_DS_EP2VP #undef PB_DS_EP2VP
#undef PB_DS_V2S #undef PB_DS_V2S

View File

@ -51,8 +51,8 @@ join(PB_DS_CLASS_C_DEC& other)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.PB_DS_BASE_C_DEC::assert_valid();) _GLIBCXX_DEBUG_ONLY(other.base_type::assert_valid();)
if (PB_DS_BASE_C_DEC::join_prep(other) == false) if (base_type::join_prep(other) == false)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
@ -61,11 +61,11 @@ join(PB_DS_CLASS_C_DEC& other)
const node_pointer p_x = other.split_min(); const node_pointer p_x = other.split_min();
join_imp(p_x, other.m_p_head->m_p_parent); join_imp(p_x, other.m_p_head->m_p_parent);
PB_DS_BASE_C_DEC::join_finish(other); base_type::join_finish(other);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::assert_valid();) _GLIBCXX_DEBUG_ONLY(base_type::assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.PB_DS_BASE_C_DEC::assert_valid();) _GLIBCXX_DEBUG_ONLY(other.base_type::assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -77,7 +77,7 @@ join_imp(node_pointer p_x, node_pointer p_r)
if (p_r != NULL) if (p_r != NULL)
p_r->m_red = false; p_r->m_red = false;
const size_type h = black_height(PB_DS_BASE_C_DEC::m_p_head->m_p_parent); const size_type h = black_height(base_type::m_p_head->m_p_parent);
const size_type other_h = black_height(p_r); const size_type other_h = black_height(p_r);
node_pointer p_x_l; node_pointer p_x_l;
node_pointer p_x_r; node_pointer p_x_r;
@ -85,28 +85,28 @@ join_imp(node_pointer p_x, node_pointer p_r)
const bool right_join = h >= other_h; const bool right_join = h >= other_h;
if (right_join) if (right_join)
{ {
join_pos = find_join_pos_right(PB_DS_BASE_C_DEC::m_p_head->m_p_parent, join_pos = find_join_pos_right(base_type::m_p_head->m_p_parent,
h, other_h); h, other_h);
p_x_l = join_pos.first; p_x_l = join_pos.first;
p_x_r = p_r; p_x_r = p_r;
} }
else else
{ {
p_x_l = PB_DS_BASE_C_DEC::m_p_head->m_p_parent; p_x_l = base_type::m_p_head->m_p_parent;
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = p_r; base_type::m_p_head->m_p_parent = p_r;
if (p_r != NULL) if (p_r != NULL)
p_r->m_p_parent = PB_DS_BASE_C_DEC::m_p_head; p_r->m_p_parent = base_type::m_p_head;
join_pos = find_join_pos_left(PB_DS_BASE_C_DEC::m_p_head->m_p_parent, join_pos = find_join_pos_left(base_type::m_p_head->m_p_parent,
h, other_h); h, other_h);
p_x_r = join_pos.first; p_x_r = join_pos.first;
} }
node_pointer p_parent = join_pos.second; node_pointer p_parent = join_pos.second;
if (p_parent == PB_DS_BASE_C_DEC::m_p_head) if (p_parent == base_type::m_p_head)
{ {
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = p_x; base_type::m_p_head->m_p_parent = p_x;
p_x->m_p_parent = PB_DS_BASE_C_DEC::m_p_head; p_x->m_p_parent = base_type::m_p_head;
} }
else else
{ {
@ -127,11 +127,11 @@ join_imp(node_pointer p_x, node_pointer p_r)
p_x->m_red = true; p_x->m_red = true;
PB_DS_BASE_C_DEC::initialize_min_max(); base_type::initialize_min_max();
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::structure_only_assert_valid();) _GLIBCXX_DEBUG_ONLY(base_type::structure_only_assert_valid();)
PB_DS_BASE_C_DEC::update_to_top(p_x, (node_update* )this); base_type::update_to_top(p_x, (node_update* )this);
insert_fixup(p_x); insert_fixup(p_x);
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::structure_only_assert_valid()); _GLIBCXX_DEBUG_ONLY(base_type::structure_only_assert_valid());
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -139,15 +139,15 @@ inline typename PB_DS_CLASS_C_DEC::node_pointer
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
split_min() split_min()
{ {
node_pointer p_min = PB_DS_BASE_C_DEC::m_p_head->m_p_left; node_pointer p_min = base_type::m_p_head->m_p_left;
#ifdef _GLIBCXX_DEBUG #ifdef _GLIBCXX_DEBUG
const node_pointer p_head = PB_DS_BASE_C_DEC::m_p_head; const node_pointer p_head = base_type::m_p_head;
_GLIBCXX_DEBUG_ASSERT(p_min != p_head); _GLIBCXX_DEBUG_ASSERT(p_min != p_head);
#endif #endif
remove_node(p_min); remove_node(p_min);
return (p_min); return p_min;
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -159,10 +159,10 @@ find_join_pos_right(node_pointer p_l, size_type h_l, size_type h_r)
{ {
_GLIBCXX_DEBUG_ASSERT(h_l >= h_r); _GLIBCXX_DEBUG_ASSERT(h_l >= h_r);
if (PB_DS_BASE_C_DEC::m_p_head->m_p_parent == NULL) if (base_type::m_p_head->m_p_parent == NULL)
return (std::make_pair((node_pointer)NULL, PB_DS_BASE_C_DEC::m_p_head)); return (std::make_pair((node_pointer)NULL, base_type::m_p_head));
node_pointer p_l_parent = PB_DS_BASE_C_DEC::m_p_head; node_pointer p_l_parent = base_type::m_p_head;
while (h_l > h_r) while (h_l > h_r)
{ {
if (p_l->m_red == false) if (p_l->m_red == false)
@ -195,10 +195,10 @@ PB_DS_CLASS_C_DEC::
find_join_pos_left(node_pointer p_r, size_type h_l, size_type h_r) find_join_pos_left(node_pointer p_r, size_type h_l, size_type h_r)
{ {
_GLIBCXX_DEBUG_ASSERT(h_r > h_l); _GLIBCXX_DEBUG_ASSERT(h_r > h_l);
if (PB_DS_BASE_C_DEC::m_p_head->m_p_parent == NULL) if (base_type::m_p_head->m_p_parent == NULL)
return (std::make_pair((node_pointer)NULL, return (std::make_pair((node_pointer)NULL,
PB_DS_BASE_C_DEC::m_p_head)); base_type::m_p_head));
node_pointer p_r_parent = PB_DS_BASE_C_DEC::m_p_head; node_pointer p_r_parent = base_type::m_p_head;
while (h_r > h_l) while (h_r > h_l)
{ {
if (p_r->m_red == false) if (p_r->m_red == false)
@ -244,20 +244,20 @@ PB_DS_CLASS_C_DEC::
split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other) split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::assert_valid();) _GLIBCXX_DEBUG_ONLY(base_type::assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid()); _GLIBCXX_DEBUG_ONLY(other.assert_valid());
_GLIBCXX_DEBUG_ONLY(other.PB_DS_BASE_C_DEC::assert_valid();) _GLIBCXX_DEBUG_ONLY(other.base_type::assert_valid();)
if (PB_DS_BASE_C_DEC::split_prep(r_key, other) == false) if (base_type::split_prep(r_key, other) == false)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
_GLIBCXX_DEBUG_ONLY(other.assert_valid()); _GLIBCXX_DEBUG_ONLY(other.assert_valid());
return; return;
} }
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::structure_only_assert_valid();) _GLIBCXX_DEBUG_ONLY(base_type::structure_only_assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.PB_DS_BASE_C_DEC::structure_only_assert_valid();) _GLIBCXX_DEBUG_ONLY(other.base_type::structure_only_assert_valid();)
node_pointer p_nd = upper_bound(r_key).m_p_nd; node_pointer p_nd = upper_bound(r_key).m_p_nd;
do do
{ {
@ -265,13 +265,13 @@ split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other)
if (Cmp_Fn::operator()(r_key, PB_DS_V2F(p_nd->m_value))) if (Cmp_Fn::operator()(r_key, PB_DS_V2F(p_nd->m_value)))
split_at_node(p_nd, other); split_at_node(p_nd, other);
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::structure_only_assert_valid();) _GLIBCXX_DEBUG_ONLY(base_type::structure_only_assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.PB_DS_BASE_C_DEC::structure_only_assert_valid();) _GLIBCXX_DEBUG_ONLY(other.base_type::structure_only_assert_valid();)
p_nd = p_next_nd; p_nd = p_next_nd;
} }
while (p_nd != PB_DS_BASE_C_DEC::m_p_head); while (p_nd != base_type::m_p_head);
PB_DS_BASE_C_DEC::split_finish(other); base_type::split_finish(other);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
@ -286,12 +286,12 @@ split_at_node(node_pointer p_nd, PB_DS_CLASS_C_DEC& other)
node_pointer p_l = p_nd->m_p_left; node_pointer p_l = p_nd->m_p_left;
node_pointer p_r = p_nd->m_p_right; node_pointer p_r = p_nd->m_p_right;
node_pointer p_parent = p_nd->m_p_parent; node_pointer p_parent = p_nd->m_p_parent;
if (p_parent == PB_DS_BASE_C_DEC::m_p_head) if (p_parent == base_type::m_p_head)
{ {
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = p_l; base_type::m_p_head->m_p_parent = p_l;
if (p_l != NULL) if (p_l != NULL)
{ {
p_l->m_p_parent = PB_DS_BASE_C_DEC::m_p_head; p_l->m_p_parent = base_type::m_p_head;
p_l->m_red = false; p_l->m_red = false;
} }
} }
@ -311,9 +311,9 @@ split_at_node(node_pointer p_nd, PB_DS_CLASS_C_DEC& other)
remove_fixup(p_l, p_parent); remove_fixup(p_l, p_parent);
} }
PB_DS_BASE_C_DEC::initialize_min_max(); base_type::initialize_min_max();
other.join_imp(p_nd, p_r); other.join_imp(p_nd, p_r);
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::structure_only_assert_valid()); _GLIBCXX_DEBUG_ONLY(base_type::structure_only_assert_valid());
_GLIBCXX_DEBUG_ONLY(other.PB_DS_BASE_C_DEC::structure_only_assert_valid()); _GLIBCXX_DEBUG_ONLY(other.base_type::structure_only_assert_valid());
} }

View File

@ -53,16 +53,15 @@ namespace pb_ds
{ {
namespace detail namespace detail
{ {
template<typename Key, template<typename Key,
typename Mapped, typename Mapped,
class Cmp_Fn, typename Cmp_Fn,
template<typename Const_Node_Iterator, template<typename Const_Node_Iterator,
class Node_Iterator, class Node_Iterator,
class Cmp_Fn_, class Cmp_Fn_,
class Allocator_> class Allocator_>
class Node_Update, class Node_Update,
class Allocator> typename Allocator>
struct tree_traits< struct tree_traits<
Key, Key,
Mapped, Mapped,
@ -128,4 +127,4 @@ namespace pb_ds
} // namespace detail } // namespace detail
} // namespace pb_ds } // namespace pb_ds
#endif // #ifndef PB_DS_RB_TREE_NODE_AND_IT_TRAITS_HPP #endif

View File

@ -59,39 +59,35 @@ PB_DS_CLASS_C_DEC::
PB_DS_CLASS_NAME() PB_DS_CLASS_NAME()
{ {
initialize(); initialize();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn) : PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn) :
PB_DS_BASE_C_DEC(r_cmp_fn) base_type(r_cmp_fn)
{ {
initialize(); initialize();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn, const node_update& r_node_update) : PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn, const node_update& r_node_update) :
PB_DS_BASE_C_DEC(r_cmp_fn, r_node_update) base_type(r_cmp_fn, r_node_update)
{ {
initialize(); initialize();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC& other) : PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC& other) :
PB_DS_BASE_C_DEC(other) base_type(other)
{ {
initialize(); initialize();
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
@ -99,18 +95,14 @@ PB_DS_CLASS_C_DEC::
swap(PB_DS_CLASS_C_DEC& other) swap(PB_DS_CLASS_C_DEC& other)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
base_type::swap(other);
PB_DS_BASE_C_DEC::swap(other);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
initialize() initialize()
{ { base_type::m_p_head->m_special = true; }
PB_DS_BASE_C_DEC::m_p_head->m_special = true;
}

View File

@ -51,8 +51,8 @@ void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
assert_valid() const assert_valid() const
{ {
PB_DS_BASE_C_DEC::assert_valid(); base_type::assert_valid();
const node_pointer p_head = PB_DS_BASE_C_DEC::m_p_head; const node_pointer p_head = base_type::m_p_head;
assert_special_imp(p_head); assert_special_imp(p_head);
} }
@ -64,7 +64,7 @@ assert_special_imp(const node_pointer p_nd) const
if (p_nd == NULL) if (p_nd == NULL)
return; return;
if (p_nd == PB_DS_BASE_C_DEC::m_p_head) if (p_nd == base_type::m_p_head)
{ {
_GLIBCXX_DEBUG_ASSERT(p_nd->m_special); _GLIBCXX_DEBUG_ASSERT(p_nd->m_special);
assert_special_imp(p_nd->m_p_parent); assert_special_imp(p_nd->m_p_parent);

View File

@ -50,13 +50,10 @@ PB_DS_CLASS_C_DEC::
erase(const_key_reference r_key) erase(const_key_reference r_key)
{ {
point_iterator it = find(r_key); point_iterator it = find(r_key);
if (it == base_type::end())
if (it == PB_DS_BASE_C_DEC::end()) return false;
return (false);
erase(it); erase(it);
return true;
return (true);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -65,19 +62,13 @@ PB_DS_CLASS_C_DEC::
erase(iterator it) erase(iterator it)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
if (it == base_type::end())
if (it == PB_DS_BASE_C_DEC::end()) return it;
return (it);
iterator ret_it = it; iterator ret_it = it;
++ret_it; ++ret_it;
erase_node(it.m_p_nd); erase_node(it.m_p_nd);
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
return ret_it;
return (ret_it);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -86,19 +77,13 @@ PB_DS_CLASS_C_DEC::
erase(reverse_iterator it) erase(reverse_iterator it)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
if (it.m_p_nd == base_type::m_p_head)
if (it.m_p_nd == PB_DS_BASE_C_DEC::m_p_head)
return (it); return (it);
reverse_iterator ret_it = it; reverse_iterator ret_it = it;
++ret_it; ++ret_it;
erase_node(it.m_p_nd); erase_node(it.m_p_nd);
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
return ret_it;
return (ret_it);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -108,26 +93,20 @@ PB_DS_CLASS_C_DEC::
erase_if(Pred pred) erase_if(Pred pred)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
size_type num_ersd = 0;
size_type num_ersd = 0; iterator it = base_type::begin();
while (it != base_type::end())
iterator it = PB_DS_BASE_C_DEC::begin();
while (it != PB_DS_BASE_C_DEC::end())
{ {
if (pred(*it)) if (pred(*it))
{ {
++num_ersd; ++num_ersd;
it = erase(it); it = erase(it);
} }
else else
++it; ++it;
} }
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return num_ersd;
return (num_ersd);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -136,56 +115,40 @@ PB_DS_CLASS_C_DEC::
erase_node(node_pointer p_nd) erase_node(node_pointer p_nd)
{ {
_GLIBCXX_DEBUG_ASSERT(p_nd != NULL); _GLIBCXX_DEBUG_ASSERT(p_nd != NULL);
splay(p_nd); splay(p_nd);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ASSERT(p_nd == this->m_p_head->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_nd == this->m_p_head->m_p_parent);
node_pointer p_l = p_nd->m_p_left; node_pointer p_l = p_nd->m_p_left;
node_pointer p_r = p_nd->m_p_right; node_pointer p_r = p_nd->m_p_right;
PB_DS_BASE_C_DEC::update_min_max_for_erased_node(p_nd); base_type::update_min_max_for_erased_node(p_nd);
base_type::actual_erase_node(p_nd);
PB_DS_BASE_C_DEC::actual_erase_node(p_nd);
if (p_r == NULL) if (p_r == NULL)
{ {
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = p_l; base_type::m_p_head->m_p_parent = p_l;
if (p_l != NULL) if (p_l != NULL)
p_l->m_p_parent = PB_DS_BASE_C_DEC::m_p_head; p_l->m_p_parent = base_type::m_p_head;
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
return;
return;
} }
node_pointer p_target_r = leftmost(p_r); node_pointer p_target_r = leftmost(p_r);
_GLIBCXX_DEBUG_ASSERT(p_target_r != NULL); _GLIBCXX_DEBUG_ASSERT(p_target_r != NULL);
p_r->m_p_parent = base_type::m_p_head;
p_r->m_p_parent = PB_DS_BASE_C_DEC::m_p_head; base_type::m_p_head->m_p_parent = p_r;
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = p_r;
splay(p_target_r); splay(p_target_r);
_GLIBCXX_DEBUG_ONLY(p_target_r->m_p_left = NULL); _GLIBCXX_DEBUG_ONLY(p_target_r->m_p_left = NULL);
_GLIBCXX_DEBUG_ASSERT(p_target_r->m_p_parent == this->m_p_head); _GLIBCXX_DEBUG_ASSERT(p_target_r->m_p_parent == this->m_p_head);
_GLIBCXX_DEBUG_ASSERT(this->m_p_head->m_p_parent == p_target_r);
_GLIBCXX_DEBUG_ASSERT(this->m_p_head->m_p_parent ==
p_target_r);
p_target_r->m_p_left = p_l; p_target_r->m_p_left = p_l;
if (p_l != NULL) if (p_l != NULL)
p_l->m_p_parent = p_target_r; p_l->m_p_parent = p_target_r;
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
apply_update(p_target_r, (node_update* )this);
apply_update(p_target_r, (node_update* )this);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -194,9 +157,7 @@ PB_DS_CLASS_C_DEC::
leftmost(node_pointer p_nd) leftmost(node_pointer p_nd)
{ {
_GLIBCXX_DEBUG_ASSERT(p_nd != NULL); _GLIBCXX_DEBUG_ASSERT(p_nd != NULL);
while (p_nd->m_p_left != NULL) while (p_nd->m_p_left != NULL)
p_nd = p_nd->m_p_left; p_nd = p_nd->m_p_left;
return p_nd;
return (p_nd);
} }

View File

@ -50,11 +50,9 @@ PB_DS_CLASS_C_DEC::
find(const_key_reference r_key) find(const_key_reference r_key)
{ {
node_pointer p_found = find_imp(r_key); node_pointer p_found = find_imp(r_key);
if (p_found != base_type::m_p_head)
if (p_found != PB_DS_BASE_C_DEC::m_p_head)
splay(p_found); splay(p_found);
return point_iterator(p_found);
return (point_iterator(p_found));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -63,11 +61,9 @@ PB_DS_CLASS_C_DEC::
find(const_key_reference r_key) const find(const_key_reference r_key) const
{ {
const node_pointer p_found = find_imp(r_key); const node_pointer p_found = find_imp(r_key);
if (p_found != base_type::m_p_head)
if (p_found != PB_DS_BASE_C_DEC::m_p_head)
const_cast<PB_DS_CLASS_C_DEC* >(this)->splay(p_found); const_cast<PB_DS_CLASS_C_DEC* >(this)->splay(p_found);
return point_iterator(p_found);
return (point_iterator(p_found));
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -75,22 +71,18 @@ inline typename PB_DS_CLASS_C_DEC::node_pointer
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
find_imp(const_key_reference r_key) find_imp(const_key_reference r_key)
{ {
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::structure_only_assert_valid();) _GLIBCXX_DEBUG_ONLY(base_type::structure_only_assert_valid();)
node_pointer p_nd = base_type::m_p_head->m_p_parent;
node_pointer p_nd = PB_DS_BASE_C_DEC::m_p_head->m_p_parent;
while (p_nd != NULL) while (p_nd != NULL)
if (!Cmp_Fn::operator()(PB_DS_V2F(p_nd->m_value), r_key)) if (!Cmp_Fn::operator()(PB_DS_V2F(p_nd->m_value), r_key))
{ {
if (!Cmp_Fn::operator()(r_key, PB_DS_V2F(p_nd->m_value))) if (!Cmp_Fn::operator()(r_key, PB_DS_V2F(p_nd->m_value)))
return (p_nd); return p_nd;
p_nd = p_nd->m_p_left; p_nd = p_nd->m_p_left;
} }
else else
p_nd = p_nd->m_p_right; p_nd = p_nd->m_p_right;
return base_type::m_p_head;
return PB_DS_BASE_C_DEC::m_p_head;
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -99,19 +91,15 @@ PB_DS_CLASS_C_DEC::
find_imp(const_key_reference r_key) const find_imp(const_key_reference r_key) const
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
node_pointer p_nd = base_type::m_p_head->m_p_parent;
node_pointer p_nd = PB_DS_BASE_C_DEC::m_p_head->m_p_parent;
while (p_nd != NULL) while (p_nd != NULL)
if (!Cmp_Fn::operator()(PB_DS_V2F(p_nd->m_value), r_key)) if (!Cmp_Fn::operator()(PB_DS_V2F(p_nd->m_value), r_key))
{ {
if (!Cmp_Fn::operator()(r_key, PB_DS_V2F(p_nd->m_value))) if (!Cmp_Fn::operator()(r_key, PB_DS_V2F(p_nd->m_value)))
return (p_nd); return p_nd;
p_nd = p_nd->m_p_left; p_nd = p_nd->m_p_left;
} }
else else
p_nd = p_nd->m_p_right; p_nd = p_nd->m_p_right;
return base_type::m_p_head;
return PB_DS_BASE_C_DEC::m_p_head;
} }

View File

@ -50,19 +50,12 @@ PB_DS_CLASS_C_DEC::
insert(const_reference r_value) insert(const_reference r_value)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
std::pair<point_iterator, bool> ins_pair = insert_leaf_imp(r_value);
std::pair<point_iterator, bool> ins_pair =
insert_leaf_imp(r_value);
ins_pair.first.m_p_nd->m_special = false; ins_pair.first.m_p_nd->m_special = false;
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
splay(ins_pair.first.m_p_nd); splay(ins_pair.first.m_p_nd);
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
return ins_pair;
return (ins_pair);
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
@ -70,55 +63,37 @@ inline std::pair<typename PB_DS_CLASS_C_DEC::point_iterator, bool>
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
insert_leaf_imp(const_reference r_value) insert_leaf_imp(const_reference r_value)
{ {
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::structure_only_assert_valid();) _GLIBCXX_DEBUG_ONLY(base_type::structure_only_assert_valid();)
if (base_type::m_size == 0)
return std::make_pair(base_type::insert_imp_empty(r_value), true);
if (PB_DS_BASE_C_DEC::m_size == 0) node_pointer p_nd = base_type::m_p_head->m_p_parent;
return (std::make_pair( node_pointer p_pot = base_type::m_p_head;
PB_DS_BASE_C_DEC::insert_imp_empty(r_value),
true));
node_pointer p_nd = PB_DS_BASE_C_DEC::m_p_head->m_p_parent;
node_pointer p_pot = PB_DS_BASE_C_DEC::m_p_head;
while (p_nd != NULL) while (p_nd != NULL)
if (!Cmp_Fn::operator()( if (!Cmp_Fn::operator()(PB_DS_V2F(p_nd->m_value), PB_DS_V2F(r_value)))
PB_DS_V2F(p_nd->m_value),
PB_DS_V2F(r_value)))
{ {
if (!Cmp_Fn::operator()( if (!Cmp_Fn::operator()(PB_DS_V2F(r_value), PB_DS_V2F(p_nd->m_value)))
PB_DS_V2F(r_value),
PB_DS_V2F(p_nd->m_value)))
{ {
return std::make_pair( return std::make_pair(point_iterator(p_nd), false);
point_iterator(p_nd),
false);
} }
p_pot = p_nd; p_pot = p_nd;
p_nd = p_nd->m_p_left; p_nd = p_nd->m_p_left;
} }
else else
p_nd = p_nd->m_p_right; p_nd = p_nd->m_p_right;
if (p_pot == PB_DS_BASE_C_DEC::m_p_head) if (p_pot == base_type::m_p_head)
return (std::make_pair( return std::make_pair(base_type::insert_leaf_new(r_value, base_type::m_p_head->m_p_right, false), true);
PB_DS_BASE_C_DEC::insert_leaf_new(r_value, PB_DS_BASE_C_DEC::m_p_head->m_p_right, false),
true));
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::check_key_does_not_exist( _GLIBCXX_DEBUG_ONLY(base_type::check_key_does_not_exist(PB_DS_V2F(r_value)));
PB_DS_V2F(r_value)));
p_nd = p_pot->m_p_left; p_nd = p_pot->m_p_left;
if (p_nd == NULL) if (p_nd == NULL)
return (std::make_pair( return (std::make_pair(base_type::insert_leaf_new(r_value, p_pot, true), true));
PB_DS_BASE_C_DEC::insert_leaf_new( r_value, p_pot, true),
true));
while (p_nd->m_p_right != NULL) while (p_nd->m_p_right != NULL)
p_nd = p_nd->m_p_right; p_nd = p_nd->m_p_right;
return (std::make_pair( return std::make_pair(insert_leaf_new(r_value, p_nd, false), true);
insert_leaf_new(r_value, p_nd, false),
true));
} }

View File

@ -51,121 +51,81 @@ namespace pb_ds
{ {
namespace detail namespace detail
{ {
template<typename Value_Type, class Metadata, class Allocator> template<typename Value_Type, class Metadata, class Allocator>
struct splay_tree_node_ struct splay_tree_node_
{ {
public: public:
typedef typedef Value_Type value_type;
typename Allocator::template rebind<
splay_tree_node_<
Value_Type,
Metadata,
Allocator> >::other::pointer
node_pointer;
typedef Metadata metadata_type; typedef Metadata metadata_type;
typedef typedef
typename Allocator::template rebind< typename Allocator::template rebind<
metadata_type>::other::reference splay_tree_node_<Value_Type, Metadata, Allocator> >::other::pointer
node_pointer;
typedef
typename Allocator::template rebind<metadata_type>::other::reference
metadata_reference; metadata_reference;
typedef typedef
typename Allocator::template rebind< typename Allocator::template rebind<metadata_type>::other::const_reference
metadata_type>::other::const_reference
const_metadata_reference; const_metadata_reference;
#ifdef PB_DS_BIN_SEARCH_TREE_TRACE_ #ifdef PB_DS_BIN_SEARCH_TREE_TRACE_
void void
trace() const trace() const
{ { std::cout << PB_DS_V2F(m_value) << "(" << m_metadata << ")"; }
std::cout << PB_DS_V2F(m_value) << #endif
"(" << m_metadata << ")";
}
#endif // #ifdef PB_DS_BIN_SEARCH_TREE_TRACE_
public:
inline bool inline bool
special() const special() const
{ { return m_special; }
return (m_special);
}
inline const_metadata_reference inline const_metadata_reference
get_metadata() const get_metadata() const
{ { return m_metadata; }
return (m_metadata);
}
inline metadata_reference inline metadata_reference
get_metadata() get_metadata()
{ { return m_metadata; }
return (m_metadata);
}
public:
typedef Value_Type value_type;
value_type m_value; value_type m_value;
bool m_special; bool m_special;
node_pointer m_p_left; node_pointer m_p_left;
node_pointer m_p_right; node_pointer m_p_right;
node_pointer m_p_parent; node_pointer m_p_parent;
metadata_type m_metadata; metadata_type m_metadata;
}; };
template<typename Value_Type, class Allocator> template<typename Value_Type, typename Allocator>
struct splay_tree_node_< struct splay_tree_node_<Value_Type, null_node_metadata, Allocator>
Value_Type,
null_node_metadata,
Allocator>
{ {
public: public:
typedef
typename Allocator::template rebind<
splay_tree_node_<
Value_Type,
null_node_metadata,
Allocator> >::other::pointer
node_pointer;
typedef Value_Type value_type; typedef Value_Type value_type;
typedef null_node_metadata metadata_type; typedef null_node_metadata metadata_type;
public: typedef
typename Allocator::template rebind<
splay_tree_node_<Value_Type, null_node_metadata, Allocator> >::other::pointer
node_pointer;
inline bool inline bool
special() const special() const
{ { return m_special; }
return (m_special);
}
#ifdef PB_DS_BIN_SEARCH_TREE_TRACE_ #ifdef PB_DS_BIN_SEARCH_TREE_TRACE_
void void
trace() const trace() const
{ { std::cout << PB_DS_V2F(m_value); }
std::cout << PB_DS_V2F(m_value); #endif
}
#endif // #ifdef PB_DS_BIN_SEARCH_TREE_TRACE_
public:
node_pointer m_p_left; node_pointer m_p_left;
node_pointer m_p_right; node_pointer m_p_right;
node_pointer m_p_parent; node_pointer m_p_parent;
value_type m_value; value_type m_value;
bool m_special; bool m_special;
}; };
} // namespace detail } // namespace detail
} // namespace pb_ds } // namespace pb_ds
#endif // #ifndef PB_DS_SPLAY_TREE_NODE_HPP #endif

View File

@ -49,20 +49,20 @@ void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
splay(node_pointer p_nd) splay(node_pointer p_nd)
{ {
while (p_nd->m_p_parent != PB_DS_BASE_C_DEC::m_p_head) while (p_nd->m_p_parent != base_type::m_p_head)
{ {
#ifdef _GLIBCXX_DEBUG #ifdef _GLIBCXX_DEBUG
{ {
node_pointer p_head = PB_DS_BASE_C_DEC::m_p_head; node_pointer p_head = base_type::m_p_head;
assert_special_imp(p_head); assert_special_imp(p_head);
} }
#endif #endif
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::assert_node_consistent(p_nd);) _GLIBCXX_DEBUG_ONLY(base_type::assert_node_consistent(p_nd);)
if (p_nd->m_p_parent->m_p_parent == PB_DS_BASE_C_DEC::m_p_head) if (p_nd->m_p_parent->m_p_parent == base_type::m_p_head)
{ {
PB_DS_BASE_C_DEC::rotate_parent(p_nd); base_type::rotate_parent(p_nd);
_GLIBCXX_DEBUG_ASSERT(p_nd == this->m_p_head->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_nd == this->m_p_head->m_p_parent);
} }
else else
@ -72,7 +72,7 @@ splay(node_pointer p_nd)
#ifdef _GLIBCXX_DEBUG #ifdef _GLIBCXX_DEBUG
const size_type total = const size_type total =
PB_DS_BASE_C_DEC::recursive_count(p_grandparent); base_type::recursive_count(p_grandparent);
_GLIBCXX_DEBUG_ASSERT(total >= 3); _GLIBCXX_DEBUG_ASSERT(total >= 3);
#endif #endif
@ -90,19 +90,20 @@ splay(node_pointer p_nd)
_GLIBCXX_DEBUG_ASSERT(total ==this->recursive_count(p_nd)); _GLIBCXX_DEBUG_ASSERT(total ==this->recursive_count(p_nd));
} }
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::assert_node_consistent(p_nd);) _GLIBCXX_DEBUG_ONLY(base_type::assert_node_consistent(p_nd);)
} }
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
splay_zig_zag_left(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent) splay_zig_zag_left(node_pointer p_nd, node_pointer p_parent,
node_pointer p_grandparent)
{ {
_GLIBCXX_DEBUG_ASSERT(p_parent == p_nd->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_parent == p_nd->m_p_parent);
_GLIBCXX_DEBUG_ASSERT(p_grandparent == p_parent->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_grandparent == p_parent->m_p_parent);
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::assert_node_consistent(p_grandparent);) _GLIBCXX_DEBUG_ONLY(base_type::assert_node_consistent(p_grandparent);)
_GLIBCXX_DEBUG_ASSERT(p_parent->m_p_left == p_nd && _GLIBCXX_DEBUG_ASSERT(p_parent->m_p_left == p_nd &&
p_grandparent->m_p_right == p_parent); p_grandparent->m_p_right == p_parent);
@ -132,12 +133,13 @@ splay_zig_zag_left(node_pointer p_nd, node_pointer p_parent, node_pointer p_gran
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
splay_zig_zag_right(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent) splay_zig_zag_right(node_pointer p_nd, node_pointer p_parent,
node_pointer p_grandparent)
{ {
_GLIBCXX_DEBUG_ASSERT(p_parent == p_nd->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_parent == p_nd->m_p_parent);
_GLIBCXX_DEBUG_ASSERT(p_grandparent == p_parent->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_grandparent == p_parent->m_p_parent);
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::assert_node_consistent(p_grandparent);) _GLIBCXX_DEBUG_ONLY(base_type::assert_node_consistent(p_grandparent);)
_GLIBCXX_DEBUG_ASSERT(p_parent->m_p_right == p_nd && _GLIBCXX_DEBUG_ASSERT(p_parent->m_p_right == p_nd &&
p_grandparent->m_p_left == p_parent); p_grandparent->m_p_left == p_parent);
@ -167,12 +169,13 @@ splay_zig_zag_right(node_pointer p_nd, node_pointer p_parent, node_pointer p_gra
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
splay_zig_zig_left(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent) splay_zig_zig_left(node_pointer p_nd, node_pointer p_parent,
node_pointer p_grandparent)
{ {
_GLIBCXX_DEBUG_ASSERT(p_parent == p_nd->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_parent == p_nd->m_p_parent);
_GLIBCXX_DEBUG_ASSERT(p_grandparent == p_parent->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_grandparent == p_parent->m_p_parent);
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::assert_node_consistent(p_grandparent);) _GLIBCXX_DEBUG_ONLY(base_type::assert_node_consistent(p_grandparent);)
_GLIBCXX_DEBUG_ASSERT(p_parent->m_p_left == p_nd && _GLIBCXX_DEBUG_ASSERT(p_parent->m_p_left == p_nd &&
p_nd->m_p_parent->m_p_parent->m_p_left == p_nd->m_p_parent); p_nd->m_p_parent->m_p_parent->m_p_left == p_nd->m_p_parent);
@ -202,15 +205,14 @@ splay_zig_zig_left(node_pointer p_nd, node_pointer p_parent, node_pointer p_gran
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
splay_zig_zig_right(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent) splay_zig_zig_right(node_pointer p_nd, node_pointer p_parent,
node_pointer p_grandparent)
{ {
_GLIBCXX_DEBUG_ASSERT(p_parent == p_nd->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_parent == p_nd->m_p_parent);
_GLIBCXX_DEBUG_ASSERT(p_grandparent == p_parent->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_grandparent == p_parent->m_p_parent);
_GLIBCXX_DEBUG_ONLY(base_type::assert_node_consistent(p_grandparent);)
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::assert_node_consistent(p_grandparent);) _GLIBCXX_DEBUG_ASSERT(p_parent->m_p_right == p_nd &&
p_nd->m_p_parent->m_p_parent->m_p_right == p_nd->m_p_parent);
_GLIBCXX_DEBUG_ASSERT(p_parent->m_p_right == p_nd&&
p_nd->m_p_parent->m_p_parent->m_p_right == p_nd->m_p_parent);
splay_zz_start(p_nd, p_parent, p_grandparent); splay_zz_start(p_nd, p_parent, p_grandparent);
@ -231,7 +233,7 @@ splay_zig_zig_right(node_pointer p_nd, node_pointer p_parent, node_pointer p_gra
if (p_c != NULL) if (p_c != NULL)
p_c->m_p_parent = p_grandparent; p_c->m_p_parent = p_grandparent;
PB_DS_BASE_C_DEC::update_to_top(p_grandparent, (node_update* )this); base_type::update_to_top(p_grandparent, (node_update* )this);
splay_zz_end(p_nd, p_parent, p_grandparent); splay_zz_end(p_nd, p_parent, p_grandparent);
} }
@ -250,15 +252,12 @@ splay_zz_start(node_pointer p_nd,
_GLIBCXX_DEBUG_ASSERT(p_parent != NULL); _GLIBCXX_DEBUG_ASSERT(p_parent != NULL);
_GLIBCXX_DEBUG_ASSERT(p_grandparent != NULL); _GLIBCXX_DEBUG_ASSERT(p_grandparent != NULL);
const bool grandparent_head = const bool grandparent_head = p_grandparent->m_p_parent == base_type::m_p_head;
p_grandparent->m_p_parent == PB_DS_BASE_C_DEC::m_p_head;
if (grandparent_head) if (grandparent_head)
{ {
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = base_type::m_p_head->m_p_parent = base_type::m_p_head->m_p_parent;
PB_DS_BASE_C_DEC::m_p_head->m_p_parent; p_nd->m_p_parent = base_type::m_p_head;
p_nd->m_p_parent = PB_DS_BASE_C_DEC::m_p_head;
return; return;
} }
@ -275,15 +274,16 @@ splay_zz_start(node_pointer p_nd,
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
inline void inline void
PB_DS_CLASS_C_DEC:: PB_DS_CLASS_C_DEC::
splay_zz_end(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent) splay_zz_end(node_pointer p_nd, node_pointer p_parent,
node_pointer p_grandparent)
{ {
if (p_nd->m_p_parent == PB_DS_BASE_C_DEC::m_p_head) if (p_nd->m_p_parent == base_type::m_p_head)
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = p_nd; base_type::m_p_head->m_p_parent = p_nd;
apply_update(p_grandparent, (node_update* )this); apply_update(p_grandparent, (node_update* )this);
apply_update(p_parent, (node_update* )this); apply_update(p_parent, (node_update* )this);
apply_update(p_nd, (node_update* )this); apply_update(p_nd, (node_update* )this);
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::assert_node_consistent(p_nd);) _GLIBCXX_DEBUG_ONLY(base_type::assert_node_consistent(p_nd);)
} }

View File

@ -97,50 +97,31 @@ namespace pb_ds
{ {
namespace detail namespace detail
{ {
#define PB_DS_CLASS_T_DEC \
#define PB_DS_CLASS_T_DEC \ template<typename Key, typename Mapped, typename Cmp_Fn, \
template< \ typename Node_And_It_Traits, typename Allocator>
typename Key, \
typename Mapped, \
class Cmp_Fn, \
class Node_And_It_Traits, \
class Allocator>
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
#define PB_DS_CLASS_NAME \ #define PB_DS_CLASS_NAME splay_tree_data_
splay_tree_data_
#endif #endif
#ifdef PB_DS_DATA_FALSE_INDICATOR #ifdef PB_DS_DATA_FALSE_INDICATOR
#define PB_DS_CLASS_NAME \ #define PB_DS_CLASS_NAME splay_tree_no_data_
splay_tree_no_data_
#endif #endif
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
#define PB_DS_BASE_CLASS_NAME \ #define PB_DS_BASE_CLASS_NAME bin_search_tree_data_
bin_search_tree_data_
#endif #endif
#ifdef PB_DS_DATA_FALSE_INDICATOR #ifdef PB_DS_DATA_FALSE_INDICATOR
#define PB_DS_BASE_CLASS_NAME \ #define PB_DS_BASE_CLASS_NAME bin_search_tree_no_data_
bin_search_tree_no_data_
#endif #endif
#define PB_DS_CLASS_C_DEC \ #define PB_DS_CLASS_C_DEC \
PB_DS_CLASS_NAME< \ PB_DS_CLASS_NAME<Key, Mapped, Cmp_Fn, Node_And_It_Traits, Allocator>
Key, \
Mapped, \
Cmp_Fn, \
Node_And_It_Traits, \
Allocator>
#define PB_DS_BASE_C_DEC \ #define PB_DS_BASE_C_DEC \
PB_DS_BASE_CLASS_NAME< \ PB_DS_BASE_CLASS_NAME<Key, Mapped, Cmp_Fn, Node_And_It_Traits, Allocator>
Key, \
Mapped, \
Cmp_Fn, \
Node_And_It_Traits, \
Allocator>
#ifdef PB_DS_DATA_TRUE_INDICATOR #ifdef PB_DS_DATA_TRUE_INDICATOR
#define PB_DS_V2F(X) (X).first #define PB_DS_V2F(X) (X).first
@ -155,102 +136,61 @@ namespace pb_ds
#endif #endif
// $p14y 7r33 7481. // $p14y 7r33 7481.
template<typename Key, template<typename Key, typename Mapped, typename Cmp_Fn,
typename Mapped, typename Node_And_It_Traits, typename Allocator>
class Cmp_Fn,
class Node_And_It_Traits,
class Allocator>
class PB_DS_CLASS_NAME : public PB_DS_BASE_C_DEC class PB_DS_CLASS_NAME : public PB_DS_BASE_C_DEC
{ {
private: private:
typedef typename PB_DS_BASE_C_DEC::node_pointer node_pointer; typedef PB_DS_BASE_C_DEC base_type;
typedef typename base_type::node_pointer node_pointer;
public: public:
typedef typename Allocator::size_type size_type;
typedef typename Allocator::difference_type difference_type;
typedef typename PB_DS_BASE_C_DEC::key_type key_type;
typedef typename PB_DS_BASE_C_DEC::key_pointer key_pointer;
typedef typename PB_DS_BASE_C_DEC::const_key_pointer const_key_pointer;
typedef typename PB_DS_BASE_C_DEC::key_reference key_reference;
typedef
typename PB_DS_BASE_C_DEC::const_key_reference
const_key_reference;
typedef typename PB_DS_BASE_C_DEC::mapped_type mapped_type;
typedef typename PB_DS_BASE_C_DEC::mapped_pointer mapped_pointer;
typedef
typename PB_DS_BASE_C_DEC::const_mapped_pointer
const_mapped_pointer;
typedef typename PB_DS_BASE_C_DEC::mapped_reference mapped_reference;
typedef
typename PB_DS_BASE_C_DEC::const_mapped_reference
const_mapped_reference;
typedef typename PB_DS_BASE_C_DEC::value_type value_type;
typedef typename PB_DS_BASE_C_DEC::pointer pointer;
typedef typename PB_DS_BASE_C_DEC::const_pointer const_pointer;
typedef typename PB_DS_BASE_C_DEC::reference reference;
typedef typename PB_DS_BASE_C_DEC::const_reference const_reference;
typedef typename PB_DS_BASE_C_DEC::point_iterator point_iterator;
typedef typename PB_DS_BASE_C_DEC::const_iterator const_point_iterator;
typedef typename PB_DS_BASE_C_DEC::iterator iterator;
typedef typename PB_DS_BASE_C_DEC::const_iterator const_iterator;
typedef typename PB_DS_BASE_C_DEC::reverse_iterator reverse_iterator;
typedef
typename PB_DS_BASE_C_DEC::const_reverse_iterator
const_reverse_iterator;
typedef Cmp_Fn cmp_fn;
typedef Allocator allocator; typedef Allocator allocator;
typedef typename Allocator::size_type size_type;
typedef typename PB_DS_BASE_C_DEC::node_update node_update; typedef typename Allocator::difference_type difference_type;
typedef Cmp_Fn cmp_fn;
public: typedef typename base_type::key_type key_type;
typedef typename base_type::key_pointer key_pointer;
typedef typename base_type::const_key_pointer const_key_pointer;
typedef typename base_type::key_reference key_reference;
typedef typename base_type::const_key_reference const_key_reference;
typedef typename base_type::mapped_type mapped_type;
typedef typename base_type::mapped_pointer mapped_pointer;
typedef typename base_type::const_mapped_pointer const_mapped_pointer;
typedef typename base_type::mapped_reference mapped_reference;
typedef typename base_type::const_mapped_reference const_mapped_reference;
typedef typename base_type::value_type value_type;
typedef typename base_type::pointer pointer;
typedef typename base_type::const_pointer const_pointer;
typedef typename base_type::reference reference;
typedef typename base_type::const_reference const_reference;
typedef typename base_type::point_iterator point_iterator;
typedef typename base_type::const_iterator const_point_iterator;
typedef typename base_type::iterator iterator;
typedef typename base_type::const_iterator const_iterator;
typedef typename base_type::reverse_iterator reverse_iterator;
typedef typename base_type::const_reverse_iterator const_reverse_iterator;
typedef typename base_type::node_update node_update;
PB_DS_CLASS_NAME(); PB_DS_CLASS_NAME();
PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn); PB_DS_CLASS_NAME(const Cmp_Fn&);
PB_DS_CLASS_NAME(const Cmp_Fn& r_cmp_fn, const node_update& r_node_update); PB_DS_CLASS_NAME(const Cmp_Fn&, const node_update&);
PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC& other); PB_DS_CLASS_NAME(const PB_DS_CLASS_C_DEC&);
void void
swap(PB_DS_CLASS_C_DEC& other); swap(PB_DS_CLASS_C_DEC&);
template<typename It> template<typename It>
void void
copy_from_range(It first_it, It last_it); copy_from_range(It, It);
void void
initialize(); initialize();
inline std::pair< inline std::pair<point_iterator, bool>
point_iterator,
bool>
insert(const_reference r_value); insert(const_reference r_value);
inline mapped_reference inline mapped_reference
@ -262,87 +202,85 @@ namespace pb_ds
insert_leaf_imp(value_type(r_key, mapped_type())); insert_leaf_imp(value_type(r_key, mapped_type()));
ins_pair.first.m_p_nd->m_special = false; ins_pair.first.m_p_nd->m_special = false;
_GLIBCXX_DEBUG_ONLY(PB_DS_BASE_C_DEC::assert_valid()); _GLIBCXX_DEBUG_ONLY(base_type::assert_valid());
splay(ins_pair.first.m_p_nd); splay(ins_pair.first.m_p_nd);
_GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::assert_valid();) _GLIBCXX_DEBUG_ONLY(PB_DS_CLASS_C_DEC::assert_valid();)
return ins_pair.first.m_p_nd->m_value.second; return ins_pair.first.m_p_nd->m_value.second;
#else #else
insert(r_key); insert(r_key);
return PB_DS_BASE_C_DEC::s_null_mapped; return base_type::s_null_mapped;
#endif #endif
} }
inline point_iterator inline point_iterator
find(const_key_reference r_key); find(const_key_reference);
inline const_point_iterator inline const_point_iterator
find(const_key_reference r_key) const; find(const_key_reference) const;
inline bool inline bool
erase(const_key_reference r_key); erase(const_key_reference);
inline iterator inline iterator
erase(iterator it); erase(iterator it);
inline reverse_iterator inline reverse_iterator
erase(reverse_iterator it); erase(reverse_iterator);
template<typename Pred> template<typename Pred>
inline size_type inline size_type
erase_if(Pred pred); erase_if(Pred);
void void
join(PB_DS_CLASS_C_DEC& other); join(PB_DS_CLASS_C_DEC&);
void void
split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other); split(const_key_reference, PB_DS_CLASS_C_DEC&);
private: private:
inline std::pair<point_iterator, bool> inline std::pair<point_iterator, bool>
insert_leaf_imp(const_reference r_mapped_value); insert_leaf_imp(const_reference);
inline node_pointer inline node_pointer
find_imp(const_key_reference r_key); find_imp(const_key_reference);
inline const node_pointer inline const node_pointer
find_imp(const_key_reference r_key) const; find_imp(const_key_reference) const;
#ifdef _GLIBCXX_DEBUG #ifdef _GLIBCXX_DEBUG
void void
assert_valid() const; assert_valid() const;
void void
assert_special_imp(const node_pointer p_nd) const; assert_special_imp(const node_pointer) const;
#endif #endif
void void
splay(node_pointer p_nd); splay(node_pointer);
inline void inline void
splay_zig_zag_left(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent); splay_zig_zag_left(node_pointer, node_pointer, node_pointer);
inline void inline void
splay_zig_zag_right(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent); splay_zig_zag_right(node_pointer, node_pointer, node_pointer);
inline void inline void
splay_zig_zig_left(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent); splay_zig_zig_left(node_pointer, node_pointer, node_pointer);
inline void inline void
splay_zig_zig_right(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent); splay_zig_zig_right(node_pointer, node_pointer, node_pointer);
inline void inline void
splay_zz_start(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent); splay_zz_start(node_pointer, node_pointer, node_pointer);
inline void inline void
splay_zz_end(node_pointer p_nd, node_pointer p_parent, node_pointer p_grandparent); splay_zz_end(node_pointer, node_pointer, node_pointer);
inline node_pointer inline node_pointer
leftmost(node_pointer p_nd); leftmost(node_pointer);
void void
erase_node(node_pointer p_nd); erase_node(node_pointer);
}; };
#include <ext/pb_ds/detail/splay_tree_/constructors_destructor_fn_imps.hpp> #include <ext/pb_ds/detail/splay_tree_/constructors_destructor_fn_imps.hpp>
@ -358,7 +296,6 @@ namespace pb_ds
#undef PB_DS_CLASS_NAME #undef PB_DS_CLASS_NAME
#undef PB_DS_BASE_CLASS_NAME #undef PB_DS_BASE_CLASS_NAME
#undef PB_DS_BASE_C_DEC #undef PB_DS_BASE_C_DEC
#undef PB_DS_V2F #undef PB_DS_V2F
#undef PB_DS_EP2VP #undef PB_DS_EP2VP
#undef PB_DS_V2S #undef PB_DS_V2S

View File

@ -50,40 +50,35 @@ PB_DS_CLASS_C_DEC::
join(PB_DS_CLASS_C_DEC& other) join(PB_DS_CLASS_C_DEC& other)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
if (base_type::join_prep(other) == false)
if (PB_DS_BASE_C_DEC::join_prep(other) == false) {
{ _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) return;
}
return;
}
node_pointer p_target_r = other.leftmost(other.m_p_head); node_pointer p_target_r = other.leftmost(other.m_p_head);
_GLIBCXX_DEBUG_ASSERT(p_target_r != NULL); _GLIBCXX_DEBUG_ASSERT(p_target_r != NULL);
other.splay(p_target_r); other.splay(p_target_r);
_GLIBCXX_DEBUG_ASSERT(p_target_r == other.m_p_head->m_p_parent); _GLIBCXX_DEBUG_ASSERT(p_target_r == other.m_p_head->m_p_parent);
_GLIBCXX_DEBUG_ASSERT(p_target_r->m_p_left == NULL); _GLIBCXX_DEBUG_ASSERT(p_target_r->m_p_left == NULL);
p_target_r->m_p_left = PB_DS_BASE_C_DEC::m_p_head->m_p_parent; p_target_r->m_p_left = base_type::m_p_head->m_p_parent;
_GLIBCXX_DEBUG_ASSERT(p_target_r->m_p_left != NULL); _GLIBCXX_DEBUG_ASSERT(p_target_r->m_p_left != NULL);
p_target_r->m_p_left->m_p_parent = p_target_r; p_target_r->m_p_left->m_p_parent = p_target_r;
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = p_target_r; base_type::m_p_head->m_p_parent = p_target_r;
p_target_r->m_p_parent = PB_DS_BASE_C_DEC::m_p_head; p_target_r->m_p_parent = base_type::m_p_head;
apply_update(p_target_r, (node_update* )this); apply_update(p_target_r, (node_update* )this);
PB_DS_BASE_C_DEC::join_finish(other); base_type::join_finish(other);
_GLIBCXX_DEBUG_ONLY(assert_valid();) _GLIBCXX_DEBUG_ONLY(assert_valid();)
_GLIBCXX_DEBUG_ONLY(other.assert_valid();) _GLIBCXX_DEBUG_ONLY(other.assert_valid();)
} }
PB_DS_CLASS_T_DEC PB_DS_CLASS_T_DEC
void void
@ -93,11 +88,10 @@ split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other)
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
_GLIBCXX_DEBUG_ONLY(other.assert_valid()); _GLIBCXX_DEBUG_ONLY(other.assert_valid());
if (PB_DS_BASE_C_DEC::split_prep(r_key, other) == false) if (base_type::split_prep(r_key, other) == false)
{ {
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
_GLIBCXX_DEBUG_ONLY(other.assert_valid()); _GLIBCXX_DEBUG_ONLY(other.assert_valid());
return; return;
} }
@ -110,16 +104,13 @@ split(const_key_reference r_key, PB_DS_CLASS_C_DEC& other)
node_pointer p_new_root = p_upper_bound->m_p_left; node_pointer p_new_root = p_upper_bound->m_p_left;
_GLIBCXX_DEBUG_ASSERT(p_new_root != NULL); _GLIBCXX_DEBUG_ASSERT(p_new_root != NULL);
PB_DS_BASE_C_DEC::m_p_head->m_p_parent = p_new_root; base_type::m_p_head->m_p_parent = p_new_root;
p_new_root->m_p_parent = PB_DS_BASE_C_DEC::m_p_head; p_new_root->m_p_parent = base_type::m_p_head;
other.m_p_head->m_p_parent = p_upper_bound; other.m_p_head->m_p_parent = p_upper_bound;
p_upper_bound->m_p_parent = other.m_p_head; p_upper_bound->m_p_parent = other.m_p_head;
p_upper_bound->m_p_left = NULL; p_upper_bound->m_p_left = NULL;
apply_update(p_upper_bound, (node_update* )this); apply_update(p_upper_bound, (node_update* )this);
base_type::split_finish(other);
PB_DS_BASE_C_DEC::split_finish(other);
_GLIBCXX_DEBUG_ONLY(assert_valid()); _GLIBCXX_DEBUG_ONLY(assert_valid());
_GLIBCXX_DEBUG_ONLY(other.assert_valid()); _GLIBCXX_DEBUG_ONLY(other.assert_valid());

View File

@ -96,26 +96,14 @@ namespace pb_ds
class Node_Iterator, class Node_Iterator,
class Cmp_Fn_, class Cmp_Fn_,
class Allocator_> class Allocator_>
class Node_Update, class Node_Update,
class Allocator> class Allocator>
struct tree_traits< struct tree_traits<Key, null_mapped_type, Cmp_Fn, Node_Update,
Key, splay_tree_tag, Allocator>
null_mapped_type, : public bin_search_tree_traits<Key, null_mapped_type, Cmp_Fn,
Cmp_Fn, Node_Update,
Node_Update, splay_tree_node_<typename types_traits<Key, null_mapped_type, Allocator, false>::value_type,
splay_tree_tag, typename tree_node_metadata_selector<
Allocator> : public bin_search_tree_traits<
Key,
null_mapped_type,
Cmp_Fn,
Node_Update,
splay_tree_node_<
typename types_traits<
Key,
null_mapped_type,
Allocator,
false>::value_type,
typename tree_node_metadata_selector<
Key, Key,
null_mapped_type, null_mapped_type,
Cmp_Fn, Cmp_Fn,