pb_assoc: Delete.
[gcc.git] / libstdc++-v3 / ChangeLog
1 2006-06-14 Ami Tavory <atavory@gmail.com>
2 Benjamin Kosnik <bkoz@redhat.com>
3
4 * include/ext/pb_assoc: Delete.
5 * include/ext/pb_ds: Add.
6 * docs/html/ext/pb_assoc: Delete.
7 * docs/html/ext/pb_ds: Add.
8 * testsuite/ext/pb_assoc: Delete.
9 * testsuite/ext/pb_ds: Add.
10 * testsuite/performance/ext: Add.
11 * testsuite/performance/ext/pb_ds: Add.
12
13 * testsuite/util/regression: New.
14 * testsuite/util/rng: New.
15 * testsuite/util/native_type: New.
16 * testsuite/util/common_type: New.
17 * testsuite/util/performance: New.
18 * testsuite/util/hash_fn: New.
19 * testsuite/util/io: New.
20 * testsuite/util/statistic: New.
21
22 * scripts/make_graph.py: New.
23 * scripts/make_graphs.py: New.
24 * testsuite/data/thirty_years_among_the_dead_preproc.txt: Add.
25 * testsuite/data/make_graph_htmls.xml: Add.
26 * testsuite/data/make_graph_test_infos.xml: Add.
27
28 * testsuite/lib/libstdc++.exp (v3-build_support): Add in new
29 object files for regression testing.
30 * docs/html/documentation.html: Adjust links.
31 * include/Makefile.am (install-headers): Update for new sources,
32 directories.
33 * include/Makefine.in: Regenerate.
34 * scripts/testsuite_flags.in: Adjust to testsuite/util path.
35 * scripts/check_performance: Simplify, adjust for new testsuite output.
36 * testsuite/Makefile.am (check-performance): Adjust.
37 (doc-performance): New.
38 * testsuite/Makefile.in: Regenerate.
39
40 * include/ext/pb_ds: New.
41 * include/ext/pb_ds/assoc_container.hpp: Same.
42 * include/ext/pb_ds/detail: New.
43 * include/ext/pb_ds/detail/binomial_heap_base_: New.
44 * include/ext/pb_ds/detail/binomial_heap_base_/erase_fn_imps.hpp: Same.
45 * include/ext/pb_ds/detail/binomial_heap_base_/find_fn_imps.hpp: Same.
46 * include/ext/pb_ds/detail/binomial_heap_base_/insert_fn_imps.hpp: Same.
47 * include/ext/pb_ds/detail/binomial_heap_base_/binomial_heap_base_.hpp: Same.
48 * include/ext/pb_ds/detail/binomial_heap_base_/debug_fn_imps.hpp: Same.
49 * include/ext/pb_ds/detail/binomial_heap_base_/constructors_destructor_fn_imps.hpp: Same.
50 * include/ext/pb_ds/detail/binomial_heap_base_/split_join_fn_imps.hpp: Same.
51 * include/ext/pb_ds/detail/resize_policy: New.
52 * include/ext/pb_ds/detail/resize_policy/sample_size_policy.hpp: Same.
53 * include/ext/pb_ds/detail/resize_policy/hash_prime_size_policy_imp.hpp: Same.
54 * include/ext/pb_ds/detail/resize_policy/cc_hash_max_collision_check_resize_trigger_imp.hpp: Same.
55 * include/ext/pb_ds/detail/resize_policy/sample_resize_policy.hpp: Same.
56 * include/ext/pb_ds/detail/resize_policy/sample_resize_trigger.hpp: Same.
57 * include/ext/pb_ds/detail/resize_policy/hash_load_check_resize_trigger_size_base.hpp: Same.
58 * include/ext/pb_ds/detail/resize_policy/hash_exponential_size_policy_imp.hpp: Same.
59 * include/ext/pb_ds/detail/resize_policy/hash_load_check_resize_trigger_imp.hpp: Same.
60 * include/ext/pb_ds/detail/resize_policy/hash_standard_resize_policy_imp.hpp: Same.
61 * include/ext/pb_ds/detail/container_base_dispatch.hpp: Same.
62 * include/ext/pb_ds/detail/cc_hash_table_map_: New.
63 * include/ext/pb_ds/detail/cc_hash_table_map_/constructor_destructor_no_store_hash_fn_imps.hpp: Same.
64 * include/ext/pb_ds/detail/cc_hash_table_map_/erase_store_hash_fn_imps.hpp: Same.
65 * include/ext/pb_ds/detail/cc_hash_table_map_/cmp_fn_imps.hpp: Same.
66 * include/ext/pb_ds/detail/cc_hash_table_map_/insert_no_store_hash_fn_imps.hpp: Same.
67 * include/ext/pb_ds/detail/cc_hash_table_map_/resize_store_hash_fn_imps.hpp: Same.
68 * include/ext/pb_ds/detail/cc_hash_table_map_/policy_access_fn_imps.hpp: Same.
69 * include/ext/pb_ds/detail/cc_hash_table_map_/find_fn_imps.hpp: Same.
70 * include/ext/pb_ds/detail/cc_hash_table_map_/constructor_destructor_store_hash_fn_imps.hpp: Same.
71 * include/ext/pb_ds/detail/cc_hash_table_map_/insert_store_hash_fn_imps.hpp: Same.
72 * include/ext/pb_ds/detail/cc_hash_table_map_/debug_fn_imps.hpp: Same.
73 * include/ext/pb_ds/detail/cc_hash_table_map_/info_fn_imps.hpp: Same.
74 * include/ext/pb_ds/detail/cc_hash_table_map_/entry_list_fn_imps.hpp: Same.
75 * include/ext/pb_ds/detail/cc_hash_table_map_/trace_fn_imps.hpp: Same.
76 * include/ext/pb_ds/detail/cc_hash_table_map_/find_store_hash_fn_imps.hpp: Same.
77 * include/ext/pb_ds/detail/cc_hash_table_map_/erase_fn_imps.hpp: Same.
78 * include/ext/pb_ds/detail/cc_hash_table_map_/resize_fn_imps.hpp: Same.
79 * include/ext/pb_ds/detail/cc_hash_table_map_/cc_ht_map_.hpp: Same.
80 * include/ext/pb_ds/detail/cc_hash_table_map_/debug_no_store_hash_fn_imps.hpp: Same.
81 * include/ext/pb_ds/detail/cc_hash_table_map_/constructor_destructor_fn_imps.hpp: Same.
82 * include/ext/pb_ds/detail/cc_hash_table_map_/cond_key_dtor_entry_dealtor.hpp: Same.
83 * include/ext/pb_ds/detail/cc_hash_table_map_/insert_fn_imps.hpp: Same.
84 * include/ext/pb_ds/detail/cc_hash_table_map_/debug_store_hash_fn_imps.hpp: Same.
85 * include/ext/pb_ds/detail/cc_hash_table_map_/erase_no_store_hash_fn_imps.hpp: Same.
86 * include/ext/pb_ds/detail/cc_hash_table_map_/size_fn_imps.hpp: Same.
87 * include/ext/pb_ds/detail/cc_hash_table_map_/standard_policies.hpp: Same.
88 * include/ext/pb_ds/detail/cc_hash_table_map_/iterators_fn_imps.hpp: Same.
89 * include/ext/pb_ds/detail/cc_hash_table_map_/resize_no_store_hash_fn_imps.hpp: Same.
90 * include/ext/pb_ds/detail/typelist_assoc_container.hpp: Same.
91 * include/ext/pb_ds/detail/tree_trace_base.hpp: Same.
92 * include/ext/pb_ds/detail/unordered_iterator: New.
93 * include/ext/pb_ds/detail/unordered_iterator/iterator.hpp: Same.
94 * include/ext/pb_ds/detail/unordered_iterator/const_iterator.hpp: Same.
95 * include/ext/pb_ds/detail/unordered_iterator/point_iterator.hpp: Same.
96 * include/ext/pb_ds/detail/unordered_iterator/const_point_iterator.hpp: Same.
97 * include/ext/pb_ds/detail/typelist.hpp: Same.
98 * include/ext/pb_ds/detail/pat_trie_: New.
99 * include/ext/pb_ds/detail/pat_trie_/r_erase_fn_imps.hpp: Same.
100 * include/ext/pb_ds/detail/pat_trie_/policy_access_fn_imps.hpp: Same.
101 * include/ext/pb_ds/detail/pat_trie_/find_fn_imps.hpp: Same.
102 * include/ext/pb_ds/detail/pat_trie_/child_iterator.hpp: Same.
103 * include/ext/pb_ds/detail/pat_trie_/update_fn_imps.hpp: Same.
104 * include/ext/pb_ds/detail/pat_trie_/insert_join_fn_imps.hpp: Same.
105 * include/ext/pb_ds/detail/pat_trie_/split_join_branch_bag.hpp: Same.
106 * include/ext/pb_ds/detail/pat_trie_/constructors_destructor_fn_imps.hpp: Same.
107 * include/ext/pb_ds/detail/pat_trie_/debug_fn_imps.hpp: Same.
108 * include/ext/pb_ds/detail/pat_trie_/head.hpp: Same.
109 * include/ext/pb_ds/detail/pat_trie_/const_child_iterator.hpp: Same.
110 * include/ext/pb_ds/detail/pat_trie_/split_fn_imps.hpp: Same.
111 * include/ext/pb_ds/detail/pat_trie_/traits.hpp: Same.
112 * include/ext/pb_ds/detail/pat_trie_/cond_dtor_entry_dealtor.hpp: Same.
113 * include/ext/pb_ds/detail/pat_trie_/pat_trie_.hpp: Same.
114 * include/ext/pb_ds/detail/pat_trie_/info_fn_imps.hpp: Same.
115 * include/ext/pb_ds/detail/pat_trie_/leaf.hpp: Same.
116 * include/ext/pb_ds/detail/pat_trie_/trace_fn_imps.hpp: Same.
117 * include/ext/pb_ds/detail/pat_trie_/rotate_fn_imps.hpp: Same.
118 * include/ext/pb_ds/detail/pat_trie_/erase_fn_imps.hpp: Same.
119 * include/ext/pb_ds/detail/pat_trie_/node_base.hpp: Same.
120 * include/ext/pb_ds/detail/pat_trie_/node_metadata_base.hpp: Same.
121 * include/ext/pb_ds/detail/pat_trie_/synth_e_access_traits.hpp: Same.
122 * include/ext/pb_ds/detail/pat_trie_/node_iterators.hpp: Same.
123 * include/ext/pb_ds/detail/pat_trie_/internal_node.hpp: Same.
124 * include/ext/pb_ds/detail/pat_trie_/point_iterators.hpp: Same.
125 * include/ext/pb_ds/detail/pat_trie_/iterators_fn_imps.hpp: Same.
126 * include/ext/pb_ds/detail/bin_search_tree_: New.
127 * include/ext/pb_ds/detail/bin_search_tree_/policy_access_fn_imps.hpp: Same.
128 * include/ext/pb_ds/detail/bin_search_tree_/find_fn_imps.hpp: Same.
129 * include/ext/pb_ds/detail/bin_search_tree_/r_erase_fn_imps.hpp: Same.
130 * include/ext/pb_ds/detail/bin_search_tree_/constructors_destructor_fn_imps.hpp: Same.
131 * include/ext/pb_ds/detail/bin_search_tree_/debug_fn_imps.hpp: Same.
132 * include/ext/pb_ds/detail/bin_search_tree_/cond_dtor_entry_dealtor.hpp: Same.
133 * include/ext/pb_ds/detail/bin_search_tree_/traits.hpp: Same.
134 * include/ext/pb_ds/detail/bin_search_tree_/info_fn_imps.hpp: Same.
135 * include/ext/pb_ds/detail/bin_search_tree_/rotate_fn_imps.hpp: Same.
136 * include/ext/pb_ds/detail/bin_search_tree_/erase_fn_imps.hpp: Same.
137 * include/ext/pb_ds/detail/bin_search_tree_/bin_search_tree_.hpp: Same.
138 * include/ext/pb_ds/detail/bin_search_tree_/cond_key_dtor_entry_dealtor.hpp: Same.
139 * include/ext/pb_ds/detail/bin_search_tree_/insert_fn_imps.hpp: Same.
140 * include/ext/pb_ds/detail/bin_search_tree_/node_iterators.hpp: Same.
141 * include/ext/pb_ds/detail/bin_search_tree_/point_iterators.hpp: Same.
142 * include/ext/pb_ds/detail/bin_search_tree_/split_join_fn_imps.hpp: Same.
143 * include/ext/pb_ds/detail/bin_search_tree_/iterators_fn_imps.hpp: Same.
144 * include/ext/pb_ds/detail/gp_hash_table_map_: New.
145 * include/ext/pb_ds/detail/gp_hash_table_map_/constructor_destructor_no_store_hash_fn_imps.hpp: Same.
146 * include/ext/pb_ds/detail/gp_hash_table_map_/erase_store_hash_fn_imps.hpp: Same.
147 * include/ext/pb_ds/detail/gp_hash_table_map_/insert_no_store_hash_fn_imps.hpp: Same.
148 * include/ext/pb_ds/detail/gp_hash_table_map_/resize_store_hash_fn_imps.hpp: Same.
149 * include/ext/pb_ds/detail/gp_hash_table_map_/policy_access_fn_imps.hpp: Same.
150 * include/ext/pb_ds/detail/gp_hash_table_map_/find_fn_imps.hpp: Same.
151 * include/ext/pb_ds/detail/gp_hash_table_map_/gp_ht_map_.hpp: Same.
152 * include/ext/pb_ds/detail/gp_hash_table_map_/constructor_destructor_store_hash_fn_imps.hpp: Same.
153 * include/ext/pb_ds/detail/gp_hash_table_map_/insert_store_hash_fn_imps.hpp: Same.
154 * include/ext/pb_ds/detail/gp_hash_table_map_/debug_fn_imps.hpp: Same.
155 * include/ext/pb_ds/detail/gp_hash_table_map_/iterator_fn_imps.hpp: Same.
156 * include/ext/pb_ds/detail/gp_hash_table_map_/info_fn_imps.hpp: Same.
157 * include/ext/pb_ds/detail/gp_hash_table_map_/find_no_store_hash_fn_imps.hpp: Same.
158 * include/ext/pb_ds/detail/gp_hash_table_map_/trace_fn_imps.hpp: Same.
159 * include/ext/pb_ds/detail/gp_hash_table_map_/erase_fn_imps.hpp: Same.
160 * include/ext/pb_ds/detail/gp_hash_table_map_/find_store_hash_fn_imps.hpp: Same.
161 * include/ext/pb_ds/detail/gp_hash_table_map_/resize_fn_imps.hpp: Same.
162 * include/ext/pb_ds/detail/gp_hash_table_map_/debug_no_store_hash_fn_imps.hpp: Same.
163 * include/ext/pb_ds/detail/gp_hash_table_map_/constructor_destructor_fn_imps.hpp: Same.
164 * include/ext/pb_ds/detail/gp_hash_table_map_/insert_fn_imps.hpp: Same.
165 * include/ext/pb_ds/detail/gp_hash_table_map_/debug_store_hash_fn_imps.hpp: Same.
166 * include/ext/pb_ds/detail/gp_hash_table_map_/erase_no_store_hash_fn_imps.hpp: Same.
167 * include/ext/pb_ds/detail/gp_hash_table_map_/standard_policies.hpp: Same.
168 * include/ext/pb_ds/detail/gp_hash_table_map_/resize_no_store_hash_fn_imps.hpp: Same.
169 * include/ext/pb_ds/detail/standard_policies.hpp: Same.
170 * include/ext/pb_ds/detail/typelist: New.
171 * include/ext/pb_ds/detail/typelist/typelist_flatten.hpp: Same.
172 * include/ext/pb_ds/detail/typelist/typelist_contains.hpp: Same.
173 * include/ext/pb_ds/detail/typelist/typelist_typelist_append.hpp: Same.
174 * include/ext/pb_ds/detail/typelist/typelist_apply.hpp: Same.
175 * include/ext/pb_ds/detail/typelist/typelist_filter.hpp: Same.
176 * include/ext/pb_ds/detail/typelist/typelist_append.hpp: Same.
177 * include/ext/pb_ds/detail/typelist/typelist_assoc_container_find.hpp: Same.
178 * include/ext/pb_ds/detail/typelist/typelist_transform.hpp: Same.
179 * include/ext/pb_ds/detail/typelist/typelist_at_index.hpp: Same.
180 * include/ext/pb_ds/detail/tree_policy: New.
181 * include/ext/pb_ds/detail/tree_policy/order_statistics_imp.hpp: Same.
182 * include/ext/pb_ds/detail/tree_policy/node_metadata_selector.hpp: Same.
183 * include/ext/pb_ds/detail/tree_policy/null_node_update_imp.hpp: Same.
184 * include/ext/pb_ds/detail/tree_policy/sample_tree_node_update.hpp: Same.
185 * include/ext/pb_ds/detail/basic_tree_policy: New.
186 * include/ext/pb_ds/detail/basic_tree_policy/basic_tree_policy_base.hpp: Same.
187 * include/ext/pb_ds/detail/basic_tree_policy/null_node_metadata.hpp: Same.
188 * include/ext/pb_ds/detail/basic_tree_policy/traits.hpp: Same.
189 * include/ext/pb_ds/detail/types_traits.hpp: Same.
190 * include/ext/pb_ds/detail/binary_heap_: New.
191 * include/ext/pb_ds/detail/binary_heap_/policy_access_fn_imps.hpp: Same.
192 * include/ext/pb_ds/detail/binary_heap_/find_fn_imps.hpp: Same.
193 * include/ext/pb_ds/detail/binary_heap_/const_iterator.hpp: Same.
194 * include/ext/pb_ds/detail/binary_heap_/entry_cmp.hpp: Same.
195 * include/ext/pb_ds/detail/binary_heap_/constructors_destructor_fn_imps.hpp: Same.
196 * include/ext/pb_ds/detail/binary_heap_/debug_fn_imps.hpp: Same.
197 * include/ext/pb_ds/detail/binary_heap_/info_fn_imps.hpp: Same.
198 * include/ext/pb_ds/detail/binary_heap_/const_point_iterator.hpp: Same.
199 * include/ext/pb_ds/detail/binary_heap_/trace_fn_imps.hpp: Same.
200 * include/ext/pb_ds/detail/binary_heap_/erase_fn_imps.hpp: Same.
201 * include/ext/pb_ds/detail/binary_heap_/entry_pred.hpp: Same.
202 * include/ext/pb_ds/detail/binary_heap_/insert_fn_imps.hpp: Same.
203 * include/ext/pb_ds/detail/binary_heap_/resize_policy.hpp: Same.
204 * include/ext/pb_ds/detail/binary_heap_/binary_heap_.hpp: Same.
205 * include/ext/pb_ds/detail/binary_heap_/split_join_fn_imps.hpp: Same.
206 * include/ext/pb_ds/detail/binary_heap_/iterators_fn_imps.hpp: Same.
207 * include/ext/pb_ds/detail/trie_policy: New.
208 * include/ext/pb_ds/detail/trie_policy/string_trie_e_access_traits_imp.hpp: Same.
209 * include/ext/pb_ds/detail/trie_policy/order_statistics_imp.hpp: Same.
210 * include/ext/pb_ds/detail/trie_policy/sample_trie_node_update.hpp: Same.
211 * include/ext/pb_ds/detail/trie_policy/trie_policy_base.hpp: Same.
212 * include/ext/pb_ds/detail/trie_policy/prefix_search_node_update_imp.hpp: Same.
213 * include/ext/pb_ds/detail/trie_policy/sample_trie_e_access_traits.hpp: Same.
214 * include/ext/pb_ds/detail/trie_policy/node_metadata_selector.hpp: Same.
215 * include/ext/pb_ds/detail/trie_policy/null_node_update_imp.hpp: Same.
216 * include/ext/pb_ds/detail/cond_dealtor.hpp: Same.
217 * include/ext/pb_ds/detail/priority_queue_base_dispatch.hpp: Same.
218 * include/ext/pb_ds/detail/pairing_heap_: Name.
219 * include/ext/pb_ds/detail/pairing_heap_/erase_fn_imps.hpp: Same.
220 * include/ext/pb_ds/detail/pairing_heap_/find_fn_imps.hpp: Same.
221 * include/ext/pb_ds/detail/pairing_heap_/insert_fn_imps.hpp: Same.
222 * include/ext/pb_ds/detail/pairing_heap_/debug_fn_imps.hpp: Same.
223 * include/ext/pb_ds/detail/pairing_heap_/constructors_destructor_fn_imps.hpp: Same.
224 * include/ext/pb_ds/detail/pairing_heap_/pairing_heap_.hpp: Same.
225 * include/ext/pb_ds/detail/pairing_heap_/split_join_fn_imps.hpp: Same.
226 * include/ext/pb_ds/detail/binomial_heap_: New.
227 * include/ext/pb_ds/detail/binomial_heap_/debug_fn_imps.hpp: Same.
228 * include/ext/pb_ds/detail/binomial_heap_/constructors_destructor_fn_imps.hpp: Same.
229 * include/ext/pb_ds/detail/binomial_heap_/binomial_heap_.hpp: Same.
230 * include/ext/pb_ds/detail/constructors_destructor_fn_imps.hpp: Same.
231 * include/ext/pb_ds/detail/type_utils.hpp: Same.
232 * include/ext/pb_ds/detail/eq_fn: New.
233 * include/ext/pb_ds/detail/eq_fn/hash_eq_fn.hpp: Same.
234 * include/ext/pb_ds/detail/eq_fn/eq_by_less.hpp: Same.
235 * include/ext/pb_ds/detail/basic_types.hpp: Same.
236 * include/ext/pb_ds/detail/list_update_policy: New.
237 * include/ext/pb_ds/detail/list_update_policy/mtf_lu_policy_imp.hpp: Same.
238 * include/ext/pb_ds/detail/list_update_policy/counter_lu_metadata.hpp: Same.
239 * include/ext/pb_ds/detail/list_update_policy/sample_update_policy.hpp: Same.
240 * include/ext/pb_ds/detail/list_update_policy/counter_lu_policy_imp.hpp: Same.
241 * include/ext/pb_ds/detail/thin_heap_: New.
242 * include/ext/pb_ds/detail/thin_heap_/trace_fn_imps.hpp: Same.
243 * include/ext/pb_ds/detail/thin_heap_/erase_fn_imps.hpp: Same.
244 * include/ext/pb_ds/detail/thin_heap_/find_fn_imps.hpp: Same.
245 * include/ext/pb_ds/detail/thin_heap_/thin_heap_.hpp: Same.
246 * include/ext/pb_ds/detail/thin_heap_/insert_fn_imps.hpp: Same.
247 * include/ext/pb_ds/detail/thin_heap_/debug_fn_imps.hpp: Same.
248 * include/ext/pb_ds/detail/thin_heap_/constructors_destructor_fn_imps.hpp: Same.
249 * include/ext/pb_ds/detail/thin_heap_/split_join_fn_imps.hpp: Same.
250 * include/ext/pb_ds/detail/left_child_next_sibling_heap_: New.
251 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/trace_fn_imps.hpp: Same.
252 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/erase_fn_imps.hpp: Same.
253 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/null_metadata.hpp: Same.
254 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/policy_access_fn_imps.hpp: Same.
255 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/left_child_next_sibling_heap_.hpp: Same.
256 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/insert_fn_imps.hpp: Same.
257 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/const_iterator.hpp: Same.
258 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/debug_fn_imps.hpp: Same.
259 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/constructors_destructor_fn_imps.hpp: Same.
260 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/node.hpp: Same.
261 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/info_fn_imps.hpp: Same.
262 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/iterators_fn_imps.hpp: Same.
263 * include/ext/pb_ds/detail/left_child_next_sibling_heap_/const_point_iterator.hpp: Same.
264 * include/ext/pb_ds/detail/ov_tree_map_: New.
265 * include/ext/pb_ds/detail/ov_tree_map_/erase_fn_imps.hpp: Same.
266 * include/ext/pb_ds/detail/ov_tree_map_/policy_access_fn_imps.hpp: Same.
267 * include/ext/pb_ds/detail/ov_tree_map_/cond_dtor.hpp: Same.
268 * include/ext/pb_ds/detail/ov_tree_map_/insert_fn_imps.hpp: Same.
269 * include/ext/pb_ds/detail/ov_tree_map_/ov_tree_map_.hpp: Same.
270 * include/ext/pb_ds/detail/ov_tree_map_/node_iterators.hpp: Same.
271 * include/ext/pb_ds/detail/ov_tree_map_/debug_fn_imps.hpp: Same.
272 * include/ext/pb_ds/detail/ov_tree_map_/constructors_destructor_fn_imps.hpp: Same.
273 * include/ext/pb_ds/detail/ov_tree_map_/split_join_fn_imps.hpp: Same.
274 * include/ext/pb_ds/detail/ov_tree_map_/traits.hpp: Same.
275 * include/ext/pb_ds/detail/ov_tree_map_/info_fn_imps.hpp: Same.
276 * include/ext/pb_ds/detail/ov_tree_map_/iterators_fn_imps.hpp: Same.
277 * include/ext/pb_ds/detail/map_debug_base.hpp: Same.
278 * include/ext/pb_ds/detail/hash_fn: New.
279 * include/ext/pb_ds/detail/hash_fn/linear_probe_fn_imp.hpp: Same.
280 * include/ext/pb_ds/detail/hash_fn/mod_based_range_hashing.hpp: Same.
281 * include/ext/pb_ds/detail/hash_fn/ranged_probe_fn.hpp: Same.
282 * include/ext/pb_ds/detail/hash_fn/sample_probe_fn.hpp: Same.
283 * include/ext/pb_ds/detail/hash_fn/direct_mod_range_hashing_imp.hpp: Same.
284 * include/ext/pb_ds/detail/hash_fn/sample_ranged_probe_fn.hpp: Same.
285 * include/ext/pb_ds/detail/hash_fn/quadratic_probe_fn_imp.hpp: Same.
286 * include/ext/pb_ds/detail/hash_fn/sample_range_hashing.hpp: Same.
287 * include/ext/pb_ds/detail/hash_fn/probe_fn_base.hpp: Same.
288 * include/ext/pb_ds/detail/hash_fn/ranged_hash_fn.hpp: Same.
289 * include/ext/pb_ds/detail/hash_fn/mask_based_range_hashing.hpp: Same.
290 * include/ext/pb_ds/detail/hash_fn/sample_ranged_hash_fn.hpp: Same.
291 * include/ext/pb_ds/detail/hash_fn/direct_mask_range_hashing_imp.hpp: Same.
292 * include/ext/pb_ds/detail/splay_tree_: New.
293 * include/ext/pb_ds/detail/splay_tree_/erase_fn_imps.hpp: Same.
294 * include/ext/pb_ds/detail/splay_tree_/find_fn_imps.hpp: Same.
295 * include/ext/pb_ds/detail/splay_tree_/insert_fn_imps.hpp: Same.
296 * include/ext/pb_ds/detail/splay_tree_/debug_fn_imps.hpp: Same.
297 * include/ext/pb_ds/detail/splay_tree_/constructors_destructor_fn_imps.hpp: Same.
298 * include/ext/pb_ds/detail/splay_tree_/splay_fn_imps.hpp: Same.
299 * include/ext/pb_ds/detail/splay_tree_/node.hpp: Same.
300 * include/ext/pb_ds/detail/splay_tree_/split_join_fn_imps.hpp: Same.
301 * include/ext/pb_ds/detail/splay_tree_/splay_tree_.hpp: Same.
302 * include/ext/pb_ds/detail/splay_tree_/traits.hpp: Same.
303 * include/ext/pb_ds/detail/splay_tree_/info_fn_imps.hpp: Same.
304 * include/ext/pb_ds/detail/list_update_map_: New.
305 * include/ext/pb_ds/detail/list_update_map_/trace_fn_imps.hpp: Same.
306 * include/ext/pb_ds/detail/list_update_map_/erase_fn_imps.hpp: Same.
307 * include/ext/pb_ds/detail/list_update_map_/find_fn_imps.hpp: Same.
308 * include/ext/pb_ds/detail/list_update_map_/entry_metadata_base.hpp: Same.
309 * include/ext/pb_ds/detail/list_update_map_/lu_map_.hpp: Same.
310 * include/ext/pb_ds/detail/list_update_map_/constructor_destructor_fn_imps.hpp: Same.
311 * include/ext/pb_ds/detail/list_update_map_/insert_fn_imps.hpp: Same.
312 * include/ext/pb_ds/detail/list_update_map_/debug_fn_imps.hpp: Same.
313 * include/ext/pb_ds/detail/list_update_map_/info_fn_imps.hpp: Same.
314 * include/ext/pb_ds/detail/list_update_map_/iterators_fn_imps.hpp: Same.
315 * include/ext/pb_ds/detail/rc_binomial_heap_: New.
316 * include/ext/pb_ds/detail/rc_binomial_heap_/trace_fn_imps.hpp: Same.
317 * include/ext/pb_ds/detail/rc_binomial_heap_/erase_fn_imps.hpp: Same.
318 * include/ext/pb_ds/detail/rc_binomial_heap_/rc_binomial_heap_.hpp: Same.
319 * include/ext/pb_ds/detail/rc_binomial_heap_/insert_fn_imps.hpp: Same.
320 * include/ext/pb_ds/detail/rc_binomial_heap_/debug_fn_imps.hpp: Same.
321 * include/ext/pb_ds/detail/rc_binomial_heap_/constructors_destructor_fn_imps.hpp: Same.
322 * include/ext/pb_ds/detail/rc_binomial_heap_/rc.hpp: Same.
323 * include/ext/pb_ds/detail/rc_binomial_heap_/split_join_fn_imps.hpp: Same.
324 * include/ext/pb_ds/detail/rb_tree_map_: New.
325 * include/ext/pb_ds/detail/rb_tree_map_/erase_fn_imps.hpp: Same.
326 * include/ext/pb_ds/detail/rb_tree_map_/find_fn_imps.hpp: Same.
327 * include/ext/pb_ds/detail/rb_tree_map_/insert_fn_imps.hpp: Same.
328 * include/ext/pb_ds/detail/rb_tree_map_/rb_tree_.hpp: Same.
329 * include/ext/pb_ds/detail/rb_tree_map_/debug_fn_imps.hpp: Same.
330 * include/ext/pb_ds/detail/rb_tree_map_/constructors_destructor_fn_imps.hpp: Same.
331 * include/ext/pb_ds/detail/rb_tree_map_/node.hpp: Same.
332 * include/ext/pb_ds/detail/rb_tree_map_/split_join_fn_imps.hpp: Same.
333 * include/ext/pb_ds/detail/rb_tree_map_/traits.hpp: Same.
334 * include/ext/pb_ds/detail/rb_tree_map_/info_fn_imps.hpp: Same.
335 * include/ext/pb_ds/list_update_policy.hpp: Same.
336 * include/ext/pb_ds/exception.hpp: Same.
337 * include/ext/pb_ds/tree_policy.hpp: Same.
338 * include/ext/pb_ds/tag_and_trait.hpp: Same.
339 * include/ext/pb_ds/hash_policy.hpp: Same.
340 * include/ext/pb_ds/trie_policy.hpp: Same.
341 * include/ext/pb_ds/priority_queue.hpp: Same.
342
343 * docs/html/ext/pb_ds: New.
344 * docs/html/ext/pb_ds/container_tag.html: Same.
345 * docs/html/ext/pb_ds/trivial_iterator_tag.html: Same.
346 * docs/html/ext/pb_ds/tree_text_lor_find_timing_test_local.png
347 * docs/html/ext/pb_ds/sample_trie_e_access_traits.html: Same.
348 * docs/html/ext/pb_ds/gp_hash_table.html: Same.
349 * docs/html/ext/pb_ds/priority_queue_tag_cd.svg
350 * docs/html/ext/pb_ds/container_cd.svg
351 * docs/html/ext/pb_ds/linear_probe_fn.html: Same.
352 * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test_local.png
353 * docs/html/ext/pb_ds/quadratic_probe_fn.html: Same.
354 * docs/html/ext/pb_ds/assoc_regression_tests.html: Same.
355 * docs/html/ext/pb_ds/tree_tag.html: Same.
356 * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test.html: Same.
357 * docs/html/ext/pb_ds/interface.html: Same.
358 * docs/html/ext/pb_ds/hash_zlob_random_int_find_timing_test_msvc.png
359 * docs/html/ext/pb_ds/hash_random_int_subscript_find_timing_test.html: Same.
360 * docs/html/ext/pb_ds/lu_based_containers.html: Same.
361 * docs/html/ext/pb_ds/embedded_lists_3.png
362 * docs/html/ext/pb_ds/tree_text_find_find_timing_test.html: Same.
363 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_hash_local.png
364 * docs/html/ext/pb_ds/assoc_performance_tests.html: Same.
365 * docs/html/ext/pb_ds/list_update.html: Same.
366 * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test_gcc.png
367 * docs/html/ext/pb_ds/tree_text_insert_timing_test_pat_trie_local.png
368 * docs/html/ext/pb_ds/point_iterators_range_ops_1.png
369 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_insert_msvc.png
370 * docs/html/ext/pb_ds/hash_zlob_random_int_find_timing_test_gcc.png
371 * docs/html/ext/pb_ds/text_find_timing_test_tree_like_msvc.png
372 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_tree_local.png
373 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_local.png
374 * docs/html/ext/pb_ds/tree_text_insert_timing_test_pat_trie_msvc.png
375 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test.html: Same.
376 * docs/html/ext/pb_ds/move_to_front_lu_policy.html: Same.
377 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_hash_gcc.png
378 * docs/html/ext/pb_ds/hash_random_int_find_find_timing_test.html: Same.
379 * docs/html/ext/pb_ds/string_trie_e_access_traits.html: Same.
380 * docs/html/ext/pb_ds/prerequisites.html: Same.
381 * docs/html/ext/pb_ds/gp_hash_tag.html: Same.
382 * docs/html/ext/pb_ds/priority_queue_tag_cd.png
383 * docs/html/ext/pb_ds/container_cd.png
384 * docs/html/ext/pb_ds/priority_queue_text_join_timing_test_gcc.png
385 * docs/html/ext/pb_ds/container_base.html: Same.
386 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_hash_msvc.png
387 * docs/html/ext/pb_ds/tree_random_int_find_find_timing_test.html: Same.
388 * docs/html/ext/pb_ds/binary_priority_queue_random_int_push_timing_test_msvc.png
389 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_find_local.png
390 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_find_gcc.png
391 * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test_msvc.png
392 * docs/html/ext/pb_ds/random_int_find_find_timing_test_tree_msvc.png
393 * docs/html/ext/pb_ds/text_find_timing_test_hash_local.png
394 * docs/html/ext/pb_ds/tree_text_insert_timing_test_node_tree_msvc.png
395 * docs/html/ext/pb_ds/ov_tree_tag.html: Same.
396 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_hash_local.png
397 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_hash_msvc.png
398 * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test_msvc.png
399 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_pairing_thin_msvc.png
400 * docs/html/ext/pb_ds/list_update_tag.html: Same.
401 * docs/html/ext/pb_ds/balls_and_bins.png
402 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_tree_local.png
403 * docs/html/ext/pb_ds/disclaimer.html: Same.
404 * docs/html/ext/pb_ds/insert_error.html: Same.
405 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_hash_gcc.png
406 * docs/html/ext/pb_ds/ccgp_hash_random_int_subscript_timing_test_insert_gcc.png
407 * docs/html/ext/pb_ds/examples.html: Same.
408 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small.html: Same.
409 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_pop_timing_test_gcc.png
410 * docs/html/ext/pb_ds/sample_probe_fn.html: Same.
411 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_hash_local.png
412 * docs/html/ext/pb_ds/priority_queue_text_push_timing_test.html: Same.
413 * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test_gcc.png
414 * docs/html/ext/pb_ds/null_mapped_type.html: Same.
415 * docs/html/ext/pb_ds/binary_priority_queue_random_int_push_timing_test_gcc.png
416 * docs/html/ext/pb_ds/tree_order_statistics_timing_test_gcc.png
417 * docs/html/ext/pb_ds/associative_container_tag.html: Same.
418 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_tree_local.png
419 * docs/html/ext/pb_ds/design.html: Same.
420 * docs/html/ext/pb_ds/cc_hash_max_collision_check_resize_trigger.html: Same.
421 * docs/html/ext/pb_ds/pairing_heap_tag.html: Same.
422 * docs/html/ext/pb_ds/tree_text_lor_find_timing_test_gcc.png
423 * docs/html/ext/pb_ds/references.html: Same.
424 * docs/html/ext/pb_ds/tree_order_statistics_timing_test_msvc.png
425 * docs/html/ext/pb_ds/hash_load_check_resize_trigger.html: Same.
426 * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test_gcc.png
427 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_pairing_thin_gcc.png
428 * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test_gcc.png
429 * docs/html/ext/pb_ds/pq_different_underlying_dss.png
430 * docs/html/ext/pb_ds/insert_resize_sequence_diagram1.png
431 * docs/html/ext/pb_ds/pq_regression_tests.html: Same.
432 * docs/html/ext/pb_ds/sample_tree_node_update.html: Same.
433 * docs/html/ext/pb_ds/invalidation_guarantee_erase.png
434 * docs/html/ext/pb_ds/basic_invalidation_guarantee.html: Same.
435 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_hash_local.png
436 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_hash_gcc.png
437 * docs/html/ext/pb_ds/hash_zlob_random_int_find_timing_test_local.png
438 * docs/html/ext/pb_ds/point_iterators_range_ops_2.png
439 * docs/html/ext/pb_ds/null_probe_fn.html: Same.
440 * docs/html/ext/pb_ds/hash_prime_size_policy.html: Same.
441 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_hash_msvc.png
442 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_gcc.png
443 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_tree_local.png
444 * docs/html/ext/pb_ds/binary_priority_queue_random_int_push_timing_test_local.png
445 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_hash_msvc.png
446 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_tree_gcc.png
447 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large.html: Same.
448 * docs/html/ext/pb_ds/sample_resize_policy.html: Same.
449 * docs/html/ext/pb_ds/binomial_heap_tag.html: Same.
450 * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test_local.png
451 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_pairing_thin_local.png
452 * docs/html/ext/pb_ds/tree_text_lor_find_find_timing_test.html: Same.
453 * docs/html/ext/pb_ds/priority_queue_text_join_timing_test_msvc.png
454 * docs/html/ext/pb_ds/trie_based_containers.html: Same.
455 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_insert_gcc.png
456 * docs/html/ext/pb_ds/tree_split_join_timing_test_local.png
457 * docs/html/ext/pb_ds/text_find_timing_test_hash_gcc.png
458 * docs/html/ext/pb_ds/motivation.html: Same.
459 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_tree_msvc.png
460 * docs/html/ext/pb_ds/tree_split_join_timing_test_gcc.png
461 * docs/html/ext/pb_ds/tree.html: Same.
462 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_hash_gcc.png
463 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_insert_msvc.png
464 * docs/html/ext/pb_ds/invalidation_guarantee_cd.png
465 * docs/html/ext/pb_ds/tutorial.html: Same.
466 * docs/html/ext/pb_ds/null_trie_node_update.html: Same.
467 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_gcc.png
468 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_tree_msvc.png
469 * docs/html/ext/pb_ds/ccgp_hash_random_int_subscript_timing_test_insert_local.png
470 * docs/html/ext/pb_ds/point_iterators_cd.png
471 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_hash_local.png
472 * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test_local.png
473 * docs/html/ext/pb_ds/rb_tree_tag.html: Same.
474 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_find_msvc.png
475 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_timing_test_msvc.png
476 * docs/html/ext/pb_ds/tree_text_insert_timing_test_pat_trie_gcc.png
477 * docs/html/ext/pb_ds/exceptions.html: Same.
478 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_msvc.png
479 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_tree_local.png
480 * docs/html/ext/pb_ds/hash_policy_cd.png
481 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_tree_gcc.png
482 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small.html: Same.
483 * docs/html/ext/pb_ds/ds_gen.html: Same.
484 * docs/html/ext/pb_ds/hash_exponential_size_policy.html: Same.
485 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_insert_local.png
486 * docs/html/ext/pb_ds/hash_random_int_erase_mem_usage_test_msvc.png
487 * docs/html/ext/pb_ds/index.html: Same.
488 * docs/html/ext/pb_ds/binary_heap_tag.html: Same.
489 * docs/html/ext/pb_ds/basic_hash_tag.html: Same.
490 * docs/html/ext/pb_ds/trie_order_statistics_node_update.html: Same.
491 * docs/html/ext/pb_ds/sample_resize_trigger.html: Same.
492 * docs/html/ext/pb_ds/priority_queue_text_push_timing_test_local.png
493 * docs/html/ext/pb_ds/hash_text_find_find_timing_test.html: Same.
494 * docs/html/ext/pb_ds/tree_text_insert_timing_test.html: Same.
495 * docs/html/ext/pb_ds/trie_tag.html: Same.
496 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_find_local.png
497 * docs/html/ext/pb_ds/pq_tests.html: Same.
498 * docs/html/ext/pb_ds/insert_resize_sequence_diagram2.png
499 * docs/html/ext/pb_ds/node_invariant_invalidations.png
500 * docs/html/ext/pb_ds/priority_queue_text_modify_down_timing_test_msvc.png
501 * docs/html/ext/pb_ds/resize_policy_cd.png
502 * docs/html/ext/pb_ds/embedded_lists_1.png
503 * docs/html/ext/pb_ds/hash_ranged_hash_range_hashing_fns.png
504 * docs/html/ext/pb_ds/null_lu_metadata.html: Same.
505 * docs/html/ext/pb_ds/tree_order_statistics_timing_test.html: Same.
506 * docs/html/ext/pb_ds/trie_prefix_search_node_update.html: Same.
507 * docs/html/ext/pb_ds/hash_range_hashing_seq_diagram.png
508 * docs/html/ext/pb_ds/point_invalidation_guarantee.html: Same.
509 * docs/html/ext/pb_ds/direct_mod_range_hashing.html: Same.
510 * docs/html/ext/pb_ds/tree_text_insert_timing_test_vector_tree_local.png
511 * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test_msvc.png
512 * docs/html/ext/pb_ds/misc.html: Same.
513 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_hash_local.png
514 * docs/html/ext/pb_ds/counter_lu_policy.html: Same.
515 * docs/html/ext/pb_ds/different_underlying_dss.png
516 * docs/html/ext/pb_ds/restoring_node_invariants.png
517 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large.html: Same.
518 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_timing_test_local.png
519 * docs/html/ext/pb_ds/sample_update_policy.html: Same.
520 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_timing_test_gcc.png
521 * docs/html/ext/pb_ds/tree_order_statistics_timing_test_local.png
522 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_tree_msvc.png
523 * docs/html/ext/pb_ds/simple_list.png
524 * docs/html/ext/pb_ds/text_find_timing_test_hash_msvc.png
525 * docs/html/ext/pb_ds/assoc_examples.html: Same.
526 * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test_local.png
527 * docs/html/ext/pb_ds/hash_based_containers.html: Same.
528 * docs/html/ext/pb_ds/text_find_timing_test_tree_like_local.png
529 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_tree_local.png
530 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_tree_gcc.png
531 * docs/html/ext/pb_ds/tree_node_iterator.html: Same.
532 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_pairing_thin_msvc.png
533 * docs/html/ext/pb_ds/trie_node_iterator.html: Same.
534 * docs/html/ext/pb_ds/tree_based_containers.html: Same.
535 * docs/html/ext/pb_ds/hash_random_int_subscript_insert_timing_test.html: Same.
536 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_tree_msvc.png
537 * docs/html/ext/pb_ds/ccgp_hash_random_int_subscript_timing_test_insert_msvc.png
538 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_hash_msvc.png
539 * docs/html/ext/pb_ds/priority_queue_text_push_timing_test_gcc.png
540 * docs/html/ext/pb_ds/rationale_null_node_updator.png
541 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_pairing_thin_local.png
542 * docs/html/ext/pb_ds/lu.png
543 * docs/html/ext/pb_ds/assoc_container_traits.html: Same.
544 * docs/html/ext/pb_ds/gp_hash_random_int_find_timing_test_msvc.png
545 * docs/html/ext/pb_ds/assoc_design.html: Same.
546 * docs/html/ext/pb_ds/splay_tree_tag.html: Same.
547 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_find_gcc.png
548 * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test.html: Same.
549 * docs/html/ext/pb_ds/assoc_container_tag_cd.svg
550 * docs/html/ext/pb_ds/resize_error.html: Same.
551 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_hash_msvc.png
552 * docs/html/ext/pb_ds/tree_text_insert_timing_test_node_tree_gcc.png
553 * docs/html/ext/pb_ds/priority_queue_text_join_timing_test.html: Same.
554 * docs/html/ext/pb_ds/basic_tree_assoc_container_const_node_iterator.html: Same.
555 * docs/html/ext/pb_ds/gp_hash_random_int_find_timing_test_gcc.png
556 * docs/html/ext/pb_ds/trie_const_node_iterator.html: Same.
557 * docs/html/ext/pb_ds/hash_zlob_random_int_find_find_timing_test.html: Same.
558 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_tree_gcc.png
559 * docs/html/ext/pb_ds/sample_size_policy.html: Same.
560 * docs/html/ext/pb_ds/tree_text_insert_timing_test_vector_tree_gcc.png
561 * docs/html/ext/pb_ds/cc_hash_table.html: Same.
562 * docs/html/ext/pb_ds/node_invariants.png
563 * docs/html/ext/pb_ds/tree_split_join_timing_test_msvc.png
564 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test.html: Same.
565 * docs/html/ext/pb_ds/tree_order_statistics_node_update.html: Same.
566 * docs/html/ext/pb_ds/cc_hash_random_int_find_timing_test_msvc.png
567 * docs/html/ext/pb_ds/cc_hash_random_int_subscript_timing_test_insert_local.png
568 * docs/html/ext/pb_ds/priority_queue.html: Same.
569 * docs/html/ext/pb_ds/assoc_tests.html: Same.
570 * docs/html/ext/pb_ds/assoc_container_tag_cd.png
571 * docs/html/ext/pb_ds/basic_hash_table.html: Same.
572 * docs/html/ext/pb_ds/basic_tree_tag.html: Same.
573 * docs/html/ext/pb_ds/tree_split_join_timing_test.html: Same.
574 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_local.png
575 * docs/html/ext/pb_ds/insert_resize_sequence_diagram3.png
576 * docs/html/ext/pb_ds/embedded_lists_2.png
577 * docs/html/ext/pb_ds/random_int_find_find_timing_test_tree_local.png
578 * docs/html/ext/pb_ds/sample_ranged_probe_fn.html: Same.
579 * docs/html/ext/pb_ds/random_int_find_find_timing_test_tree_gcc.png
580 * docs/html/ext/pb_ds/sample_trie_node_update.html: Same.
581 * docs/html/ext/pb_ds/introduction.html: Same.
582 * docs/html/ext/pb_ds/pq_performance_tests.html: Same.
583 * docs/html/ext/pb_ds/pat_trie.png
584 * docs/html/ext/pb_ds/range_invalidation_guarantee.html: Same.
585 * docs/html/ext/pb_ds/contact.html: Same.
586 * docs/html/ext/pb_ds/sample_range_hashing.html: Same.
587 * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test_local.png
588 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large_s2p_hash_gcc.png
589 * docs/html/ext/pb_ds/update_seq_diagram.png
590 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_large_s2p_tree_gcc.png
591 * docs/html/ext/pb_ds/direct_mask_range_hashing.html: Same.
592 * docs/html/ext/pb_ds/tests.html: Same.
593 * docs/html/ext/pb_ds/cc_hash_random_int_find_timing_test_gcc.png
594 * docs/html/ext/pb_ds/tree_node_updator_policy_cd.png
595 * docs/html/ext/pb_ds/text_find_timing_test_tree_like_gcc.png
596 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_large.html: Same.
597 * docs/html/ext/pb_ds/trie_node_updator_policy_cd.png
598 * docs/html/ext/pb_ds/priority_queue_random_int_push_timing_test_msvc.png
599 * docs/html/ext/pb_ds/concepts.html: Same.
600 * docs/html/ext/pb_ds/pq_examples.html: Same.
601 * docs/html/ext/pb_ds/priority_queue_tag.html: Same.
602 * docs/html/ext/pb_ds/priority_queue_random_int_push_pop_timing_test.html: Same.
603 * docs/html/ext/pb_ds/update_policy_cd.png
604 * docs/html/ext/pb_ds/thin_heap_tag.html: Same.
605 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_pop_timing_test_msvc.png
606 * docs/html/ext/pb_ds/basic_tree.html: Same.
607 * docs/html/ext/pb_ds/null_hash_fn.html: Same.
608 * docs/html/ext/pb_ds/null_tree_node_update.html: Same.
609 * docs/html/ext/pb_ds/priority_queue_text_modify_up_timing_test_pairing_thin_gcc.png
610 * docs/html/ext/pb_ds/trie.html: Same.
611 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small_s2p_tree_msvc.png
612 * docs/html/ext/pb_ds/rc_binomial_heap_tag.html: Same.
613 * docs/html/ext/pb_ds/priority_queue_text_push_timing_test_msvc.png
614 * docs/html/ext/pb_ds/pq_container_traits.html: Same.
615 * docs/html/ext/pb_ds/pq_design.html: Same.
616 * docs/html/ext/pb_ds/checked_by_tidy.gif
617 * docs/html/ext/pb_ds/tree_text_insert_timing_test_node_tree_local.png
618 * docs/html/ext/pb_ds/multimap_text_insert_mem_usage_test_small_s2p_hash_gcc.png
619 * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test.html: Same.
620 * docs/html/ext/pb_ds/multimap_text_insert_timing_test_small_s2p_tree_gcc.png
621 * docs/html/ext/pb_ds/pairing_priority_queue_text_push_pop_timing_test_local.png
622 * docs/html/ext/pb_ds/acks.html: Same.
623 * docs/html/ext/pb_ds/gp_hash_random_int_find_timing_test_local.png
624 * docs/html/ext/pb_ds/cc_hash_tag.html: Same.
625 * docs/html/ext/pb_ds/sample_ranged_hash_fn.html: Same.
626 * docs/html/ext/pb_ds/multimap_text_find_timing_test_large_s2p_tree_msvc.png
627 * docs/html/ext/pb_ds/priority_queue_text_pop_mem_usage_test.html: Same.
628 * docs/html/ext/pb_ds/multimap_text_find_timing_test_small.html: Same.
629 * docs/html/ext/pb_ds/tree_text_lor_find_timing_test_msvc.png
630 * docs/html/ext/pb_ds/hash_range_hashing_seq_diagram2.png
631 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_find_msvc.png
632 * docs/html/ext/pb_ds/PythonPoweredSmall.gif
633 * docs/html/ext/pb_ds/cc_hash_random_int_find_timing_test_local.png
634 * docs/html/ext/pb_ds/pat_trie_tag.html: Same.
635 * docs/html/ext/pb_ds/hash_standard_resize_policy.html: Same.
636 * docs/html/ext/pb_ds/tree_text_insert_timing_test_vector_tree_msvc.png
637 * docs/html/ext/pb_ds/gp_hash_random_int_subscript_timing_test_insert_gcc.png
638 * docs/html/ext/pb_ds/join_error.html: Same.
639 * docs/html/ext/pb_ds/priority_queue_text_push_pop_timing_test_gcc.png
640 * docs/html/ext/pb_ds/priority_queue_text_join_timing_test_local.png
641
642 * testsuite/ext/pb_ds: New.
643 * testsuite/ext/pb_ds/regression: New.
644 * testsuite/ext/pb_ds/regression/trie_data_map_rand.cc: Same.
645 * testsuite/ext/pb_ds/regression/hash_data_map_rand.cc: Same.
646 * testsuite/ext/pb_ds/regression/associative_containers.cc: Same.
647 * testsuite/ext/pb_ds/regression/list_update_no_data_map_rand.cc: Same.
648 * testsuite/ext/pb_ds/regression/tree_no_data_map_rand.cc: Same.
649 * testsuite/ext/pb_ds/regression/list_update_data_map_rand.cc: Same.
650 * testsuite/ext/pb_ds/regression/priority_queues.cc: Same.
651 * testsuite/ext/pb_ds/regression/hash_no_data_map_rand.cc: Same.
652 * testsuite/ext/pb_ds/regression/priority_queue_rand.cc: Same.
653 * testsuite/ext/pb_ds/regression/trie_no_data_map_rand.cc: Same.
654 * testsuite/ext/pb_ds/regression/tree_data_map_rand.cc: Same.
655 * testsuite/ext/pb_ds/example: New.
656 * testsuite/ext/pb_ds/example/hash_shift_mask.cc: Same.
657 * testsuite/ext/pb_ds/example/basic_set.cc: Same.
658 * testsuite/ext/pb_ds/example/hash_illegal_resize.cc: Same.
659 * testsuite/ext/pb_ds/example/hash_resize_neg.cc: Same.
660 * testsuite/ext/pb_ds/example/store_hash.cc: Same.
661 * testsuite/ext/pb_ds/example/assoc_container_traits.cc: Same.
662 * testsuite/ext/pb_ds/example/hash_load_set_change.cc: Same.
663 * testsuite/ext/pb_ds/example/ranged_hash.cc: Same.
664 * testsuite/ext/pb_ds/example/hash_resize.cc: Same.
665 * testsuite/ext/pb_ds/example/tree_order_statistics.cc: Same.
666 * testsuite/ext/pb_ds/example/trie_prefix_search.cc: Same.
667 * testsuite/ext/pb_ds/example/basic_multiset.cc: Same.
668 * testsuite/ext/pb_ds/example/priority_queue_xref.cc: Same.
669 * testsuite/ext/pb_ds/example/hash_find_neg.cc: Same.
670 * testsuite/ext/pb_ds/example/erase_if.cc: Same.
671 * testsuite/ext/pb_ds/example/priority_queue_container_traits.cc: Same.
672 * testsuite/ext/pb_ds/example/tree_join.cc: Same.
673 * testsuite/ext/pb_ds/example/basic_map.cc: Same.
674 * testsuite/ext/pb_ds/example/trie_split.cc: Same.
675 * testsuite/ext/pb_ds/example/priority_queue_split_join.cc: Same.
676 * testsuite/ext/pb_ds/example/priority_queue_dijkstra.cc: Same.
677 * testsuite/ext/pb_ds/example/priority_queue_erase_if.cc: Same.
678 * testsuite/ext/pb_ds/example/hash_mod.cc: Same.
679 * testsuite/ext/pb_ds/example/tree_order_statistics_join.cc: Same.
680 * testsuite/ext/pb_ds/example/trie_dna.cc: Same.
681 * testsuite/ext/pb_ds/example/hash_initial_size.cc: Same.
682 * testsuite/ext/pb_ds/example/basic_priority_queue.cc: Same.
683 * testsuite/ext/pb_ds/example/tree_intervals.cc: Same.
684 * testsuite/ext/pb_ds/example/basic_multimap.cc: Same.
685 * testsuite/performance/ext: New.
686 * testsuite/performance/ext/pb_ds: New.
687 * testsuite/performance/ext/pb_ds/multimap_text_find_timing_small.cc: Same.
688 * testsuite/performance/ext/pb_ds/text_find_timing.cc: Same.
689 * testsuite/performance/ext/pb_ds/hash_random_int_erase_mem_usage.cc: Same.
690 * testsuite/performance/ext/pb_ds/tree_text_insert_timing.cc: Same.
691 * testsuite/performance/ext/pb_ds/priority_queue_text_modify_down_timing.cc: Same.
692 * testsuite/performance/ext/pb_ds/random_int_subscript_find_timing.cc: Same.
693 * testsuite/performance/ext/pb_ds/priority_queue_text_push_timing.cc: Same.
694 * testsuite/performance/ext/pb_ds/tree_split_join_timing.cc: Same.
695 * testsuite/performance/ext/pb_ds/random_int_find_timing.cc: Same.
696 * testsuite/performance/ext/pb_ds/multimap_text_insert_timing_large.cc: Same.
697 * testsuite/performance/ext/pb_ds/multimap_text_insert_mem_usage.hpp: Same.
698 * testsuite/performance/ext/pb_ds/priority_queue_random_int_push_timing.cc: Same.
699 * testsuite/performance/ext/pb_ds/multimap_text_find_timing.hpp: Same.
700 * testsuite/performance/ext/pb_ds/priority_queue_text_modify_timing.hpp: Same.
701 * testsuite/performance/ext/pb_ds/tree_order_statistics_timing.cc: Same.
702 * testsuite/performance/ext/pb_ds/priority_queue_text_modify_up_timing.cc: Same.
703 * testsuite/performance/ext/pb_ds/multimap_text_insert_mem_usage_large.cc: Same.
704 * testsuite/performance/ext/pb_ds/priority_queue_text_push_pop_timing.cc: Same.
705 * testsuite/performance/ext/pb_ds/multimap_text_find_timing_large.cc: Same.
706 * testsuite/performance/ext/pb_ds/priority_queue_text_join_timing.cc: Same.
707 * testsuite/performance/ext/pb_ds/multimap_text_insert_timing_small.cc: Same.
708 * testsuite/performance/ext/pb_ds/priority_queue_random_int_push_pop_timing.cc: Same.
709 * testsuite/performance/ext/pb_ds/random_int_subscript_insert_timing.cc: Same.
710 * testsuite/performance/ext/pb_ds/tree_text_lor_find_timing.cc: Same.
711 * testsuite/performance/ext/pb_ds/priority_queue_text_pop_mem_usage.cc: Same.
712 * testsuite/performance/ext/pb_ds/multimap_text_insert_timing.hpp: Same.
713 * testsuite/performance/ext/pb_ds/hash_zlob_random_int_find_timing.cc: Same.
714 * testsuite/performance/ext/pb_ds/multimap_text_insert_mem_usage_small.cc: Same.
715 * testsuite/data/make_graph_test_infos.xml: Same.
716 * testsuite/data/thirty_years_among_the_dead_preproc.txt: New.
717 * testsuite/data/make_graph_htmls.xml: Same.
718 * testsuite/util/regression: New.
719 * testsuite/util/regression/trait: New.
720 * testsuite/util/regression/trait/priority_queue: New.
721 * testsuite/util/regression/trait/priority_queue/trait.hpp: Same.
722 * testsuite/util/regression/trait/erase_if_fn.hpp: Same.
723 * testsuite/util/regression/trait/assoc: New.
724 * testsuite/util/regression/trait/assoc/native_type_trait.hpp: Same.
725 * testsuite/util/regression/trait/assoc/node_update_trait.hpp: Same.
726 * testsuite/util/regression/trait/assoc/get_set_load_trait.hpp: Same.
727 * testsuite/util/regression/trait/assoc/get_set_loads_trait.hpp: Same.
728 * testsuite/util/regression/trait/assoc/trait.hpp: Same.
729 * testsuite/util/regression/trait/assoc/type_trait.hpp: Same.
730 * testsuite/util/regression/trait/assoc/resize_trait.hpp: Same.
731 * testsuite/util/regression/trait/assoc/to_string.hpp: Same.
732 * testsuite/util/regression/rand: New.
733 * testsuite/util/regression/rand/priority_queue: New.
734 * testsuite/util/regression/rand/priority_queue/detail: New.
735 * testsuite/util/regression/rand/priority_queue/detail/erase_fn_imps.hpp: Same.
736 * testsuite/util/regression/rand/priority_queue/detail/cmp_fn_imps.hpp: Same.
737 * testsuite/util/regression/rand/priority_queue/detail/policy_access_fn_imps.hpp: Same.
738 * testsuite/util/regression/rand/priority_queue/detail/defs_fn_imps.hpp: Same.
739 * testsuite/util/regression/rand/priority_queue/detail/it_conversion_fn_imps.hpp: Same.
740 * testsuite/util/regression/rand/priority_queue/detail/constructor_destructor_fn_imps.hpp: Same.
741 * testsuite/util/regression/rand/priority_queue/detail/diagnostic_fn_imps.hpp: Same.
742 * testsuite/util/regression/rand/priority_queue/detail/insert_fn_imps.hpp: Same.
743 * testsuite/util/regression/rand/priority_queue/detail/clear_fn_imps.hpp: Same.
744 * testsuite/util/regression/rand/priority_queue/detail/modify_fn_imps.hpp: Same.
745 * testsuite/util/regression/rand/priority_queue/detail/split_join_fn_imps.hpp: Same.
746 * testsuite/util/regression/rand/priority_queue/detail/operator_fn_imps.hpp: Same.
747 * testsuite/util/regression/rand/priority_queue/rand_regression_test.hpp: Same.
748 * testsuite/util/regression/rand/priority_queue/container_rand_regression_test.hpp: Same.
749 * testsuite/util/regression/rand/io: New.
750 * testsuite/util/regression/rand/io/priority_queue: New.
751 * testsuite/util/regression/rand/io/priority_queue/xml_formatter.hpp: Same.
752 * testsuite/util/regression/rand/io/assoc: New.
753 * testsuite/util/regression/rand/io/assoc/xml_formatter.hpp: Same.
754 * testsuite/util/regression/rand/io/xml_formatter.hpp: Same.
755 * testsuite/util/regression/rand/assoc: New.
756 * testsuite/util/regression/rand/assoc/detail: New.
757 * testsuite/util/regression/rand/assoc/detail/subscript_fn_imps.hpp: Same.
758 * testsuite/util/regression/rand/assoc/detail/cmp_fn_imps.hpp: Same.
759 * testsuite/util/regression/rand/assoc/detail/policy_access_fn_imps.hpp: Same.
760 * testsuite/util/regression/rand/assoc/detail/defs_fn_imps.hpp: Same.
761 * testsuite/util/regression/rand/assoc/detail/it_conversion_fn_imps.hpp: Same.
762 * testsuite/util/regression/rand/assoc/detail/diagnostic_fn_imps.hpp: Same.
763 * testsuite/util/regression/rand/assoc/detail/clear_fn_imps.hpp: Same.
764 * testsuite/util/regression/rand/assoc/detail/get_set_load_fn_imps.hpp: Same.
765 * testsuite/util/regression/rand/assoc/detail/operator_fn_imps.hpp: Same.
766 * testsuite/util/regression/rand/assoc/detail/erase_fn_imps.hpp: Same.
767 * testsuite/util/regression/rand/assoc/detail/resize_fn_imps.hpp: Same.
768 * testsuite/util/regression/rand/assoc/detail/constructor_destructor_fn_imps.hpp: Same.
769 * testsuite/util/regression/rand/assoc/detail/insert_fn_imps.hpp: Same.
770 * testsuite/util/regression/rand/assoc/detail/split_join_fn_imps.hpp: Same.
771 * testsuite/util/regression/rand/assoc/detail/get_set_loads_fn_imps.hpp: Same.
772 * testsuite/util/regression/rand/assoc/rand_regression_test.hpp: Same.
773 * testsuite/util/regression/rand/assoc/container_rand_regression_test.hpp: Same.
774 * testsuite/util/regression/priority_queue: New.
775 * testsuite/util/regression/priority_queue/common_type.hpp: Same.
776 * testsuite/util/regression/basic_type.hpp: Same.
777 * testsuite/util/regression/assoc: New.
778 * testsuite/util/regression/assoc/common_type.hpp: Same.
779 * testsuite/util/regression/res_mng: New.
780 * testsuite/util/regression/res_mng/forced_exception.hpp: Same.
781 * testsuite/util/regression/res_mng/dbg_ex_allocator_base.cc: Same.
782 * testsuite/util/regression/res_mng/dbg_ex_allocator_base.hpp: Same.
783 * testsuite/util/regression/res_mng/dbg_ex_allocator.hpp: Same.
784 * testsuite/util/rng: New.
785 * testsuite/util/rng/twister_rand_gen.cc: Same.
786 * testsuite/util/rng/twister_rand_gen.hpp: Same.
787 * testsuite/util/native_type: New.
788 * testsuite/util/native_type/priority_queue: New.
789 * testsuite/util/native_type/priority_queue/native_priority_queue.hpp: Same.
790 * testsuite/util/native_type/priority_queue/native_pq_tag.hpp: Same.
791 * testsuite/util/native_type/assoc: New.
792 * testsuite/util/native_type/assoc/native_multimap.hpp: Same.
793 * testsuite/util/native_type/assoc/native_tree_tag.hpp: Same.
794 * testsuite/util/native_type/assoc/native_set.hpp: Same.
795 * testsuite/util/native_type/assoc/native_hash_multimap.hpp: Same.
796 * testsuite/util/native_type/assoc/native_map.hpp: Same.
797 * testsuite/util/native_type/assoc/native_hash_tag.hpp: Same.
798 * testsuite/util/native_type/assoc/native_hash_set.hpp: Same.
799 * testsuite/util/native_type/assoc/native_hash_map.hpp: Same.
800 * testsuite/util/common_type: New.
801 * testsuite/util/common_type/priority_queue
802 * testsuite/util/common_type/priority_queue/common_type.hpp: Same.
803 * testsuite/util/common_type/priority_queue/string_form.hpp: Same.
804 * testsuite/util/common_type/priority_queue/detail
805 * testsuite/util/common_type/priority_queue/detail/ds_string_form.hpp: Same.
806 * testsuite/util/common_type/assoc: New.
807 * testsuite/util/common_type/assoc/common_type.hpp: Same.
808 * testsuite/util/common_type/assoc/string_form.hpp: Same.
809 * testsuite/util/common_type/assoc/template_policy.hpp: Same.
810 * testsuite/util/common_type/assoc/detail: New.
811 * testsuite/util/common_type/assoc/detail/resize_policy_string_form.hpp: Same.
812 * testsuite/util/common_type/assoc/detail/trigger_policy_string_form.hpp: Same.
813 * testsuite/util/common_type/assoc/detail/ds_string_form.hpp: Same.
814 * testsuite/util/common_type/assoc/detail/comb_hash_fn_string_form.hpp: Same.
815 * testsuite/util/common_type/assoc/detail/size_policy_string_form.hpp: Same.
816 * testsuite/util/common_type/assoc/detail/probe_fn_string_form.hpp: Same.
817 * testsuite/util/common_type/assoc/detail/tree_supports_order_statistics.hpp: Same.
818 * testsuite/util/common_type/assoc/detail/trie_supports_prefix_search.hpp: Same.
819 * testsuite/util/common_type/assoc/detail/list_update_policy_string_form.hpp: Same.
820 * testsuite/util/common_type/assoc/detail/trie_supports_order_statistics.hpp: Same.
821 * testsuite/util/common_type/assoc/detail/store_hash_string_form.hpp: Same.
822 * testsuite/util/common_type/assoc/native_set.hpp: Same.
823 * testsuite/util/performance: New.
824 * testsuite/util/performance/priority_queue: New.
825 * testsuite/util/performance/priority_queue/mem_usage: New.
826 * testsuite/util/performance/priority_queue/mem_usage/pop_test.hpp: Same.
827 * testsuite/util/performance/priority_queue/timing: New.
828 * testsuite/util/performance/priority_queue/timing/push_pop_test.hpp: Same.
829 * testsuite/util/performance/priority_queue/timing/push_test.hpp: Same.
830 * testsuite/util/performance/priority_queue/timing/join_test.hpp: Same.
831 * testsuite/util/performance/priority_queue/timing/modify_test.hpp: Same.
832 * testsuite/util/performance/io: New.
833 * testsuite/util/performance/io/xml_formatter.hpp: Same.
834 * testsuite/util/performance/assoc: New.
835 * testsuite/util/performance/assoc/mem_usage: New.
836 * testsuite/util/performance/assoc/mem_usage/multimap_insert_test.hpp: Same.
837 * testsuite/util/performance/assoc/mem_usage/erase_test.hpp: Same.
838 * testsuite/util/performance/assoc/multimap_common_type.hpp: Same.
839 * testsuite/util/performance/assoc/timing: New.
840 * testsuite/util/performance/assoc/timing/common_type.hpp: Same.
841 * testsuite/util/performance/assoc/timing/multimap_insert_test.hpp: Same.
842 * testsuite/util/performance/assoc/timing/subscript_find_test.hpp: Same.
843 * testsuite/util/performance/assoc/timing/find_test.hpp: Same.
844 * testsuite/util/performance/assoc/timing/subscript_insert_test.hpp: Same.
845 * testsuite/util/performance/assoc/timing/insert_test.hpp: Same.
846 * testsuite/util/performance/assoc/timing/tree_order_statistics_test.hpp: Same.
847 * testsuite/util/performance/assoc/timing/multimap_find_test.hpp: Same.
848 * testsuite/util/performance/assoc/timing/tree_split_join_test.hpp: Same.
849 * testsuite/util/performance/time: New.
850 * testsuite/util/performance/time/elapsed_timer.cc: Same.
851 * testsuite/util/performance/time/elapsed_timer.hpp: Same.
852 * testsuite/util/performance/time/timing_test_base.hpp: Same.
853 * testsuite/util/performance/mem: New.
854 * testsuite/util/performance/mem/mem_track_allocator_base.hpp: Same.
855 * testsuite/util/performance/mem/mem_track_allocator.hpp: Same.
856 * testsuite/util/hash_fn: New.
857 * testsuite/util/hash_fn/limit_string_hash_fn.hpp: Same.
858 * testsuite/util/hash_fn/string_ranged_hash_fn.hpp: Same.
859 * testsuite/util/hash_fn/string_hash_fn.hpp: Same.
860 * testsuite/util/hash_fn/string_ranged_probe_fn.hpp: Same.
861 * testsuite/util/hash_fn/dna_str_limit.hpp: Same.
862 * testsuite/util/io: New.
863 * testsuite/util/io/prog_bar.cc: Same.
864 * testsuite/util/io/prog_bar.hpp: Same.
865 * testsuite/util/io/text_populate.hpp: Same.
866 * testsuite/util/io/xml.hpp: Same.
867 * testsuite/util/io/illegal_input_error.hpp: Same.
868 * testsuite/util/io/xml_test_formatter.hpp: Same.
869 * testsuite/util/io/verified_cmd_line_input.cc: Same.
870 * testsuite/util/io/verified_cmd_line_input.hpp: Same.
871 * testsuite/util/statistic: New.
872 * testsuite/util/statistic/sample_var.hpp: Same.
873 * testsuite/util/statistic/res_recorder.hpp: Same.
874 * testsuite/util/statistic/sample_mean.hpp: Same.
875 * testsuite/util/statistic/sample_mean_confidence_checker.hpp: Same.
876
877 2006-06-12 Paolo Carlini <pcarlini@suse.de>
878
879 PR libstdc++/26970
880 * config/locale/gnu/c_locale.h (__convert_from_v<>): Change to
881 variadic function, instead of template function.
882 * config/locale/generic/c_locale.h (__convert_from_v<>): Likewise.
883 * include/bits/locale_facets.tcc (num_put<>::_M_insert_float):
884 Adjust.
885 (money_put<>::do_put(long double)): Likewise.
886 * src/locale-misc-inst.cc: Remove.
887 * src/Makefile.am: Adjust.
888 * src/Makefile.in: Regenerate.
889
890 2006-06-09 Paolo Carlini <pcarlini@suse.de>
891
892 * include/tr1/random (random_device::random_device(const
893 std::string& = "/dev/urandom")): Open in binary mode.
894
895 * include/tr1/random (random_device::random_device(const
896 std::string& = "rand")): Use mersenne_twister.
897 (random_device::_M_strtoul): New.
898 (random_device::operator()()): Update.
899
900 * include/tr1/random: Minor stylistic changes, consistently
901 qualify with std::.
902
903 2006-06-09 Paolo Carlini <pcarlini@suse.de>
904
905 * acinclude.m4 ([GLIBCXX_CHECK_RANDOM_TR1]): New, check for
906 the availability of "/dev/random" and "/dev/urandom".
907 * configure.ac: Use it.
908 * include/tr1/random (random_device): Implement, a fall-back for
909 systems not providing "/dev/random" and "/dev/urandom" included.
910 * testsuite/tr1/5_numerical_facilities/random/random_device/
911 cons/default.cc: New.
912 * testsuite/tr1/5_numerical_facilities/random/random_device/
913 cons/token.cc: Likewise.
914 * testsuite/tr1/5_numerical_facilities/random/random_device/
915 requirements/typedefs.cc: Likewise.
916 * config.h.in: Regenerate.
917 * configure: Likewise.
918
919 * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
920 cons/gen1.cc: Minor tweak, add bool test.
921
922 2006-06-06 Benjamin Kosnik <bkoz@redhat.com>
923
924 * testsuite/util: New directory.
925 * testsuite/testsuite_hooks.cc: Move to util sub-directory.
926 * testsuite/testsuite_abi_check.cc: Same.
927 * testsuite/testsuite_abi.cc: Same.
928 * testsuite/testsuite_tr1.h: Same.
929 * testsuite/testsuite_io.h: Same.
930 * testsuite/testsuite_iterators.h: Same.
931 * testsuite/testsuite_allocator.cc: Same.
932 * testsuite/testsuite_allocator.h: Same.
933 * testsuite/testsuite_hooks.h: Same.
934 * testsuite/testsuite_character.cc: Same.
935 * testsuite/testsuite_abi.h: Same.
936 * testsuite/testsuite_character.h: Same.
937 * testsuite/testsuite_visualization.h: Same.
938 * testsuite/testsuite_performance.h: Same.
939 * testsuite/testsuite_shared.cc: Same.
940 * testsuite/testsuite_common_types.h: Same.
941
942 * testsuite/lib/libstdc++.exp (v3-build_support): Adjust paths.
943 * testsuite/libstdc++-abi/abi.exp: Same.
944 * testsuite/libstdc++-dg/conformance.exp: Remove any files in the
945 utilities subdirectory from the list of test cases.
946
947 * scripts/testsuite_flags.in (build-includes): Adjust path for
948 testsuite includes.
949 * scripts/create_testsuite_files (dlist): Don't let utility files
950 creep into the testsuite_files list.
951
952 2006-06-06 Paolo Carlini <pcarlini@suse.de>
953
954 * include/tr1/random (mersenne_twister<>::operator==,
955 operator!=, operator<<, operator>>): Implement.
956 * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
957 operators/equal.cc: New.
958 * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
959 operators/not_equal.cc: Likewise.
960 * testsuite/tr1/5_numerical_facilities/random/mersenne_twister/
961 operators/serialize.cc: Likewise.
962
963 * include/tr1/random (subtract_with_carry<>::operator==): Fix,
964 compare the whole state; use std::equal.
965
966 * include/tr1/random: Minor formatting and style changes.
967
968 2006-06-06 Benjamin Kosnik <bkoz@redhat.com>
969
970 * testsuite/tr1/5_numerical_facilies: Move to...
971 * testsuite/tr1/5_numerical_facilities: ...this.
972
973 2006-06-06 Paolo Carlini <pcarlini@suse.de>
974
975 * include/tr1/random: Trivial uglification fixes.
976 * include/tr1/random.tcc: Likewise.
977
978 * include/tr1/random (subtract_with_carry<>::
979 subtract_with_carry(_IntType)): Fix parameter type to unsigned long.
980 (subtract_with_carry<>::seed(_IntType)): Likewise.
981 * include/tr1/random.tcc (subtract_with_carry<>::seed(_IntType)):
982 Adjust.
983
984 2006-06-05 Paolo Carlini <pcarlini@suse.de>
985
986 * include/tr1/random (mersenne_twister<>::seed()): Fix per
987 tr1/5.1.4.2, p8.
988 * include/tr1/random.tcc (mod_w): Add.
989 (mersenne_twister<>::seed(unsigned long)): Fix per tr1/5.1.4.2, p9.
990 (mersenne_twister<>::seed(Gen&, false_type)): Adjust to use mod_w.
991 * testsuite/tr1/5_numerical_facilies/random/mt19937.cc: Fix
992 expected result per tr1/5.1.5, p2.
993 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
994 cons/default.cc: Adjust.
995
996 * include/tr1/random (exponential_distribution<>::operator()()): Fix.
997
998 2006-06-05 Paolo Carlini <pcarlini@suse.de>
999
1000 * include/tr1/random.tcc (Max::value()): Cast 1 to Tp(1) and
1001 adjust shift count to w; rename as Max_w.
1002 (struct Mod_w): New.
1003 (mersenne_twister<>::seed(Gen&, false_type): Use the latter.
1004 (mersenne_twister<>::operator()()): Fix ~0ul to ~_UInt().
1005 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
1006 cons/default.cc: Fix ~0ul to 2^32-1.
1007 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
1008 cons/gen1.cc: Likewise.
1009
1010 2006-06-05 Stephen M. Webb <stephen.webb@bregmasoft.com>
1011
1012 * include/tr1/random: New.
1013 * include/tr1/random.tcc: Likewise.
1014 * include/Makefile.am: Add.
1015 * testsuite/tr1/5_numerical_facilies/random/ranlux3.cc: New.
1016 * testsuite/tr1/5_numerical_facilies/random/ranlux4.cc: Likewise.
1017 * testsuite/tr1/5_numerical_facilies/random/mt19937.cc: Likewise.
1018 * testsuite/tr1/5_numerical_facilies/random/variate_generator/
1019 requirements/typedefs.cc: Likewise.
1020 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
1021 cons/seed1.cc: Likewise.
1022 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
1023 cons/seed2.cc: Likewise.
1024 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
1025 cons/default.cc: Likewise.
1026 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
1027 cons/gen1.cc: Likewise.
1028 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
1029 requirements/typedefs.cc: Likewise.
1030 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
1031 operators/equal.cc: Likewise.
1032 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
1033 operators/not_equal.cc: Likewise.
1034 * testsuite/tr1/5_numerical_facilies/random/subtract_with_carry/
1035 operators/serialize.cc: Likewise.
1036 * testsuite/tr1/5_numerical_facilies/random/uniform_real/
1037 requirements/typedefs.cc: Likewise.
1038 * testsuite/tr1/5_numerical_facilies/random/discard_block/
1039 requirements/requirements.cc: Likewise.
1040 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
1041 cons/seed1.cc: Likewise.
1042 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
1043 cons/seed2.cc: Likewise.
1044 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
1045 cons/default.cc: Likewise.
1046 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
1047 cons/gen1.cc: Likewise.
1048 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
1049 requirements/non_uint_neg.cc: Likewise.
1050 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
1051 requirements/typedefs.cc: Likewise.
1052 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
1053 operators/equal.cc: Likewise.
1054 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
1055 operators/not_equal.cc: Likewise.
1056 * testsuite/tr1/5_numerical_facilies/random/linear_congruential/
1057 operators/serialize.cc: Likewise.
1058 * testsuite/tr1/5_numerical_facilies/random/xor_combine/
1059 requirements/typedefs.cc: Likewise.
1060 * testsuite/tr1/5_numerical_facilies/random/minstd_rand.cc: Likewise.
1061 * testsuite/tr1/5_numerical_facilies/random/minstd_rand0.cc: Likewise.
1062 * testsuite/tr1/5_numerical_facilies/random/uniform_int/
1063 cons/range.cc: Likewise.
1064 * testsuite/tr1/5_numerical_facilies/random/uniform_int/
1065 cons/default.cc: Likewise.
1066 * testsuite/tr1/5_numerical_facilies/random/uniform_int/
1067 cons/range_neg.cc: Likewise.
1068 * testsuite/tr1/5_numerical_facilies/random/uniform_int/
1069 requirements/typedefs.cc: Likewise.
1070 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
1071 cons/seed1.cc: Likewise.
1072 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
1073 cons/seed2.cc: Likewise.
1074 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
1075 cons/default.cc: Likewise.
1076 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
1077 cons/gen1.cc: Likewise.
1078 * testsuite/tr1/5_numerical_facilies/random/mersenne_twister/
1079 requirements/typedefs.cc: Likewise.
1080 * include/Makefile.in: Regenerate.
1081 * testsuite/tr1/headers.cc: Update.
1082
1083 2006-06-04 Paolo Carlini <pcarlini@suse.de>
1084
1085 PR libstdc++/27867
1086 * include/bits/valarray_before.h (struct _BinClos<_Oper, _ValArray,
1087 _ValArray, _Tp, _Tp>): Fix value_type typedef.
1088 * testsuite/26_numerics/valarray/27867.cc: New.
1089
1090 2006-05-29 Paolo Carlini <pcarlini@suse.de>
1091
1092 PR libstdc++/24692
1093 * include/bits/atomicity.h (__exchange_and_add_multi,
1094 __atomic_add_multi): New, depending on _GLIBCXX_ATOMIC_BUILTINS,
1095 inline the atomic builtins.
1096 (__exchange_and_add_dispatch, __atomic_add_dispatch): Adjust.
1097 * configure.ac: Define _GLIBCXX_ATOMIC_BUILTINS when the atomic
1098 builtins are available.
1099 * configure: Regenerate.
1100 * config.h.in: Likewise.
1101
1102 2006-05-27 Paolo Carlini <pcarlini@suse.de>
1103
1104 * configure.host: If the CPU provides atomic builtins select
1105 generic/atomic_builtins/atomicity.h.
1106 * config/cpu/generic/atomic_builtins/atomicity.h: Add.
1107 * config/cpu/powerpc/atomicity.h: Remove.
1108 * config/cpu/ia64/atomicity.h: Likewise.
1109 * config/cpu/alpha/atomicity.h: Likewise.
1110 * config/cpu/s390/atomicity.h: Likewise.
1111
1112 2006-05-26 Carlos O'Donell <carlos@codesourcery.com>
1113
1114 * Makefile.am: Add install-html target. Add install-html to .PHONY
1115 * Makefile.in: Regenerate.
1116
1117 2006-05-24 Paolo Carlini <pcarlini@suse.de>
1118
1119 PR libstdc++/24704
1120 * include/bits/atomicity.h (__exchange_and_add_single,
1121 __atomic_add_single): New, single thread versions of the atomic
1122 functions.
1123 (__exchange_and_add_dispatch, __atomic_add_dispatch): New,
1124 depending on __GTHREADS and __gthread_active_p() dispatch either
1125 to the above or to the existing atomic functions.
1126 * include/ext/pool_allocator.h: Update callers.
1127 * include/ext/rc_string_base.h: Likewise.
1128 * include/bits/locale_classes.h: Likewise.
1129 * include/bits/basic_string.h: Likewise.
1130 * include/bits/ios_base.h: Likewise.
1131 * include/tr1/boost_shared_ptr.h: Likewise.
1132 * src/ios.cc: Likewise.
1133 * src/locale.cc: Likewise.
1134 * src/ios_init.cc: Likewise.
1135
1136 2006-05-23 Paolo Carlini <pcarlini@suse.de>
1137
1138 * testsuite/testsuite_shared.cc: Fix --enable-threads=single build.
1139
1140 2006-05-19 Paolo Carlini <pcarlini@suse.de>
1141
1142 * testsuite/27_io/objects/wchar_t/9661-1.cc: Avoid leaking the
1143 semaphores if a VERIFY fails.
1144 * testsuite/27_io/objects/wchar_t/7.cc: Likewise.
1145 * testsuite/27_io/objects/char/9661-1.cc: Likewise.
1146 * testsuite/27_io/objects/char/7.cc: Likewise.
1147 * testsuite/27_io/basic_filebuf/seekoff/char/26777.cc: Likewise.
1148 * testsuite/27_io/basic_filebuf/imbue/wchar_t/14975-2.cc: Likewise.
1149 * testsuite/27_io/basic_filebuf/imbue/char/13171-2.cc: Likewise.
1150 * testsuite/27_io/basic_filebuf/close/char/4879.cc: Likewise.
1151 * testsuite/27_io/basic_filebuf/close/char/9964.cc: Likewise.
1152 * testsuite/27_io/basic_filebuf/underflow/char/10097.cc: Likewise.
1153
1154 2006-05-17 Paolo Carlini <pcarlini@suse.de>
1155
1156 * include/tr1/hashtable (hashtable<>::m_find): Remove; update callers.
1157
1158 * include/tr1/hashtable (map_base<>::operator[]): Move out of line.
1159
1160 * include/tr1/hashtable (hashtable<>::m_insert(const value_type&,
1161 std::tr1::false_type)): Avoid memory leak risk for new_node.
1162
1163 2006-05-15 Paolo Carlini <pcarlini@suse.de>
1164
1165 * include/tr1/hashtable (hashtable<>::m_find, m_insert_bucket): Add.
1166 (hashtable<>::find, m_insert(const value_type&, std::tr1::true_type),
1167 map_base<>::operator[]): Use the above.
1168 * testsuite/performance/23_containers/insert/unordered_map_array.cc:
1169 New.
1170
1171 * include/tr1/hashtable (hashtable<>::find_node,
1172 insert(const value_type&, ...), erase_node): Rename to m_*, adjust
1173 callers.
1174 * include/tr1/hashtable: Minor cosmetic changes.
1175
1176 2006-05-13 Peter Doerfler <gcc@pdoerfler.com>
1177
1178 * include/tr1/hashtable (identity<>::operator(),
1179 extract1st<>::operator()): Return by const ref.
1180
1181 2006-05-10 Steve Ellcey <sje@cup.hp.com>
1182
1183 * testsuite/lib/libstdc++.exp (check_v3_target_cxa_atexit):
1184 Move to gcc subdir.
1185 * testsuite/lib/dg-options.exp (dg-require-iconv): Remove.
1186 (dg-require-cxa-atexit): Move to gcc subdir.
1187
1188 2006-05-10 Paolo Carlini <pcarlini@suse.de>
1189 Peter Doerfler <gcc@pdoerfler.com>
1190
1191 * include/tr1/hashtable (hashtable_iterator<>::hashtable_iterator(),
1192 hashtable_const_iterator<>::hashtable_const_iterator(),
1193 node_iterator<>::node_iterator(),
1194 node_const_iterator<>::node_const_iterator()): Add.
1195 (node_iterator<>::node_iterator(hash_node<>*),
1196 node_const_iterator<>::node_const_iterator(hash_node<>*)): Tweak,
1197 remove default.
1198 * testsuite/tr1/6_containers/unordered/hashtable/
1199 iterators_default_constructor.c: New.
1200
1201 2006-05-10 Marc Glisse <marc.glisse@normalesup.org>
1202
1203 * include/ext/pool_allocator.h: Add missing std:: qualifications.
1204 * include/ext/mt_allocator.h: Likewise.
1205 * include/ext/pb_assoc/detail/resize_policy/
1206 hash_load_check_resize_trigger_imp.hpp: Likewise.
1207 * include/ext/pb_assoc/detail/resize_policy/
1208 hash_standard_resize_policy_imp.hpp: Likewise.
1209 * include/ext/pb_assoc/detail/lu_policy/
1210 counter_lu_metadata_imp.hpp: Likewise.
1211 * include/ext/pb_assoc/detail/map_debug_base.hpp: Likewise.
1212 * libsupc++/eh_alloc.cc: Typo: memcpy -> memset.
1213
1214 2006-05-07 Paolo Carlini <pcarlini@suse.de>
1215
1216 * include/tr1/type_traits (integral_constant<>::value): Define.
1217 * testsuite/tr1/4_metaprogramming/helper_classes/static_definition.cc:
1218 New.
1219
1220 2006-05-04 Douglas Gregor <dgregor@cs.indiana.edu>
1221
1222 PR libstdc++/27404
1223 * include/ext/rope (_Rope_const_iterator<>::operator*() const,
1224 _Rope_iterator<>::operator*() const): Add.
1225
1226 2006-05-01 Paolo Carlini <pcarlini@suse.de>
1227
1228 * acinclude.m4 (GLIBCXX_ENABLE_WCHAR_T): Always check the
1229 presence of wctype.h, for use in GLIBCXX_ENABLE_C99.
1230 * configure: Regenerate.
1231
1232 2006-04-29 Paolo Carlini <pcarlini@suse.de>
1233
1234 * include/bits/locale_facets.tcc (num_get<>::_M_extract_float):
1235 Special case main parsing loop for !_M_allocated (i.e., "C" locale).
1236 (num_get<>::_M_extract_int): Likewise.
1237 * include/bits/locale_facets.h (num_get<>::_M_find): New.
1238
1239 2006-04-27 Benjamin Kosnik <bkoz@redhat.com>
1240
1241 * docs/html/17_intro/TODO: Update.
1242
1243 2006-04-26 Benjamin Kosnik <bkoz@redhat.com>
1244
1245 PR libstdc++/26875
1246 * include/ext/array_allocator.h (array_allocator): _M_used, new
1247 data member.
1248 * testsuite/ext/array_allocator/26875.cc: New.
1249
1250 2006-04-26 Shantonu Sen <ssen@opendarwin.org>
1251
1252 PR libstdc++/26513
1253 * scripts/make_exports.pl: Use $ENV{NM_FOR_TARGET}, if present.
1254
1255 2006-04-23 Marc Glisse <marc.glisse@normalesup.org>
1256
1257 PR libstdc++/27199
1258 * ext/pool_allocator.h: Add using declarations for size_t, ptrdiff_t.
1259 * ext/bitmap_allocator.h: Likewise; qualify with std::.
1260 * ext/new_allocator.h: Likewise.
1261 * ext/malloc_allocator.h: Likewise.
1262 * ext/array_allocator.h: Likewise.
1263 * ext/mt_allocator.h: Likewise.
1264 * ext/functional: Likewise for size_t.
1265 * ext/debug_allocator.h: Likewise.
1266 * bits/char_traits.h: Qualify with std:: size_t.
1267 * debug/hash_multimap.h: Likewise.
1268
1269 2006-04-23 Paolo Carlini <pcarlini@suse.de>
1270
1271 * docs/html/ext/lwg-active.html, lwg-defects.html: Import Revision 42.
1272
1273 2006-04-19 Paolo Carlini <pcarlini@suse.de>
1274
1275 PR libstdc++/26424
1276 * include/tr1/hashtable (X<>::primes): Extend for 64-bit machines.
1277 (X<>::n_primes): Adjust.
1278 (prime_rehash_policy::next_bkt, bkt_for_elements, need_rehash): Adjust.
1279
1280 2006-04-18 Paolo Carlini <pcarlini@suse.de>
1281
1282 * docs/html/faq/index.html ([5.5]): Adjust to mention function
1283 objects and reference_wrapper; minor tweaks.
1284 * docs/html/faq/index.txt: Regenerate.
1285
1286 2006-04-16 Paolo Carlini <pcarlini@suse.de>
1287
1288 PR libstdc++/6702 (again)
1289 * acinclude.m4 (GLIBCXX_ENABLE_C99): Don't check non-C99
1290 wchar_t functions...
1291 (GLIBCXX_ENABLE_WCHAR_T): ... do that here.
1292 * configure.ac: Adjust order of checks.
1293 * configure: Regenerate.
1294
1295 2006-04-14 Douglas Gregor <dgregor@cs.indiana.edu>
1296
1297 PR libstdc++/27162
1298 * include/bits/stl_algo.h (__search_n(,,,, _BinaryPredicate,
1299 std::forward_iterator_tag)): Use __binary_pred, not ==.
1300
1301 2006-04-10 Matthias Klose <doko@debian.org>
1302
1303 * testsuite/lib/libstdc++.exp (libstdc++_init): Recognize multilib
1304 directory names containing underscores.
1305
1306 2006-04-10 Paolo Carlini <pcarlini@suse.de>
1307
1308 DR 538, [Ready]
1309 * include/bits/stl_algo.h (__unique_copy(,,, input_iterator_tag,
1310 output_iterator_tag), and predicated counterpart): Revert to the
1311 algorithm pre-DR 241, i.e., value_type of InputIterator is now
1312 required to be Assignable too.
1313 * testsuite/25_algorithms/unique_copy/3.cc: Remove.
1314 * docs/html/ext/howto.html: Add an entry for DR 538.
1315
1316 2006-03-29 Benjamin Kosnik <bkoz@redhat.com>
1317
1318 * testsuite/data/sgetn.txt: Correct copyright holder.
1319 * testsuite/data/wistream_extractor_other-1.tst: Same.
1320 * testsuite/data/wistream_extractor_other-2.tst: Same.
1321 * testsuite/data/istream_extractor_other-1.txt: Same.
1322 * testsuite/data/filebuf_virtuals-1.txt: Same.
1323 * testsuite/data/wostream_inserter_other-1.tst: Same.
1324 * testsuite/data/wostream_inserter_other-2.tst: Same.
1325 * testsuite/data/ostream_inserter_other-1.tst: Same.
1326 * testsuite/data/ostream_inserter_other-2.tst: Same.
1327 * testsuite/data/wistream_extractor_other-1.txt: Same.
1328 * testsuite/data/istream_extractor_other-1.tst: Same.
1329 * testsuite/data/istream_extractor_other-2.tst: Same.
1330 * testsuite/data/filebuf_virtuals-1.tst: Same.
1331 * testsuite/27_io/basic_filebuf/sgetn/char/1-in.cc: Adjust test
1332 conditions.
1333 * testsuite/27_io/basic_filebuf/sgetn/char/1-io.cc: Same.
1334 * testsuite/27_io/basic_filebuf/sgetn/char/2-in.cc: Same.
1335 * testsuite/27_io/basic_filebuf/sgetn/char/2-io.cc: Same.
1336
1337 2006-03-28 Paolo Carlini <pcarlini@suse.de>
1338
1339 * include/ext/vstring.h (operator[]): Allow s[s.size()] in
1340 debug mode, but not pedantic mode.
1341
1342 2006-03-24 Mark Mitchell <mark@codesourcery.com>
1343 Joseph S. Myers <joseph@codesourcery.com>
1344
1345 PR libstdc++/20448
1346 PR libstdc++/20451
1347 * scripts/testsuite_flags.in (--cxxflags): Don't define LOCALEDIR.
1348 * testsuite/lib/libstdc++.exp (libstdc++_init): Always define
1349 LOCALEDIR to ".".
1350 (v3-build_support): Build MO files.
1351
1352 2006-03-22 Paolo Carlini <pcarlini@suse.de>
1353
1354 PR libstdc++/26777
1355 * include/bits/fstream.tcc (basic_filebuf<>::_M_seek): Check
1356 the return value of _M_file.seekoff.
1357 * testsuite/27_io/basic_filebuf/seekoff/char/26777.cc: New.
1358
1359 2006-03-21 Paolo Carlini <pcarlini@suse.de>
1360
1361 PR libstdc++/25482
1362 * include/bits/stl_algobase.h (__copy_aux(_CharT*, _CharT*,
1363 ostreambuf_iterator<_CharT>), __copy_aux(const _CharT*, const _CharT*,
1364 ostreambuf_iterator<_CharT>), __copy_aux(istreambuf_iterator<_CharT>,
1365 istreambuf_iterator<_CharT>, _CharT*), copy(istreambuf_iterator<_CharT>,
1366 istreambuf_iterator<_CharT>, ostreambuf_iterator<_CharT>)): Declare.
1367 * include/bits/stl_algo.h (find(istreambuf_iterator<_CharT>,
1368 istreambuf_iterator<_CharT>, _CharT)): Likewise.
1369 * include/bits/streambuf_iterator.h (copy(istreambuf_iterator<_CharT>,
1370 istreambuf_iterator<_CharT>, ostreambuf_iterator<_CharT>),
1371 __copy_aux(_CharT*, _CharT*, ostreambuf_iterator<_CharT>),
1372 __copy_aux(const _CharT*, const _CharT*, ostreambuf_iterator<_CharT>),
1373 __copy_aux(istreambuf_iterator<_CharT>, istreambuf_iterator<_CharT>,
1374 _CharT*), find(istreambuf_iterator<_CharT>, istreambuf_iterator<_CharT>,
1375 _CharT)): Define.
1376 (class istreambuf_iterator<>, class ostreambuf_iterator<>): Declare
1377 friends.
1378 * include/std/std_streambuf.h (class basic_streambuf<>): Likewise.
1379 * include/bits/cpp_type_traits.h (struct __is_char<>): Add.
1380 * testsuite/25_algorithms/copy/streambuf_iterators/char/1.cc: New.
1381 * testsuite/25_algorithms/copy/streambuf_iterators/char/2.cc: New.
1382 * testsuite/25_algorithms/copy/streambuf_iterators/char/3.cc: New.
1383 * testsuite/25_algorithms/copy/streambuf_iterators/char/4.cc: New.
1384 * testsuite/25_algorithms/copy/streambuf_iterators/wchar_t/1.cc: New.
1385 * testsuite/25_algorithms/copy/streambuf_iterators/wchar_t/2.cc: New.
1386 * testsuite/25_algorithms/copy/streambuf_iterators/wchar_t/3.cc: New.
1387 * testsuite/25_algorithms/copy/streambuf_iterators/wchar_t/4.cc: New.
1388 * testsuite/25_algorithms/find/istreambuf_iterators/char/1.cc: New.
1389 * testsuite/25_algorithms/find/istreambuf_iterators/char/2.cc: New.
1390 * testsuite/25_algorithms/find/istreambuf_iterators/wchar_t/1.cc: New.
1391 * testsuite/25_algorithms/find/istreambuf_iterators/wchar_t/2.cc: New.
1392 * testsuite/performance/25_algorithms/copy_streambuf_iterators.cc: New.
1393 * testsuite/performance/25_algorithms/find_istreambuf_iterators.cc: New.
1394
1395 006-03-13 Paolo Carlini <pcarlini@suse.de>
1396
1397 * include/bits/postypes.h (fpos<>::operator==, operator!=): Remove,
1398 exploit conversion to streamoff.
1399 * testsuite/27_io/fpos/mbstate_t/5.cc: New.
1400
1401 2006-03-12 Howard Hinnant <hhinnant@apple.com>
1402
1403 * testsuite/27_io/basic_filebuf/underflow/char/10097.cc:
1404 Fix race condition.
1405 * testsuite/27_io/objects/char/9661-1.cc: Likewise.
1406 * testsuite/27_io/objects/wchar_t/9661-1.cc: Likewise.
1407
1408 2006-03-10 Paolo Carlini <pcarlini@suse.de>
1409
1410 * include/tr1/cmath: Add atan2 and pow bits; add using declarations.
1411 * include/tr1/math.h: Add using declarations.
1412 * include/tr1/complex: Add using declarations.
1413 * testsuite/tr1/8_c_compatibility/cmath/functions.cc: Fully
1414 qualify calls.
1415 * testsuite/tr1/8_c_compatibility/cmath/overloads.cc: Likewise;
1416 add atan2 and pow bits.
1417 * testsuite/tr1/8_c_compatibility/complex/overloads_float.cc: Likewise.
1418 * testsuite/tr1/8_c_compatibility/complex/overloads_int.cc: Likewise;
1419 adjust polar bits.
1420
1421 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add checks for double_t
1422 and float_t typedefs.
1423 * include/tr1/cmath: Add double_t and float_t.
1424 * testsuite/tr1/8_c_compatibility/cmath/types.cc: New.
1425
1426 * include/tr1/ctgmath: New.
1427 * include/tr1/tgmath.h: Likewise.
1428 * include/Makefile.am: Add.
1429 * testsuite/tr1/headers.cc: Update.
1430
1431 * include/Makefile.in: Regenerate.
1432 * configure: Likewise.
1433
1434 * docs/html/ext/tr1.html: Update.
1435
1436 2006-03-08 Paolo Carlini <pcarlini@suse.de>
1437
1438 Implement the resolution of DR 455, [DR].
1439 * src/ios_init.cc (ios_base::Init::Init()): Do it.
1440 * testsuite/27_io/objects/char/dr455.cc: New.
1441 * testsuite/27_io/objects/wchar_t/dr455.cc: Likewise.
1442 * docs/html/ext/howto.html: Add an entry for DR 455.
1443
1444 2006-03-07 Paolo Carlini <pcarlini@suse.de>
1445
1446 * include/tr1/cmath: Add C99 overloads.
1447 * include/tr1/common.h (struct __promote_3): Add.
1448 * testsuite/tr1/8_c_compatibility/cmath/overloads.cc: New.
1449
1450 * testsuite/tr1/8_c_compatibility/cmath/functions.cc: Tweak.
1451 * testsuite/tr1/8_c_compatibility/complex/overloads_float.cc: Likewise.
1452
1453 2006-03-06 Paolo Carlini <pcarlini@suse.de>
1454
1455 PR target/26532
1456 * config/io/c_io_stdio.h (struct __ios_flags): Remove.
1457 * include/bits/ios_base.h: Adjust consistently.
1458 (ios_base::_S_local_word_size): Change to an anonymous enum.
1459 * src/ios.cc: Do not define static const data of __ios_flags,
1460 likewise for ios_base::_S_local_word_size.
1461 * include/bits/locale_classes.h (locale::_S_categories_size):
1462 Change to an anonymous enum.
1463 * src/locale.cc: Don't define.
1464
1465 2006-03-03 Paolo Carlini <pcarlini@suse.de>
1466
1467 PR libstdc++/26526
1468 * config/abi/pre/gnu.ver (__copy_streambufs, 64-bit version): Add
1469 @GLIBCXX_3.4.8; move existing symbols @GLIBCXX_3.4.8 to 3.4.9.
1470 * configure.ac (libtool_VERSION): To 6:9:0.
1471 * testsuite/testsuite_abi.cc (check_version): Add GLIBCXX_3.4.9.
1472 * configure: Regenerate.
1473
1474 2006-03-02 Paolo Carlini <pcarlini@suse.de>
1475
1476 * config/abi/pre/gnu.ver: Adjust __copy_streambufs_eof export
1477 vs 64-bit arches.
1478
1479 2006-03-01 Paolo Carlini <pcarlini@suse.de>
1480
1481 * docs/html/ext/lwg-active.html, lwg-defects.html: Import Revision 41.
1482
1483 2006-02-27 Jakub Jelinek <jakub@redhat.com>
1484
1485 PR other/26208
1486 * libsupc++/eh_personality.cc (PERSONALITY_FUNCTION): Use
1487 _Unwind_GetIPInfo instead of _Unwind_GetIP.
1488
1489 2006-02-27 Paolo Carlini <pcarlini@suse.de>
1490
1491 PR libstdc++/14866
1492 * testsuite/27_io/ios_base/sync_with_stdio/1.cc: Redirect
1493 stderr instead.
1494
1495 2006-02-26 Paolo Carlini <pcarlini@suse.de>
1496
1497 * include/tr1/cmath: Add templates (8.16.3).
1498 * include/tr1/cstdbool: New.
1499 * include/tr1/stdbool.h: Likewise.
1500 * include/Makefile.am: Add.
1501 * testsuite/tr1/8_c_compatibility/cmath/templates.cc: New.
1502 * testsuite/tr1/headers.cc: Update.
1503 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <stdbool.h> check.
1504 * docs/html/ext/tr1.html: Update.
1505 * include/Makefile.in: Regenerate.
1506 * config.h.in: Likewise.
1507 * configure: Likewise.
1508
1509 2006-02-24 Paolo Carlini <pcarlini@suse.de>
1510
1511 * include/tr1/array (array<>::swap, assign): Implement.
1512 * include/tr1/array (operator==, operator!=, operator<,
1513 operator>, operator>=, operator<=, swap, get): Inline.
1514 * testsuite/tr1/6_containers/array/requirements/member_swap.cc: New.
1515 * testsuite/tr1/6_containers/array/requirements/assign.cc: Likewise.
1516 * testsuite/tr1/6_containers/array/specialized_algorithms/swap.cc:
1517 Likewise.
1518
1519 2006-02-23 Benjamin Kosnik <bkoz@redhat.com>
1520
1521 * testsuite/22_locale/codecvt/in/wchar_t/1.cc (test01): Change int
1522 to size_t. Use explicit static_cast for casts.
1523 * testsuite/22_locale/codecvt/in/wchar_t/6.cc (test06): Same.
1524 * testsuite/22_locale/codecvt/in/wchar_t/5.cc (test05): Same.
1525 * testsuite/ext/stdio_sync_filebuf/wchar_t/1.cc (test01): Same.
1526
1527 2006-02-22 Paolo Carlini <pcarlini@suse.de>
1528
1529 * docs/html/ext/pb_assoc/
1530 basic_tree_assoc_cntnr_const_node_iterator.html:Fix links
1531 * docs/html/ext/pb_assoc/basic_tree_assoc_cntnr_node_iterator.html:
1532 Likewise.
1533 * docs/html/ext/pb_assoc/hash_based_containers.html: Likewise.
1534 * docs/html/ext/pb_assoc/hash_standard_resize_policy.html: Likewise.
1535 * docs/html/ext/pb_assoc/interface.html: Likewise..
1536 * docs/html/ext/pb_assoc/list_updates.html: Likewise.
1537 * docs/html/ext/pb_assoc/lu_based_containers.html: Likewise.
1538 * docs/html/ext/pb_assoc/resize_policies.html: Likewise.
1539 * docs/html/ext/pb_assoc/sample_probe_fn.html: Likewise.
1540 * docs/html/ext/pb_assoc/sample_range_hashing.html: Likewise.
1541 * docs/html/ext/pb_assoc/sample_ranged_hash_fn.html: Likewise.
1542 * docs/html/ext/pb_assoc/sample_ranged_probe_fn.html: Likewise.
1543 * docs/html/ext/pb_assoc/sample_resize_policy.html: Likewise.
1544 * docs/html/ext/pb_assoc/tree_assoc_cntnr_const_node_iterator.html:
1545 Likewise.
1546 * docs/html/ext/pb_assoc/tree_assoc_cntnr_node_iterator.html: Likewise.
1547
1548 2006-02-22 Paolo Carlini <pcarlini@suse.de>
1549
1550 PR libstdc++/26132
1551 * include/tr1/hashtable (hashtable<>::rehash): Define.
1552 * testsuite/tr1/6_containers/unordered/hashtable/26132.cc: New.
1553
1554 * include/tr1/hashtable: Trivial formatting and stylistic fixes.
1555
1556 * testsuite/tr1/headers.cc: remove <tr1/hashtable>, not a tr1 header,
1557 only an implementation detail.
1558
1559 2006-02-22 Paolo Carlini <pcarlini@suse.de>
1560
1561 * include/debug/list (splice): Remove splice_alloc check, redundant
1562 after implementing the splice bits of N1599.
1563
1564 2006-02-21 Benjamin Kosnik <bkoz@redhat.com>
1565
1566 * include/c_std/cmath.tcc: Use _GLIBCXX_BEGIN_NAMESPACE,
1567 _GLIBCXX_END_NAMESPACE.
1568
1569 2006-02-21 Benjamin Kosnik <bkoz@redhat.com>
1570
1571 * include/bits/c++config: Simplify debug namespaces.
1572 * include/ext/hash_set: Specialize insert_iterator after norm,
1573 debug containers have been (optionally) declared. Use nested
1574 namespaces.
1575 * include/ext/hash_map: Same.
1576 * include/debug/hash_map.h (insert): Add specialization for value
1577 pointer types.
1578 * include/debug/hash_set.h (insert): Same.
1579 * include/debug/hash_multimap.h: Change __gnu_debug_def to __debug.
1580 * include/debug/set.h: Same.
1581 * include/debug/bitset: Same.
1582 * include/debug/multiset.h: Same.
1583 * include/debug/hash_multiset.h: Same.
1584 * include/debug/vector: Same.
1585 * include/debug/map.h: Same.
1586 * include/debug/deque: Same.
1587 * include/debug/list: Same.
1588 * include/debug/multimap.h. Same.
1589 * include/debug/macros.h: Use __gnu_debug.
1590 * include/debug/debug.h: Same.
1591 * include/debug/formatter.h: Same.
1592 * include/debug/safe_sequence.h: Same.
1593 * include/debug/functions.h: Same.
1594 * include/debug/safe_base.h: Same.
1595 * include/debug/safe_iterator.h: Same.
1596 * include/debug/safe_iterator.tcc: Same.
1597 (_M_invalidate): Adjust compare order.
1598 * include/debug/string: Change std::__gnu_debug to __gnu_debug.
1599 * include/ext/hashtable.h: Formatting fixes.
1600 * include/bits/stl_map.h: Formatting fixes.
1601 * src/compatibility.cc: Adjust compatibility symbols for old debug
1602 mode model.
1603 * src/debug_list.cc: Tweak.
1604 * src/debug.cc: Adjust namespaces.
1605 * docs/html/debug_mode.html: Adjust namespace names.
1606 * testsuite/25_algorithms/heap/heap.cc: Restore _GLIBCXX_DEBUG
1607 macro guards, as count values differ when in debug mode.
1608 * testsuite/23_containers/vector/26412.cc: Move to...
1609 * testsuite/23_containers/vector/26412-1.cc: ... here.
1610 * testsuite/23_containers/vector/26412-2.cc: Add.
1611
1612 * include/ext/pb_assoc/detail/standard_policies.hpp
1613 (PB_ASSOC_HASH_NAMESPACE): Remove, use __gnu_cxx::hash_map and
1614 std::equal_to.
1615
1616 * configure.ac (libtool_VERSION): To 6:8:0.
1617 * configure: Regenerate.
1618 * config/abi/pre/gnu.ver: Revert to exporting __gnu_debug symbols.
1619 (GLIBCXX_3.4.8): New.
1620 * testsuite/testsuite_abi.cc: Add GLIBCXX_3.4.8 to known versions.
1621
1622 2006-02-21 Paolo Carlini <pcarlini@suse.de>
1623
1624 * include/tr1/hashtable: Trivial formatting fixes.
1625
1626 2006-02-20 Paolo Carlini <pcarlini@suse.de>
1627
1628 Revert recent commit for libstdc++/26211, now suspended waiting for
1629 DR 342 (reopened) to reach a new resolution.
1630 * include/bits/istream.tcc (basic_istream<>::tellg, seekg(pos_type),
1631 seekg(off_type, ios_base::seekdir)): Remove sentry.
1632 * testsuite/27_io/basic_istream/seekg/char/26211.cc: Remove.
1633 * testsuite/27_io/basic_istream/seekg/wchar_t/26211.cc: Likewise.
1634 * testsuite/27_io/basic_istream/tellg/char/26211.cc: Likewise.
1635 * testsuite/27_io/basic_istream/tellg/wchar_t/26211.cc: Likewise.
1636 * testsuite/27_io/basic_istream/seekg/char/8348-1.cc: Revert changes.
1637 * testsuite/27_io/basic_istream/seekg/wchar_t/8348-1.cc: Likewise.
1638 * testsuite/27_io/basic_istream/seekg/char/8348-2.cc: Likewise.
1639 * testsuite/27_io/basic_istream/seekg/wchar_t/8348-1.cc: Likewise.
1640 * testsuite/27_io/basic_istream/tellg/char/8348.cc: Likewise.
1641 * testsuite/27_io/basic_istream/tellg/wchar_t/8348.cc: Likewise.
1642
1643 2006-02-19 Paolo Carlini <pcarlini@suse.de>
1644
1645 * include/std/std_sstream.h (basic_stringbuf<>::setbuf): Simply
1646 clear the internal _M_string, adjust _M_sync call.
1647 * include/bits/sstream.tcc (basic_stringbuf<>::_M_sync): Adjust
1648 consistently for calls from setbuf.
1649
1650 2006-02-17 Paolo Carlini <pcarlini@suse.de>
1651 Howard Hinnant <hhinnant@apple.com>
1652
1653 PR libstdc++/26250
1654 * include/bits/sstream.tcc (basic_stringbuf<>::overflow): Tweak
1655 to leave epgtr() just past the new write position, as per the
1656 relevant bits of 27.7.1.3/8 (not changed by DR 432).
1657 * testsuite/27_io/basic_stringbuf/overflow/char/26250.cc: New.
1658 * testsuite/27_io/basic_stringbuf/overflow/wchar_t/26250.cc: Same.
1659
1660 * docs/html/ext/howto.html: Add entries for DR 169 and DR 432.
1661
1662 * include/std/std_sstream.h (basic_stringbuf<>::_M_sync): Move out
1663 of line...
1664 * include/bits/sstream.tcc: ... here.
1665
1666 2006-02-16 Joseph S. Myers <joseph@codesourcery.com>
1667
1668 PR libstdc++/14939
1669 * config/os/uclibc/ctype_base.h, config/os/uclibc/ctype_inline.h,
1670 config/os/uclibc/ctype_noninline.h, config/os/uclibc/os_defines.h:
1671 New.
1672 * acinclude.m4 (GLIBCXX_CONFIGURE): Test whether using uClibc.
1673 * configure.host: Use os/uclibc for uClibc.
1674 * crossconfig.m4 (*-linux*): Use link tests. Don't hardcode
1675 presence of math functions.
1676 * configure: Regenerate.
1677
1678 2006-02-12 Paolo Carlini <pcarlini@suse.de>
1679
1680 PR libstdc++/26211
1681 * include/bits/istream.tcc (basic_istream<>::tellg, seekg(pos_type),
1682 seekg(off_type, ios_base::seekdir)): Construct a sentry, as per
1683 27.6.1.3/1.
1684 * testsuite/27_io/basic_istream/seekg/char/26211.cc: New.
1685 * testsuite/27_io/basic_istream/seekg/wchar_t/26211.cc: Likewise.
1686 * testsuite/27_io/basic_istream/tellg/char/26211.cc: Likewise.
1687 * testsuite/27_io/basic_istream/tellg/wchar_t/26211.cc: Likewise.
1688 * testsuite/27_io/basic_istream/seekg/char/8348-1.cc: Adjust.
1689 * testsuite/27_io/basic_istream/seekg/wchar_t/8348-1.cc: Likewise.
1690 * testsuite/27_io/basic_istream/seekg/char/8348-2.cc: Likewise.
1691 * testsuite/27_io/basic_istream/seekg/wchar_t/8348-1.cc: Likewise.
1692 * testsuite/27_io/basic_istream/tellg/char/8348.cc: Likewise.
1693 * testsuite/27_io/basic_istream/tellg/wchar_t/8348.cc: Likewise.
1694
1695 2006-02-10 Paolo Carlini <pcarlini@suse.de>
1696
1697 PR libstdc++/26181
1698 * include/bits/streambuf.tcc (__copy_streambufs_eof): New, like
1699 the existing __copy_streambufs but reporting eof in input.
1700 (__copy_streambufs): Just use the latter.
1701 * src/streambuf.cc (__copy_streambufs_eof): Adjust specializations
1702 of __copy_streambufs.
1703 * include/bits/istream.tcc (operator>>(__streambuf_type*)): Use
1704 __copy_streambufs_eof instead.
1705 * include/std/std_streambuf.h: Adjust.
1706 * src/streambuf-inst.cc: Adjust.
1707 * config/abi/pre/gnu.ver: Export the new symbols.
1708 * testsuite/27_io/basic_istream/extractors_other/char/26181.cc: New.
1709 * testsuite/27_io/basic_istream/extractors_other/wchar_t/26181.cc:
1710 Likewise.
1711 * testsuite/27_io/basic_istream/extractors_other/char/1.cc: Adjust.
1712 * testsuite/27_io/basic_istream/extractors_other/wchar_t/1.cc:
1713 Likewise.
1714
1715 2006-02-08 Benjamin Kosnik <bkoz@redhat.com>
1716
1717 PR libstdc++/26142
1718 * include/debug/debug.h: Move debug alias inside namespace std,
1719 same with namespace __gnu_cxx. Add top-level __gnu_debug
1720 namespace.
1721 * include/debug/hash_multimap.h: Nest within __gnu_cxx, not
1722 std. Also, change nesting namespace name from __gnu_debug_def to
1723 __gnu_debug.
1724 * include/debug/hash_map.h: Same.
1725 * include/debug/hash_multiset.h: Same.
1726 * include/debug/hash_set.h: Same.
1727 * docs/html/debug.html: Same.
1728 * testsuite/23_containers/vector/26412.cc: New.
1729 * testsuite/23_containers/vector/invalidation/1.cc: Correct
1730 qualifications for debug namespace change.
1731 * testsuite/23_containers/vector/invalidation/2.cc: Same.
1732 * testsuite/23_containers/vector/invalidation/3.cc: Same.
1733 * testsuite/23_containers/vector/invalidation/4.cc: Same.
1734 * testsuite/23_containers/deque/invalidation/1.cc: Same.
1735 * testsuite/23_containers/deque/invalidation/2.cc: Same.
1736 * testsuite/23_containers/deque/invalidation/3.cc: Same.
1737 * testsuite/23_containers/deque/invalidation/4.cc: Same.
1738 * testsuite/23_containers/multiset/invalidation/1.cc: Same.
1739 * testsuite/23_containers/multiset/invalidation/2.cc: Same.
1740 * testsuite/23_containers/multimap/invalidation/1.cc: Same.
1741 * testsuite/23_containers/multimap/invalidation/2.cc: Same.
1742 * testsuite/23_containers/bitset/invalidation/1.cc: Same.
1743 * testsuite/23_containers/bitset/cons/16020.cc: Same.
1744 * testsuite/23_containers/bitset/operations/13838.cc: Same.
1745 * testsuite/23_containers/list/invalidation/1.cc: Same.
1746 * testsuite/23_containers/list/invalidation/2.cc: Same.
1747 * testsuite/23_containers/list/invalidation/3.cc: Same.
1748 * testsuite/23_containers/list/invalidation/4.cc: Same.
1749 * testsuite/23_containers/set/invalidation/1.cc: Same.
1750 * testsuite/23_containers/set/invalidation/2.cc: Same.
1751 * testsuite/23_containers/map/invalidation/1.cc: Same.
1752 * testsuite/23_containers/map/invalidation/2.cc: Same.
1753 * testsuite/23_containers/map/modifiers/insert/16813.cc: Same.
1754 * testsuite/21_strings/basic_string/2.cc: Same.
1755
1756 2006-02-08 Paolo Carlini <pcarlini@suse.de>
1757
1758 PR libstdc++/26133 (DR 241, [WP])
1759 * include/bits/stl_algo.h (__unique_copy(,,, forward_iterator_tag,
1760 output_iterator_tag), __unique_copy(,,, input_iterator_tag,
1761 output_iterator_tag), __unique_copy(,,, input_iterator_tag,
1762 forward_iterator_tag), and predicated counterparts): Add.
1763 (__unique_copy(,,, output_iterator_tag), __unique_copy(,,,
1764 forward_iterator_tag), and predicated counterparts): Remove.
1765 (unique_copy): Adjust, dispatch to the three helpers above.
1766 * testsuite/25_algorithms/unique_copy/2.cc: New.
1767 * testsuite/25_algorithms/unique_copy/26133.cc: Likewise.
1768 * testsuite/25_algorithms/unique_copy/3.cc: Likewise.
1769 * docs/html/ext/howto.html: Add an entry for DR 241.
1770
1771 * testsuite/25_algorithms/unique_copy/1.cc: Minor cosmetic changes.
1772
1773 2006-02-07 Jakub Jelinek <jakub@redhat.com>
1774 Benjamin Kosnik <bkoz@redhat.com>
1775
1776 * configure.ac (_GLIBCXX_LONG_DOUBLE_COMPAT): New check.
1777 If true, set also port_specific_symbol_files and create
1778 as_symver_specs.
1779 (GLIBCXX_LDBL_COMPAT): New GLIBCXX_CONDITIONAL.
1780 * configure: Rebuilt.
1781 * config.h.in: Rebuilt.
1782 * config/os/gnu-linux/ldbl-extra.ver: New file.
1783 * config/abi/pre/gnu.ver: Make sure no __float128 symbols are
1784 exported.
1785 * include/bits/c++config (_GLIBCXX_LONG_DOUBLE_COMPAT,
1786 _GLIBCXX_LDBL_NAMESPACE, _GLIBCXX_BEGIN_LDBL_NAMESPACE,
1787 _GLIBCXX_END_LDBL_NAMESPACE): Define.
1788 * include/bits/localefwd.h: Use them to conditionally scope facets.
1789 * include/bits/locale_facets.h: Surround std::{money,num}_{get,put}
1790 with _GLIBCXX_BEGIN_LDBL_NAMESPACE and _GLIBCXX_END_LDBL_NAMESPACE.
1791 Surround std::{money,num}_{get,put}
1792 with _GLIBCXX_BEGIN_LDBL_NAMESPACE and _GLIBCXX_END_LDBL_NAMESPACE.
1793 [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::money_get): Add __do_get method.
1794 [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::money_put): Add __do_put method.
1795 [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::num_get): Add __do_get method.
1796 [_GLIBCXX_LONG_DOUBLE_COMPAT] (std::num_put): Add __do_put method.
1797 * include/bits/locale_facets.tcc: Surround std::{money,num}_{get,put}
1798 with _GLIBCXX_BEGIN_LDBL_NAMESPACE and _GLIBCXX_END_LDBL_NAMESPACE.
1799 (std::money_get::__do_get, std::money_put::__do_put,
1800 std::num_get::__do_get, std::num_put::__do_put): New
1801 specializations.
1802 * include/Makefile.am: Conditionally define
1803 _GLIBCXX_LONG_DOUBLE_COMPAT in c++config.
1804 * include/Makefile.in: Regenerate.
1805 * src/locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT] (_GLIBCXX_LOC_ID,
1806 _GLIBCXX_SYNC_ID): Define, use them.
1807 * src/compatibility-ldbl.cc: New file.
1808 * src/complex_io.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Add compatibility
1809 symbols.
1810 * src/limits.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
1811 * src/locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
1812 * src/locale-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
1813 * src/locale-misc-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
1814 * src/istream-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
1815 * src/ostream-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
1816 * src/locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
1817 * src/wlocale-inst.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
1818 * src/compatibility.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]: Likewise.
1819 * config/locale/generic/c_locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]:
1820 Likewise.
1821 * config/locale/gnu/c_locale.cc [_GLIBCXX_LONG_DOUBLE_COMPAT]:
1822 Likewise.
1823 * src/Makefile.am (libstdc++-symbol.ver): Append instead of
1824 insert in the middle if port specific symbol file requests it.
1825 (ldbl_compat_sources): New variable.
1826 (sources): Use it.
1827 (compatibility-ldbl.lo, compatibility-ldbl.o): New rules.
1828 * src/Makefile.in: Rebuilt.
1829 * testsuite/testsuite_abi.cc: Recognize GLIBCXX_LDBL_3.4,
1830 GLIBCXX_LDBL_3.4.7, CXXABI_LDBL_1.3.
1831
1832 2006-02-07 Paolo Carlini <pcarlini@suse.de>
1833
1834 * include/tr1/hashtable: Trivial formatting fixes.
1835
1836 2006-02-07 Paolo Carlini <pcarlini@suse.de>
1837 Zak Kipling <zak@transversal.com>
1838
1839 PR libstdc++/26127
1840 * include/tr1/hashtable (hashtable<>::key_equal): Define.
1841 (hashtable<>::bucket, rehash_base<>::max_load_factor): Fix.
1842 * testsuite/tr1/6_containers/unordered/hashtable/26127.cc: New.
1843
1844 2006-02-07 Paolo Carlini <pcarlini@suse.de>
1845
1846 * include/tr1/cmath: New.
1847 * include/tr1/cstdlib: Likewise.
1848 * include/tr1/ctime: Likewise.
1849 * include/tr1/math.h: Likewise.
1850 * include/tr1/stdlib.h: Likewise.
1851 * include/Makefile.am: Add.
1852 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <math.h> checks.
1853 * testsuite/tr1/8_c_compatibility/cmath/functions.cc: New.
1854 * testsuite/tr1/8_c_compatibility/cstdlib/functions.cc: Likewise.
1855 * testsuite/tr1/8_c_compatibility/cstdlib/types.cc: Likewise.
1856 * testsuite/tr1/headers.cc: Update.
1857
1858 * include/tr1/cinttypes: Do not provide abs and div, conflicting
1859 with the above overloads for _Longlong types.
1860 * include/tr1/inttypes.h: Adjust.
1861 * testsuite/tr1/8_c_compatibility/cinttypes/functions.cc: Adjust.
1862
1863 * docs/html/ext/tr1.html: Update.
1864
1865 * testsuite/tr1/8_c_compatibility/cwchar/functions.cc: Tweak.
1866
1867 * include/Makefile.in: Regenerate.
1868 * config.h.in: Likewise.
1869 * configure: Likewise.
1870
1871 2006-02-07 Mark Mitchell <mark@codesourcery.com>
1872
1873 * testsuite/testsuite_tr1.h (test_property): New function.
1874 * testsuite/tr1/4_metaprogramming/type_properties/extent/extent.cc
1875 (test01)
1876
1877 2006-02-05 Paolo Carlini <pcarlini@suse.de>
1878
1879 * include/tr1/cstdio: New.
1880 * include/tr1/stdio.h: Likewise.
1881 * include/Makefile.am: Add.
1882 * testsuite/tr1/8_c_compatibility/cstdio/functions.cc: New.
1883 * testsuite/tr1/headers.cc: Update.
1884 * docs/html/ext/tr1.html: Update.
1885
1886 * include/tr1/cwchar: Simplify, use _GLIBCXX_USE_C99, consistently
1887 with the facilities in std::.
1888 * include/tr1/cwctype: Likewise.
1889 * testsuite/tr1/8_c_compatibility/cwchar/functions.cc: Tweak.
1890 * testsuite/tr1/8_c_compatibility/cwctype/functions.cc: Likewise.
1891 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Remove <wchar.h> and
1892 <wctype.h> checks.
1893
1894 * include/Makefile.in: Regenerate.
1895 * config.h.in: Likewise.
1896 * configure: Likewise.
1897
1898 2006-02-04 Paolo Carlini <pcarlini@suse.de>
1899
1900 * testsuite/tr1/8_c_compatibility/cwchar/functions.cc: Fix.
1901
1902 2006-02-04 Paolo Carlini <pcarlini@suse.de>
1903
1904 * testsuite/27_io/basic_stringbuf/in_avail/char/21955.cc: Avoid
1905 warning on string constant.
1906
1907 2006-02-03 Paolo Carlini <pcarlini@suse.de>
1908
1909 * include/tr1/cwchar: New.
1910 * include/tr1/cwctype: Likewise.
1911 * include/tr1/wchar.h: Likewise.
1912 * include/tr1/wctype.h: Likewise.
1913 * include/Makefile.am: Add.
1914 * testsuite/tr1/8_c_compatibility/cwchar/functions.cc: New.
1915 * testsuite/tr1/8_c_compatibility/cwctype/functions.cc: Likewise.
1916 * testsuite/tr1/headers.cc: Update.
1917 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <wchar.h> and
1918 <wctype.h> checks.
1919 * docs/html/ext/tr1.html: Update.
1920 * include/Makefile.in: Regenerate.
1921 * config.h.in: Likewise.
1922 * configure: Likewise.
1923
1924 * testsuite/tr1/8_c_compatibility/cctype/functions.cc: Cosmetic tweak.
1925
1926 2006-02-02 Paolo Carlini <pcarlini@suse.de>
1927
1928 * include/tr1/cfloat: New.
1929 * include/tr1/climits: Likewise.
1930 * include/tr1/cstdarg: Likewise.
1931 * include/tr1/ctype.h: Likewise.
1932 * include/tr1/fenv.h: Likewise.
1933 * include/tr1/float.h: Likewise.
1934 * include/tr1/inttypes.h: Likewise.
1935 * include/tr1/limits.h: Likewise.
1936 * include/tr1/stdint.h: Likewise.
1937 * include/tr1/stdarg.h: Likewise.
1938 * include/Makefile.am: Add.
1939 * include/Makefile.in: Regenerate.
1940 * docs/html/ext/tr1.html: Update.
1941 * testsuite/tr1/headers.cc: New.
1942
1943 * include/tr1/cctype: Include <cctype> instead.
1944
1945 2006-01-31 Paolo Carlini <pcarlini@suse.de>
1946
1947 PR libstdc++/21554
1948 * include/tr1/array (array<>::_M_instance): Maximally align.
1949 * testsuite/ext/array_allocator/2.cc: Do not xfail for powerpc.
1950
1951 2006-01-31 Ed Smith-Rowland <3dw4rd@verizon.net>
1952
1953 * docs/html/faq/index.html ([1.0]): Replace references to CVS
1954 with appropriate references to SVN.
1955 ([1.3]): Likewise.
1956 ([1.4]): Likewise.
1957 ([2.3]): Likewise.
1958 * docs/html/faq/index.txt: Regenerated.
1959
1960 2006-01-30 Gabriel Dos Reis <gdr@integrable-solutions.net>
1961
1962 * include/bits/valarray_array.h (__valarray_default_construct):
1963 Replace use __is_fundamental with __is_pod.
1964 (__valarray_fill_construct): Likewise.
1965 (__valarray_copy_construct): Likewise.
1966 (__valarray_destroy_elements): Likewise.
1967 (__valarray_copy): Likewise.
1968
1969 2006-01-30 Paolo Carlini <pcarlini@suse.de>
1970
1971 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Do the <inttypes.h>
1972 checks only if the <stdint.h> checks are successful.
1973 * configure: Regenerate.
1974
1975 2006-01-30 Paolo Carlini <pcarlini@suse.de>
1976
1977 * include/tr1/cinttypes: New.
1978 * include/Makefile.am: Add.
1979 * testsuite/tr1/8_c_compatibility/cinttypes/functions: New.
1980 * testsuite/tr1/8_c_compatibility/cinttypes/types: Likewise.
1981 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <inttypes.h> checks.
1982 * docs/html/ext/tr1.html: Update.
1983 * include/Makefile.in: Regenerate.
1984 * config.h.in: Likewise.
1985 * configure: Likewise.
1986
1987 * testsuite/tr1/8_c_compatibility/cfenv/functions.cc: Cosmetic tweak.
1988 * testsuite/tr1/8_c_compatibility/cfenv/types.cc: Likewise.
1989
1990 * testsuite/tr1/8_c_compatibility/cstdint/types.cc: Fix, check in
1991 std::tr1.
1992
1993 2006-01-29 Paolo Carlini <pcarlini@suse.de>
1994
1995 * include/tr1/cstdint: New.
1996 * include/Makefile.am: Add.
1997 * testsuite/tr1/8_c_compatibility/cstdint/types: New.
1998 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <stdint.h> checks.
1999 * docs/html/ext/tr1.html: Update.
2000 * include/Makefile.in: Regenerate.
2001 * config.h.in: Likewise.
2002 * configure: Likewise.
2003
2004 * testsuite/tr1/8_c_compatibility/cfenv/types.cc: Cosmetic tweak.
2005
2006 2006-01-29 Paolo Carlini <pcarlini@suse.de>
2007
2008 PR libstdc++/26006
2009 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Tighten <ctype.h> and
2010 <fenv.h> checks.
2011 * configure: Regenerate.
2012
2013 2006-01-26 Paolo Carlini <pcarlini@suse.de>
2014
2015 * include/std/std_bitset.h (bitset<>::_M_copy_to_string):
2016 Call the internal _Unchecked_set(size_t) instead of set.
2017
2018 2006-01-26 Paolo Carlini <pcarlini@suse.de>
2019
2020 * docs/html/install.html ([Tools you will need beforehand]):
2021 Clarify that the de_DE locale is used by configure; clarify
2022 that missing localedata leads to skipped tests, not fails.
2023
2024 2006-01-26 Paolo Carlini <pcarlini@suse.de>
2025
2026 * include/tr1/cfenv: New.
2027 * include/Makefile.am: Add.
2028 * testsuite/tr1/8_c_compatibility/cfenv/functions.cc: New.
2029 * testsuite/tr1/8_c_compatibility/cfenv/types.cc: Likewise.
2030 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): Add <fenv.h> checks.
2031 * docs/html/ext/tr1.html: Update; add note.
2032 * include/Makefile.in: Regenerate.
2033 * config.h.in: Likewise.
2034 * configure: Likewise.
2035
2036 * testsuite/tr1/8_c_compatibility/complex/functions.cc: Tweak.
2037 * testsuite/tr1/8_c_compatibility/cctype/functions.cc: Likewise.
2038
2039 * docs/html/faq/index.html: Fix link to tr1.html text; fix
2040 formatting.
2041
2042 2006-01-25 Paolo Carlini <pcarlini@suse.de>
2043
2044 * include/tr1/cctype: New.
2045 * include/Makefile.am: Add.
2046 * testsuite/tr1/8_c_compatibility/cctype/functions.cc: New.
2047 * include/Makefile.in: Regenerate.
2048
2049 * acinclude.m4 ([GLIBCXX_CHECK_C99_TR1]): New, check for C99
2050 support to TR1, Chapter 8.
2051 * configure.ac: Use it.
2052 * include/tr1/complex: Adjust.
2053 * config.h.in: Regenerate.
2054 * configure: Likewise.
2055
2056 2006-01-25 Benjamin Kosnik <bkoz@redhat.com>
2057
2058 * docs/html/configopts.html: Tweak docs.
2059
2060 * libsupc++/eh_personality.cc: Fix typos.
2061
2062 2006-01-24 Paolo Carlini <pcarlini@suse.de>
2063
2064 PR libstdc++/25649
2065 * include/std/std_istream.h (operator>>(short&), operator>>(int&)):
2066 Move out of line...
2067 * include/bits/istream.tcc: ... here.
2068 * include/std/std_ostream.h (operator<<(short), operator<<(int)):
2069 Move out of line...
2070 * include/bits/ostream.tcc: ... here.
2071
2072 2006-01-24 Ed Smith-Rowland <3dw4rd@verizon.net>
2073
2074 * docs/html/faq/index.html ([5.2]): Mention TR1 and point to
2075 paragraph [5.5], describing it.
2076 ([5.5]): New.
2077 * docs/html/ext/tr1.html: New.
2078
2079 2006-01-20 Benjamin Kosnik <bkoz@redhat.com>
2080
2081 * acinclude.m4 (GLIBCXX_CHECK_LINKER_FEATURES): Verbose ld version
2082 reporting. Disable --gc-sections for old binutils, by version.
2083 * configure: Regenerate.
2084
2085 2006-01-20 Joseph S. Myers <joseph@codesourcery.com>
2086
2087 PR libstdc++/25524
2088 * include/Makefile.am: Install host-specific headers in multilib
2089 subdirectory.
2090 * include/Makefile.in: Regenerate.
2091
2092 2006-01-19 Paolo Carlini <pcarlini@suse.de>
2093
2094 Implement list::splice (and merge) bits of N1599
2095 * include/bits/stl_list.h (list<>::_M_check_equal_allocators): New.
2096 (list<>::splice(iterator, list&), splice(iterator, list&, iterator),
2097 splice(iterator, list&, iterator, iterator)): Use it.
2098 * include/bits/list.tcc (list<>::merge(list&), merge(list&,
2099 _StrictWeakOrdering)): Likewise.
2100 * testsuite/23_containers/list/operators/5.cc: New.
2101
2102 2006-01-19 H.J. Lu <hongjiu.lu@intel.com>
2103
2104 PR libstdc++/25797
2105 * acinclude.m4 (GLIBCXX_CHECK_LINKER_FEATURES): Remove -Werror
2106 from CFLAGS. Check if linker really supports --gc-sections.
2107 * configure: Regenerated.
2108
2109 2006-01-18 Paul Brook <paul@codesourcery.com>
2110
2111 * libsupc++/eh_personality.cc (PERSONALITY_FUNCTION): Use std::abort.
2112
2113 2006-01-18 Paolo Carlini <pcarlini@suse.de>
2114
2115 * include/bits/allocator.h: Include <bits/cpp_type_traits.h>.
2116
2117 2006-01-18 Perry Smith <pedz@easesoftware.net>
2118
2119 PR libstdc++/25823
2120 PR libstdc++/25824
2121 * libsupc++/eh_alloc.cc: Fix return type of memset declaration.
2122 * libsupc++/eh_globals.cc: If !_GLIBCXX_HOSTED declare malloc and free.
2123
2124 2006-01-18 Paolo Carlini <pcarlini@suse.de>
2125
2126 * include/ext/pb_assoc/detail/value_type_adapter/
2127 value_type_adapter.hpp: Include <tr1/type_traits>.
2128 * include/ext/pb_assoc/detail/value_type_adapter/
2129 it_value_type_traits.hpp (it_value_type_traits_<>::value_type_holder):
2130 Use tr1::aligned_storage and tr1::alignment_of.
2131 (it_value_type_traits_<>::buf_t): Remove.
2132 (it_value_type_traits_<>::make_valid, recast): Adjust.
2133
2134 2006-01-16 Benjamin Kosnik <bkoz@redhat.com>
2135
2136 PR libstdc++/25797
2137 * acinclude.m4 (GLIBCXX_CHECK_LINKER_FEATURES): Add -Werror to
2138 CFLAGS for --gc-sections test. Correct compile test.
2139 * configure: Regenerated.
2140
2141 2006-01-15 Paolo Carlini <pcarlini@suse.de>
2142 Gabriel Dos Reis <gdr@integrable-solutions.net>
2143
2144 PR libstdc++/25626
2145 * include/std/std_valarray.h (valarray(const slice_array<>&),
2146 valarray(const gslice_array<>&), valarray(const mask_array<>&),
2147 valarray(const indirect_array<>&), valarray(const _Expr<>&)):
2148 Forward to __valarray_copy_construct, not __valarray_copy.
2149 * include/bits/valarray_array.h
2150 (__valarray_copy_construct(_Array<>, _Array<>, _Array<>, size_t),
2151 __valarray_copy_construct(_Array<>, size_t, size_t, _Array<>)):
2152 New.
2153
2154 2006-01-15 Paolo Carlini <pcarlini@suse.de>
2155
2156 * testsuite/tr1/8_c_compatibility/complex/overloads_int.cc:
2157 Fix norm test, use casts everywhere.
2158
2159 2006-01-14 Paolo Carlini <pcarlini@suse.de>
2160
2161 * testsuite/testsuite_tr1.h: Add missing include; use std::__are_same.
2162
2163 2006-01-14 Paolo Carlini <pcarlini@suse.de>
2164
2165 * testsuite/tr1/8_c_compatibility/complex/overloads_int.cc:
2166 Fix wrong test (don't pick by mistake the (const complex<>&, int)
2167 overload); add some.
2168
2169 2006-01-13 Paolo Carlini <pcarlini@suse.de>
2170 Howard Hinnant <hhinnant@apple.com>
2171
2172 * include/tr1/complex (arg, conj, imag, norm, polar, pow, real):
2173 Add, implementing TR1, 8.1.9.
2174 (__promote_2): New.
2175 * include/tr1/common.h: New, provides __promote, __promote_2.
2176 * include/Makefile.am: Add.
2177 * include/Makefile.in: Regenerate.
2178 * testsuite/testsuite_tr1.h (check_ret_type): New.
2179 * testsuite/tr1/8_c_compatibility/complex/overloads_int.cc: New.
2180 * testsuite/tr1/8_c_compatibility/complex/overloads_float.cc: New.
2181
2182 2006-01-12 Benjamin Kosnik <bkoz@redhat.com>
2183
2184 * acinclude.m4(GLIBCXX_CHECK_LINKER_FEATURES): Enable
2185 --gc-sections in more cases.
2186 * configure: Regenerate.
2187 * scripts/testsuite_flags.in: Remove SECTION_LDFLAGS.
2188 * scripts/testsuite_flags.in (cxxldflags): New.
2189 * testsuite/lib/libstdc++.exp (v3_target_compile): Add cxxldflags.
2190 (libstdc++_init ): Same.
2191
2192 2006-01-12 Jan Beulich <jbeulich@novell.com>
2193
2194 * crossconfig.m4: Add AC_DEFINE-s for HAVE_HYPOT, HAVE_ISINF, and
2195 HAVE_ISNAN for *-*-netware*.
2196 * configure: Refresh.
2197
2198 2006-01-11 Benjamin Kosnik <bkoz@redhat.com>
2199
2200 * acinclude.m4(GLIBCXX_CHECK_LINKER_FEATURES): Use -Wl,-z,relro if
2201 possible.
2202 * configure: Regenerate.
2203
2204 2006-01-10 Paolo Carlini <pcarlini@suse.de>
2205
2206 * include/tr1/complex: New file, hosts the additions to header
2207 <complex> described in TR1, Chapter 8 [tr.c99].
2208 * include/Makefile.am: Add.
2209 * include/Makefile.in: Regenerate.
2210 * testsuite/tr1/8_c_compatibility/complex/functions.cc: New.
2211
2212 2006-01-09 Paolo Carlini <pcarlini@suse.de>
2213
2214 PR libstdc++/25658
2215 * testsuite/23_containers/deque/cons/assign/1.cc: Divide
2216 sizes by 10.
2217
2218 2006-01-08 Paolo Carlini <pcarlini@suse.de>
2219
2220 PR libstdc++/22102 (insert as close to hint as possible)
2221 * include/bits/stl_tree.h (_Rb_tree<>::_M_insert_lower,
2222 _M_insert_equal_lower): New.
2223 (_M_insert_equal(iterator, const _Val&),
2224 _M_insert_equal(const_iterator, const _Val&)): Use the above.
2225 * docs/html/ext/howto.html: Add an entry for DR 233.
2226 * testsuite/23_containers/multiset/modifiers/insert/22102.cc: New.
2227 * testsuite/23_containers/multimap/modifiers/insert/22102.cc: New.
2228
2229 * testsuite/23_containers/set/insert/: Move...
2230 * testsuite/23_containers/set/modifiers/insert/: ...here.
2231 * testsuite/23_containers/map/insert/: Move...
2232 * testsuite/23_containers/map/modifiers/insert/: ...here.
2233 * testsuite/23_containers/multiset/insert/: Move...
2234 * testsuite/23_containers/multiset/modifiers/insert/: ...here.
2235
2236 2006-01-06 Paolo Carlini <pcarlini@suse.de>
2237
2238 * include/bits/stl_tree.h (_Rb_tree<>::insert_unique): Rename
2239 to _M_insert_unique.
2240 (_Rb_tree<>::insert_equal): Rename to _M_insert_equal.
2241 * include/bits/stl_map.h (class map<>): Update callers.
2242 * include/bits/stl_set.h (class set<>): Likewise.
2243 * include/bits/stl_multimap.h (class multimap<>): Likewise.
2244 * include/bits/stl_multiset.h (class multiset<>): Likewise.
2245
2246 2006-01-06 Paolo Carlini <pcarlini@suse.de>
2247
2248 * include/bits/stl_bvector.h (vector<bool>::erase(iterator,
2249 iterator)): Just use _M_erase_at_end.
2250
2251 2006-01-06 Paolo Carlini <pcarlini@suse.de>
2252
2253 * include/bits/stl_bvector.h (class vector<bool>): Move all the
2254 helpers under protected access mode, consistently with the primary
2255 vector template.
2256 (vector<bool>::_M_erase_at_end): Add.
2257 (erase(iterator, iterator), clear, resize, _M_fill_assign,
2258 _M_assign_aux): Use it.
2259 * testsuite/23_containers/vector/bool/modifiers/erase/1.cc: New.
2260
2261 2006-01-06 Paolo Carlini <pcarlini@suse.de>
2262
2263 Implement Option 3 of DR 431 for vector<bool>.
2264 * include/bits/stl_bvector.h (class _Bvector_base): Change to
2265 a struct, consistently with the primary vector template.
2266 (class vector<bool>): Adjust to protected inheritance, tidy
2267 typedefs.
2268 (_Bvector_base<>::_M_get_Bit_allocator): Add.
2269 (vector<bool>::vector(const vector&)): Use it.
2270 (_Bvector_base<>::get_allocator): Tidy.
2271 (vector<bool>::swap): Use __alloc_swap.
2272 * testsuite/23_containers/vector/bool/modifiers/swap/1.cc: New.
2273 * testsuite/23_containers/vector/bool/modifiers/swap/2.cc: New.
2274
2275 2006-01-05 Paolo Carlini <pcarlini@suse.de>
2276
2277 * testsuite/testsuite_hooks.h (test_tm(unsigned)): Change to
2278 take all the tm members.
2279 * testsuite/testsuite_hooks.cc (test_tm): Adjust.
2280 * testsuite/22_locale/time_put/put/wchar_t/10.cc: Update.
2281 * testsuite/22_locale/time_put/put/wchar_t/1.cc: Likewise.
2282 * testsuite/22_locale/time_put/put/wchar_t/2.cc: Likewise.
2283 * testsuite/22_locale/time_put/put/wchar_t/3.cc: Likewise.
2284 * testsuite/22_locale/time_put/put/wchar_t/4.cc: Likewise.
2285 * testsuite/22_locale/time_put/put/wchar_t/5.cc: Likewise.
2286 * testsuite/22_locale/time_put/put/wchar_t/6.cc: Likewise.
2287 * testsuite/22_locale/time_put/put/wchar_t/7.cc: Likewise.
2288 * testsuite/22_locale/time_put/put/wchar_t/8.cc: Likewise.
2289 * testsuite/22_locale/time_put/put/wchar_t/9.cc: Likewise.
2290 * testsuite/22_locale/time_put/put/wchar_t/17038.cc: Likewise.
2291 * testsuite/22_locale/time_put/put/char/10.cc: Likewise.
2292 * testsuite/22_locale/time_put/put/char/1.cc: Likewise.
2293 * testsuite/22_locale/time_put/put/char/2.cc: Likewise.
2294 * testsuite/22_locale/time_put/put/char/3.cc: Likewise.
2295 * testsuite/22_locale/time_put/put/char/4.cc: Likewise.
2296 * testsuite/22_locale/time_put/put/char/5.cc: Likewise.
2297 * testsuite/22_locale/time_put/put/char/6.cc: Likewise.
2298 * testsuite/22_locale/time_put/put/char/7.cc: Likewise.
2299 * testsuite/22_locale/time_put/put/char/8.cc: Likewise.
2300 * testsuite/22_locale/time_put/put/char/9.cc: Likewise.
2301 * testsuite/22_locale/time_put/put/char/17038.cc: Likewise.
2302 * testsuite/22_locale/time_get/get_year/wchar_t/1.cc: Likewise.
2303 * testsuite/22_locale/time_get/get_year/wchar_t/3.cc: Likewise.
2304 * testsuite/22_locale/time_get/get_year/char/1.cc: Likewise.
2305 * testsuite/22_locale/time_get/get_year/char/3.cc: Likewise.
2306 * testsuite/22_locale/time_get/get_monthname/wchar_t/1.cc: Likewise.
2307 * testsuite/22_locale/time_get/get_monthname/wchar_t/2.cc: Likewise.
2308 * testsuite/22_locale/time_get/get_monthname/char/1.cc: Likewise.
2309 * testsuite/22_locale/time_get/get_monthname/char/2.cc: Likewise.
2310 * testsuite/22_locale/time_get/get_weekday/wchar_t/1.cc: Likewise.
2311 * testsuite/22_locale/time_get/get_weekday/wchar_t/2.cc: Likewise.
2312 * testsuite/22_locale/time_get/get_weekday/wchar_t/3.cc: Likewise.
2313 * testsuite/22_locale/time_get/get_weekday/char/1.cc: Likewise.
2314 * testsuite/22_locale/time_get/get_weekday/char/2.cc: Likewise.
2315 * testsuite/22_locale/time_get/get_weekday/char/3.cc: Likewise.
2316 * testsuite/22_locale/time_get/get_date/wchar_t/12750.cc: Likewise.
2317 * testsuite/22_locale/time_get/get_date/wchar_t/12750.cc: Likewise.
2318 * testsuite/22_locale/time_get/get_date/wchar_t/1.cc: Likewise.
2319 * testsuite/22_locale/time_get/get_date/wchar_t/2.cc: Likewise.
2320 * testsuite/22_locale/time_get/get_date/wchar_t/3.cc: Likewise.
2321 * testsuite/22_locale/time_get/get_date/char/12750.cc: Likewise.
2322 * testsuite/22_locale/time_get/get_date/char/12750.cc: Likewise.
2323 * testsuite/22_locale/time_get/get_date/char/1.cc: Likewise.
2324 * testsuite/22_locale/time_get/get_date/char/2.cc: Likewise.
2325 * testsuite/22_locale/time_get/get_date/char/3.cc: Likewise.
2326 * testsuite/22_locale/time_get/get_time/wchar_t/1.cc: Likewise.
2327 * testsuite/22_locale/time_get/get_time/wchar_t/2.cc: Likewise.
2328 * testsuite/22_locale/time_get/get_time/wchar_t/3.cc: Likewise.
2329 * testsuite/22_locale/time_get/get_time/wchar_t/4.cc: Likewise.
2330 * testsuite/22_locale/time_get/get_time/char/1.cc: Likewise.
2331 * testsuite/22_locale/time_get/get_time/char/2.cc: Likewise.
2332 * testsuite/22_locale/time_get/get_time/char/3.cc: Likewise.
2333 * testsuite/22_locale/time_get/get_time/char/4.cc: Likewise.
2334
2335 2006-01-05 Paolo Carlini <pcarlini@suse.de>
2336
2337 * testsuite/testsuite_hooks.h (test_tm(unsigned)): New.
2338 * testsuite/testsuite_hooks.cc (test_tm(unsigned)): Define.
2339 * testsuite/22_locale/time_put/put/wchar_t/10.cc: Use it.
2340 * testsuite/22_locale/time_put/put/wchar_t/1.cc: Likewise.
2341 * testsuite/22_locale/time_put/put/wchar_t/2.cc: Likewise.
2342 * testsuite/22_locale/time_put/put/wchar_t/3.cc: Likewise.
2343 * testsuite/22_locale/time_put/put/wchar_t/4.cc: Likewise.
2344 * testsuite/22_locale/time_put/put/wchar_t/5.cc: Likewise.
2345 * testsuite/22_locale/time_put/put/wchar_t/6.cc: Likewise.
2346 * testsuite/22_locale/time_put/put/wchar_t/7.cc: Likewise.
2347 * testsuite/22_locale/time_put/put/wchar_t/8.cc: Likewise.
2348 * testsuite/22_locale/time_put/put/wchar_t/9.cc: Likewise.
2349 * testsuite/22_locale/time_put/put/wchar_t/17038.cc: Likewise.
2350 * testsuite/22_locale/time_put/put/char/10.cc: Likewise.
2351 * testsuite/22_locale/time_put/put/char/1.cc: Likewise.
2352 * testsuite/22_locale/time_put/put/char/2.cc: Likewise.
2353 * testsuite/22_locale/time_put/put/char/3.cc: Likewise.
2354 * testsuite/22_locale/time_put/put/char/4.cc: Likewise.
2355 * testsuite/22_locale/time_put/put/char/5.cc: Likewise.
2356 * testsuite/22_locale/time_put/put/char/6.cc: Likewise.
2357 * testsuite/22_locale/time_put/put/char/7.cc: Likewise.
2358 * testsuite/22_locale/time_put/put/char/8.cc: Likewise.
2359 * testsuite/22_locale/time_put/put/char/9.cc: Likewise.
2360 * testsuite/22_locale/time_put/put/char/17038.cc: Likewise.
2361 * testsuite/22_locale/time_get/get_year/wchar_t/1.cc: Likewise.
2362 * testsuite/22_locale/time_get/get_year/wchar_t/3.cc: Likewise.
2363 * testsuite/22_locale/time_get/get_year/char/1.cc: Likewise.
2364 * testsuite/22_locale/time_get/get_year/char/3.cc: Likewise.
2365 * testsuite/22_locale/time_get/get_monthname/wchar_t/1.cc: Likewise.
2366 * testsuite/22_locale/time_get/get_monthname/wchar_t/2.cc: Likewise.
2367 * testsuite/22_locale/time_get/get_monthname/char/1.cc: Likewise.
2368 * testsuite/22_locale/time_get/get_monthname/char/2.cc: Likewise.
2369 * testsuite/22_locale/time_get/get_weekday/wchar_t/1.cc: Likewise.
2370 * testsuite/22_locale/time_get/get_weekday/wchar_t/2.cc: Likewise.
2371 * testsuite/22_locale/time_get/get_weekday/wchar_t/3.cc: Likewise.
2372 * testsuite/22_locale/time_get/get_weekday/char/1.cc: Likewise.
2373 * testsuite/22_locale/time_get/get_weekday/char/2.cc: Likewise.
2374 * testsuite/22_locale/time_get/get_weekday/char/3.cc: Likewise.
2375 * testsuite/22_locale/time_get/get_date/wchar_t/12750.cc: Likewise.
2376 * testsuite/22_locale/time_get/get_date/wchar_t/12750.cc: Likewise.
2377 * testsuite/22_locale/time_get/get_date/wchar_t/1.cc: Likewise.
2378 * testsuite/22_locale/time_get/get_date/wchar_t/2.cc: Likewise.
2379 * testsuite/22_locale/time_get/get_date/wchar_t/3.cc: Likewise.
2380 * testsuite/22_locale/time_get/get_date/char/12750.cc: Likewise.
2381 * testsuite/22_locale/time_get/get_date/char/12750.cc: Likewise.
2382 * testsuite/22_locale/time_get/get_date/char/1.cc: Likewise.
2383 * testsuite/22_locale/time_get/get_date/char/2.cc: Likewise.
2384 * testsuite/22_locale/time_get/get_date/char/3.cc: Likewise.
2385 * testsuite/22_locale/time_get/get_time/wchar_t/1.cc: Likewise.
2386 * testsuite/22_locale/time_get/get_time/wchar_t/2.cc: Likewise.
2387 * testsuite/22_locale/time_get/get_time/wchar_t/3.cc: Likewise.
2388 * testsuite/22_locale/time_get/get_time/wchar_t/4.cc: Likewise.
2389 * testsuite/22_locale/time_get/get_time/char/1.cc: Likewise.
2390 * testsuite/22_locale/time_get/get_time/char/2.cc: Likewise.
2391 * testsuite/22_locale/time_get/get_time/char/3.cc: Likewise.
2392 * testsuite/22_locale/time_get/get_time/char/4.cc: Likewise.
2393
2394 2006-01-04 Paolo Carlini <pcarlini@suse.de>
2395
2396 * include/ext/sso_string_base.h (__sso_string_base<>::_M_dataplus):
2397 Use _CharT_alloc_type as base class.
2398 (_M_get_allocator, _M_swap, _M_create, _M_destroy): Adjust.
2399 * include/ext/vstring.h (get_allocator): Tidy.
2400
2401 2006-01-04 Paolo Carlini <pcarlini@suse.de>
2402
2403 Implement Option 3 of DR 431 for all the containers.
2404 * include/bits/allocator.h (struct __alloc_swap): Add, swaps
2405 allocators, optimized to nothing in case they are empty.
2406 * include/bits/stl_deque.h (deque<>::swap): Use it.
2407 * include/bits/stl_list.h (list<>::swap): Likewise.
2408 * include/bits/stl_tree.h (_Rb_tree<>::swap): Likewise.
2409 * include/bits/stl_vector.h (vector<>::swap): Likewise.
2410 * include/tr1/hashtable (hashtable<>::swap): Likewise.
2411 * include/ext/rc_string_base.h (__rc_string_base<>::_M_swap):
2412 Likewise.
2413 * include/ext/sso_string_base.h (__sso_string_base<>::_M_swap):
2414 Likewise.
2415 * include/ext/vstring_util.h (__vstring_utility<>::_Alloc_hider):
2416 Clean-up (now vstring uses the generic __alloc_swap facility).
2417 * include/tr1/unordered_map: Adjust includes.
2418 * include/tr1/unordered_set: Likewise.
2419 * docs/html/ext/howto.html: Add an entry for DR 431.
2420 * testsuite/23_containers/deque/modifiers/swap.cc: Move to...
2421 * testsuite/23_containers/deque/modifiers/swap/1.cc: ... here.
2422 * testsuite/23_containers/deque/modifiers/swap/2.cc: New.
2423 * testsuite/23_containers/deque/modifiers/swap/3.cc: New.
2424 * testsuite/23_containers/list/modifiers/swap.cc: Move to...
2425 * testsuite/23_containers/list/modifiers/swap/1.cc: ... here.
2426 * testsuite/23_containers/list/modifiers/swap/2.cc: New.
2427 * testsuite/23_containers/list/modifiers/swap/3.cc: New.
2428 * testsuite/23_containers/vector/modifiers/swap.cc: Move to...
2429 * testsuite/23_containers/vector/modifiers/swap/1.cc: ... here.
2430 * testsuite/23_containers/vector/modifiers/swap/2.cc: New.
2431 * testsuite/23_containers/vector/modifiers/swap/3.cc: New.
2432 * testsuite/23_containers/set/modifiers/swap.cc: Move to...
2433 * testsuite/23_containers/set/modifiers/swap/1.cc: ... here.
2434 * testsuite/23_containers/set/modifiers/swap/2.cc: New.
2435 * testsuite/23_containers/set/modifiers/swap/3.cc: New.
2436 * testsuite/23_containers/map/modifiers/swap.cc: Move to...
2437 * testsuite/23_containers/map/modifiers/swap/1.cc: ... here.
2438 * testsuite/23_containers/map/modifiers/swap/2.cc: New.
2439 * testsuite/23_containers/map/modifiers/swap/3.cc: New.
2440 * testsuite/23_containers/multiset/modifiers/swap.cc: Move to...
2441 * testsuite/23_containers/multiset/modifiers/swap/1.cc: ... here.
2442 * testsuite/23_containers/multiset/modifiers/swap/2.cc: New.
2443 * testsuite/23_containers/multiset/modifiers/swap/3.cc: New.
2444 * testsuite/23_containers/multimap/modifiers/swap.cc: Move to...
2445 * testsuite/23_containers/multimap/modifiers/swap/1.cc: ... here.
2446 * testsuite/23_containers/multimap/modifiers/swap/2.cc: New.
2447 * testsuite/23_containers/multimap/modifiers/swap/3.cc: New.
2448 * testsuite/tr1/6_containers/unordered/swap/unordered_set/1.cc: New.
2449 * testsuite/tr1/6_containers/unordered/swap/unordered_set/2.cc: New.
2450 * testsuite/tr1/6_containers/unordered/swap/unordered_map/1.cc: New.
2451 * testsuite/tr1/6_containers/unordered/swap/unordered_map/2.cc: New.
2452 * testsuite/tr1/6_containers/unordered/swap/unordered_multiset/1.cc: New.
2453 * testsuite/tr1/6_containers/unordered/swap/unordered_multiset/2.cc: New.
2454 * testsuite/tr1/6_containers/unordered/swap/unordered_multimap/1.cc: New.
2455 * testsuite/tr1/6_containers/unordered/swap/unordered_multimap/2.cc: New.
2456
2457 2006-01-03 Paolo Carlini <pcarlini@suse.de>
2458
2459 * include/bits/stl_list.h (_List_base<>::_M_get_Node_allocator): Add.
2460 (_M_get_Tp_allocator, get_allocator): Tidy.
2461 (list<>::list(const list&), insert(iterator, size_type, const
2462 value_type&), insert(iterator, _InputIterator, _InputIterator)):
2463 Use _M_get_Node_allocator.
2464 * include/bits/stl_tree.h (_Rb_tree<>::_M_get_Node_allocator()): Add.
2465 (_Rb_tree(const _Rb_tree<>&): Use it.
2466 * include/bits/stl_deque.h (_Deque_base<>::_M_get_map_allocator,
2467 get_allocator): Tidy.
2468 * include/bits/stl_vector.h (_Vector_base<>::get_allocator): Tidy.
2469 * testsuite/23_containers/map/operators/1_neg.cc: Adjust dg-error
2470 line numbers.
2471 * testsuite/23_containers/set/operators/1_neg.cc: Likewise.
2472
2473 * testsuite/testsuite_allocator.h (uneq_allocator<>::swap): Fix.
2474
2475 * testsuite/testsuite_allocator.h (class uneq_allocator): A simple
2476 non-empty testing allocator which can be endowed of a "personality"
2477 at construction time.
2478
2479 2006-01-03 Paolo Carlini <pcarlini@suse.de>
2480
2481 * testsuite/27_io/basic_stringstream/str/char/1.cc: Initialize vars.
2482 * testsuite/27_io/basic_stringstream/str/wchar_t/1.cc: Likewise.
2483 * testsuite/27_io/basic_istringstream/str/char/1.cc: Likewise, tidy.
2484 * testsuite/27_io/basic_istringstream/str/wchar_t/1.cc: Likewise.
2485
2486 2006-01-02 Mark Mitchell <mark@codesourcery.com>
2487
2488 * src/Makefile.am (LTLDFLAGS): New variable.
2489 (CXXLINK): Use LTLDFLAGS.
2490 * src/Makefile.in: Regenerated.
2491 * libsupc++/Makefile.am (LTLDFLAGS): New variable.
2492 (CXXLINK): Use LTLDFLAGS.
2493 * libsupc++/Makefile.in: Regenerated.
2494
2495 2006-01-02 Paolo Carlini <pcarlini@suse.de>
2496
2497 PR libstdc++/24645
2498 * include/std/std_istream.h (basic_istream<>::_M_extract): New.
2499 (operator>>(bool&), operator>>(short&), operator>>(unsigned short&),
2500 operator>>(int&), operator>>(unsigned int&), operator>>(long&),
2501 operator>>(unsigned long&), operator>>(long long&), operator>>
2502 (unsigned long long&), operator>>(float&), operator>>(double&),
2503 operator>>(long double&), operator>>(void*&)): Use it.
2504 * include/bits/istream.tcc (basic_istream<>::_M_extract): Define.
2505 * include/std/std_ostream.h (basic_ostream<>::_M_insert): New.
2506 (operator<<(long), operator<<(unsigned long), operator<<(bool),
2507 operator<<(short), operator<<(unsigned short), operator<<(int),
2508 operator<<(unsigned int), operator<<(long long), operator<<
2509 (unsigned long long), operator<<(double), operator<<(float),
2510 operator<<(long double), operator<<(const void*): Use it.
2511 * include/bits/ostream.tcc (basic_ostream<>::_M_insert): Define.
2512 * src/istream-inst.cc: Add _M_extract instantiations.
2513 * src/ostream-inst.cc: Add _M_insert instantiations.
2514 * config/abi/pre/gnu.ver: Export the new symbols @GLIBCXX_3.4.7;
2515 detail existing @GLIBCXX_3.4 exports of basic_ostream, num_put,
2516 money_put, etc., symbols to avoid exporting _M_insert symbols
2517 @GLIBCXX_3.4.