3 // Copyright (C) 2005, 2006 Free Software Foundation, Inc.
5 // This file is part of the GNU ISO C++ Library. This library is free
6 // software; you can redistribute it and/or modify it under the terms
7 // of the GNU General Public License as published by the Free Software
8 // Foundation; either version 2, or (at your option) any later
11 // This library is distributed in the hope that it will be useful, but
12 // WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // General Public License for more details.
16 // You should have received a copy of the GNU General Public License
17 // along with this library; see the file COPYING. If not, write to
18 // the Free Software Foundation, 59 Temple Place - Suite 330, Boston,
19 // MA 02111-1307, USA.
21 // As a special exception, you may use this file as part of a free
22 // software library without restriction. Specifically, if other files
23 // instantiate templates or use macros or inline functions from this
24 // file, or you compile this file and link it with other files to
25 // produce an executable, this file does not by itself cause the
26 // resulting executable to be covered by the GNU General Public
27 // License. This exception does not however invalidate any other
28 // reasons why the executable file might be covered by the GNU General
31 // Copyright (C) 2004 Ami Tavory and Vladimir Dreizin, IBM-HRL.
33 // Permission to use, copy, modify, sell, and distribute this software
34 // is hereby granted without fee, provided that the above copyright
35 // notice appears in all copies, and that both that copyright notice
36 // and this permission notice appear in supporting documentation. None
37 // of the above authors, nor IBM Haifa Research Laboratories, make any
38 // representation about the suitability of this software for any
39 // purpose. It is provided "as is" without express or implied
44 * Containsert traits for a random regression test
45 * for a specific container type.
48 #ifndef PB_DS_REGRESSION_TEST_TRAIT_HPP
49 #define PB_DS_REGRESSION_TEST_TRAIT_HPP
51 #include <regression/trait/assoc/to_string.hpp>
52 #include <regression/trait/assoc/type_trait.hpp>
53 #include <regression/trait/assoc/native_type_trait.hpp>
54 #include <regression/trait/assoc/resize_trait.hpp>
55 #include <regression/trait/assoc/get_set_loads_trait.hpp>
56 #include <regression/trait/assoc/get_set_load_trait.hpp>
57 #include <regression/trait/assoc/node_update_trait.hpp>
58 #include <regression/trait/erase_if_fn.hpp>
69 #define PB_DS_CLASS_T_DEC \
70 template<typename Cntnr>
72 #define PB_DS_CLASS_C_DEC \
73 regression_test_traits< \
76 #define PB_DS_TYPE_TRAITS_C_DEC \
77 regression_test_type_traits< \
80 #define PB_DS_NATIVE_TYPE_TRAITS_C_DEC \
82 typename PB_DS_TYPE_TRAITS_C_DEC::key_type, \
83 typename PB_DS_TYPE_TRAITS_C_DEC::mapped_type, \
84 typename Cntnr::allocator>
86 #define PB_DS_RESIZE_TRAITS_C_DEC \
87 regression_test_resize_traits< \
89 typename Cntnr::container_category>
91 #define PB_DS_SET_LOADS_TRAITS_C_DEC \
92 regression_test_get_set_loacontainer_traits< \
94 typename Cntnr::container_category>
96 #define PB_DS_SET_LOAD_TRAITS_C_DEC \
97 regression_test_get_set_load_traits< \
99 typename Cntnr::container_category>
101 #define PB_DS_NODE_UPDATOR_TRAITS_C_DEC \
102 regression_test_node_update_traits< \
104 typename Cntnr::container_category>
106 template<typename Cntnr>
107 struct regression_test_traits : private PB_DS_TYPE_TRAITS_C_DEC,
108 private PB_DS_NATIVE_TYPE_TRAITS_C_DEC,
109 private PB_DS_RESIZE_TRAITS_C_DEC,
110 private PB_DS_NODE_UPDATOR_TRAITS_C_DEC,
111 private PB_DS_SET_LOADS_TRAITS_C_DEC,
112 private PB_DS_SET_LOAD_TRAITS_C_DEC
116 typedef PB_DS_NATIVE_TYPE_TRAITS_C_DEC native_type_traits_base;
118 typedef PB_DS_TYPE_TRAITS_C_DEC type_traits_base;
122 typedef typename Cntnr::key_type key_type;
124 typedef typename Cntnr::const_key_reference const_key_reference;
126 typedef typename Cntnr::value_type value_type;
128 typedef typename Cntnr::const_reference const_reference;
130 typedef typename PB_DS_NATIVE_TYPE_TRAITS_C_DEC::type native_type;
132 typedef typename native_type::key_type native_key_type;
134 typedef typename native_type::value_type native_value_type;
138 resize = PB_DS_RESIZE_TRAITS_C_DEC::value,
139 get_set_loads = PB_DS_SET_LOADS_TRAITS_C_DEC::value,
140 get_set_load = PB_DS_SET_LOAD_TRAITS_C_DEC::value,
142 PB_DS_NODE_UPDATOR_TRAITS_C_DEC::order_statistics,
144 PB_DS_NODE_UPDATOR_TRAITS_C_DEC::prefix_search
148 struct erase_if_fn : public regression_test_erase_if_fn<
155 erase_if(native_type& r_native_c)
158 regression_test_erase_if_fn<
159 typename native_type::value_type>
162 typename native_type::iterator it = r_native_c.begin();
166 while (it != r_native_c.end())
167 if (erase_if_fn()(*it))
171 r_native_c.erase(it);
173 it = r_native_c.begin();
182 print_container(const Cntnr& r_c, std::ostream& r_os)
184 PB_DS_TYPE_TRAITS_C_DEC::print_container(r_c, r_os);
189 template<typename Gen>
191 generate_key(Gen& r_gen, size_t max)
193 return (PB_DS_TYPE_TRAITS_C_DEC::generate_key(r_gen, max));
196 template<typename Gen>
198 generate_value(Gen& r_gen, size_t max)
200 return (PB_DS_TYPE_TRAITS_C_DEC::generate_value(r_gen, max));
203 static const_key_reference
204 extract_key(const_reference r_val)
206 return type_traits_base::extract_key(r_val);
209 static native_key_type
210 native_key(const_key_reference r_key)
212 return (native_type_traits_base::native_key(r_key));
215 static native_value_type
216 native_value(const_reference r_val)
218 return (native_type_traits_base::native_value(r_val));
221 static const native_key_type&
222 extract_native_key(const native_value_type& r_val)
224 return (native_type_traits_base::extract_key(r_val));
228 cmp(const_reference r_val, const native_value_type& r_native_val)
230 return (val_to_string(r_val) ==
231 native_val_to_string(r_native_val));
235 val_to_string(const_reference r_val)
237 return (to_string(r_val));
241 key_to_string(const_key_reference r_key)
243 return (to_string(r_key));
247 native_val_to_string(const native_value_type& r_native_val)
249 return (to_string(r_native_val));
253 prefix_match(const_key_reference r_key, const std::string& r_native_key)
255 const size_t native_substr_len = std::min(
257 r_native_key.length());
259 const std::string native_substr =
260 r_native_key.substr(0, native_substr_len);
262 return (native_substr == (const std::string& )r_key);
267 #undef PB_DS_TYPE_TRAITS_C_DEC
269 #undef PB_DS_NATIVE_TYPE_TRAITS_C_DEC
271 #undef PB_DS_RESIZE_TRAITS_C_DEC
273 #undef PB_DS_SET_LOADS_TRAITS_C_DEC
275 #undef PB_DS_SET_LOAD_TRAITS_C_DEC
277 #undef PB_DS_NODE_UPDATOR_TRAITS_C_DEC
279 #undef PB_DS_CLASS_T_DEC
281 #undef PB_DS_CLASS_C_DEC
283 } // namespace detail
289 #endif // #ifndef PB_DS_REGRESSION_TEST_TRAIT_HPP