Remove old autovect-branch by moving to "dead" directory.
[official-gcc.git] / old-autovect-branch / libstdc++-v3 / testsuite / testsuite_allocator.h
blob307a0384dc5e36404b51b34979cb4a5ade560b63
1 // -*- C++ -*-
2 // Testing allocator for the C++ library testsuite.
3 //
4 // Copyright (C) 2002, 2003, 2004, 2005 Free Software Foundation, Inc.
5 //
6 // This file is part of the GNU ISO C++ Library. This library is free
7 // software; you can redistribute it and/or modify it under the
8 // terms of the GNU General Public License as published by the
9 // Free Software Foundation; either version 2, or (at your option)
10 // any later version.
12 // This library is distributed in the hope that it will be useful,
13 // but WITHOUT ANY WARRANTY; without even the implied warranty of
14 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 // GNU General Public License for more details.
17 // You should have received a copy of the GNU General Public License along
18 // with this library; see the file COPYING. If not, write to the Free
19 // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
20 // USA.
22 // As a special exception, you may use this file as part of a free software
23 // library without restriction. Specifically, if other files instantiate
24 // templates or use macros or inline functions from this file, or you compile
25 // this file and link it with other files to produce an executable, this
26 // file does not by itself cause the resulting executable to be covered by
27 // the GNU General Public License. This exception does not however
28 // invalidate any other reasons why the executable file might be covered by
29 // the GNU General Public License.
31 // This file provides an test instrumentation allocator that can be
32 // used to verify allocation functionality of standard library
33 // containers. 2002.11.25 smw
35 #ifndef _GLIBCXX_TESTSUITE_ALLOCATOR_H
36 #define _GLIBCXX_TESTSUITE_ALLOCATOR_H
38 #include <cstddef>
39 #include <limits>
41 namespace
43 bool new_called = false;
44 bool delete_called = false;
47 namespace __gnu_test
49 class allocation_tracker
51 public:
52 typedef std::size_t size_type;
54 static void*
55 allocate(size_type blocksize)
57 allocationTotal_ += blocksize;
58 return ::operator new(blocksize);
61 static void
62 construct() { constructCount_++; }
64 static void
65 destroy() { destructCount_++; }
67 static void
68 deallocate(void* p, size_type blocksize)
70 ::operator delete(p);
71 deallocationTotal_ += blocksize;
74 static size_type
75 allocationTotal() { return allocationTotal_; }
77 static size_type
78 deallocationTotal() { return deallocationTotal_; }
80 static int
81 constructCount() { return constructCount_; }
83 static int
84 destructCount() { return destructCount_; }
86 static void
87 resetCounts()
89 allocationTotal_ = 0;
90 deallocationTotal_ = 0;
91 constructCount_ = 0;
92 destructCount_ = 0;
95 private:
96 static size_type allocationTotal_;
97 static size_type deallocationTotal_;
98 static int constructCount_;
99 static int destructCount_;
102 // A simple basic allocator that just forwards to the
103 // allocation_tracker to fulfill memory requests. This class is
104 // templated on the target object type, but tracker isn't.
105 template<class T>
106 class tracker_alloc
108 public:
109 typedef T value_type;
110 typedef T* pointer;
111 typedef const T* const_pointer;
112 typedef T& reference;
113 typedef const T& const_reference;
114 typedef std::size_t size_type;
115 typedef std::ptrdiff_t difference_type;
117 template<class U> struct rebind { typedef tracker_alloc<U> other; };
119 pointer
120 address(reference value) const
121 { return &value; }
123 const_pointer
124 address(const_reference value) const
125 { return &value; }
127 tracker_alloc() throw()
130 tracker_alloc(const tracker_alloc&) throw()
133 template<class U>
134 tracker_alloc(const tracker_alloc<U>&) throw()
137 ~tracker_alloc() throw()
140 size_type
141 max_size() const throw()
142 { return std::numeric_limits<std::size_t>::max() / sizeof(T); }
144 pointer
145 allocate(size_type n, const void* = 0)
147 return static_cast<pointer>(allocation_tracker::allocate(n * sizeof(T)));
150 void
151 construct(pointer p, const T& value)
153 new (p) T(value);
154 allocation_tracker::construct();
157 void
158 destroy(pointer p)
160 p->~T();
161 allocation_tracker::destroy();
164 void
165 deallocate(pointer p, size_type num)
166 { allocation_tracker::deallocate(p, num * sizeof(T)); }
169 template<class T1, class T2>
170 bool
171 operator==(const tracker_alloc<T1>&, const tracker_alloc<T2>&) throw()
172 { return true; }
174 template<class T1, class T2>
175 bool
176 operator!=(const tracker_alloc<T1>&, const tracker_alloc<T2>&) throw()
177 { return false; }
179 bool
180 check_construct_destroy(const char* tag, int expected_c, int expected_d);
182 template<typename Alloc, bool uses_global_new>
183 bool
184 check_new(Alloc a = Alloc())
186 bool test __attribute__((unused)) = true;
187 typename Alloc::pointer p = a.allocate(10);
188 test &= ( new_called == uses_global_new );
189 return test;
192 template<typename Alloc, bool uses_global_delete>
193 bool
194 check_delete(Alloc a = Alloc())
196 bool test __attribute__((unused)) = true;
197 typename Alloc::pointer p = a.allocate(10);
198 a.deallocate(p, 10);
199 test &= ( delete_called == uses_global_delete );
200 return test;
203 template<typename Alloc>
204 bool
205 check_deallocate_null()
207 // Let's not core here...
208 Alloc a;
209 a.deallocate(NULL, 1);
210 a.deallocate(NULL, 10);
213 template<typename Alloc>
214 bool
215 check_allocate_max_size()
217 Alloc a;
220 a.allocate(a.max_size() + 1);
222 catch(std::bad_alloc&)
224 return true;
226 catch(...)
228 throw;
230 throw;
233 template<typename Tp>
234 class throw_allocator
236 public:
237 typedef std::size_t size_type;
238 typedef std::ptrdiff_t difference_type;
239 typedef Tp* pointer;
240 typedef const Tp* const_pointer;
241 typedef Tp& reference;
242 typedef const Tp& const_reference;
243 typedef Tp value_type;
245 template<typename Tp1>
246 struct rebind
247 { typedef throw_allocator<Tp1> other; };
249 throw_allocator() throw()
250 : count(size_type(-1)) { }
252 throw_allocator(size_type c) throw()
253 : count(c) { }
255 template<typename Tp1>
256 throw_allocator(const throw_allocator<Tp1>& b) throw()
257 : count(b.get_count()) { }
259 size_type get_count() const { return count; }
261 pointer
262 address(reference x) const { return &x; }
264 const_pointer
265 address(const_reference x) const { return &x; }
267 pointer
268 allocate(size_type n, const void* = 0)
270 if (count == 0)
271 throw std::bad_alloc();
273 if (count != size_type(-1))
274 --count;
276 return static_cast<Tp*>(::operator new(n * sizeof(Tp)));
279 void
280 deallocate(pointer p, size_type)
281 { ::operator delete(p); }
283 size_type
284 max_size() const throw()
285 { return size_type(-1) / sizeof(Tp); }
287 void
288 construct(pointer p, const Tp& val)
289 { ::new(p) Tp(val); }
291 void
292 destroy(pointer p) { p->~Tp(); }
294 private:
295 template<typename Tp1>
296 friend inline bool
297 operator==(const throw_allocator&, const throw_allocator<Tp1>&)
298 { return true; }
300 template<typename Tp1>
301 friend inline bool
302 operator!=(const throw_allocator&, const throw_allocator<Tp1>&)
303 { return false; }
305 size_type count;
307 }; // namespace __gnu_test
309 #endif // _GLIBCXX_TESTSUITE_ALLOCATOR_H