1 // Queue implementation -*- C++ -*-
3 // Copyright (C) 2001, 2002, 2003, 2004 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
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 2, or (at your option)
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // You should have received a copy of the GNU General Public License along
17 // with this library; see the file COPYING. If not, write to the Free
18 // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
21 // As a special exception, you may use this file as part of a free software
22 // library without restriction. Specifically, if other files instantiate
23 // templates or use macros or inline functions from this file, or you compile
24 // this file and link it with other files to produce an executable, this
25 // file does not by itself cause the resulting executable to be covered by
26 // the GNU General Public License. This exception does not however
27 // invalidate any other reasons why the executable file might be covered by
28 // the GNU General Public License.
33 * Hewlett-Packard Company
35 * Permission to use, copy, modify, distribute and sell this software
36 * and its documentation for any purpose is hereby granted without fee,
37 * provided that the above copyright notice appear in all copies and
38 * that both that copyright notice and this permission notice appear
39 * in supporting documentation. Hewlett-Packard Company makes no
40 * representations about the suitability of this software for any
41 * purpose. It is provided "as is" without express or implied warranty.
44 * Copyright (c) 1996,1997
45 * Silicon Graphics Computer Systems, Inc.
47 * Permission to use, copy, modify, distribute and sell this software
48 * and its documentation for any purpose is hereby granted without fee,
49 * provided that the above copyright notice appear in all copies and
50 * that both that copyright notice and this permission notice appear
51 * in supporting documentation. Silicon Graphics makes no
52 * representations about the suitability of this software for any
53 * purpose. It is provided "as is" without express or implied warranty.
57 * This is an internal header file, included by other library headers.
58 * You should not attempt to use it directly.
64 #include <bits/concept_check.h>
65 #include <debug/debug.h>
69 // Forward declarations of operators < and ==, needed for friend declaration.
70 template<typename _Tp
, typename _Sequence
= deque
<_Tp
> >
73 template<typename _Tp
, typename _Seq
>
75 operator==(const queue
<_Tp
,_Seq
>&, const queue
<_Tp
,_Seq
>&);
77 template<typename _Tp
, typename _Seq
>
79 operator<(const queue
<_Tp
,_Seq
>&, const queue
<_Tp
,_Seq
>&);
82 * @brief A standard container giving FIFO behavior.
87 * Meets many of the requirements of a
88 * <a href="tables.html#65">container</a>,
89 * but does not define anything to do with iterators. Very few of the
90 * other standard container interfaces are defined.
92 * This is not a true container, but an @e adaptor. It holds another
93 * container, and provides a wrapper interface to that container. The
94 * wrapper is what enforces strict first-in-first-out %queue behavior.
96 * The second template parameter defines the type of the underlying
97 * sequence/container. It defaults to std::deque, but it can be any type
98 * that supports @c front, @c back, @c push_back, and @c pop_front,
99 * such as std::list or an appropriate user-defined type.
101 * Members not found in "normal" containers are @c container_type,
102 * which is a typedef for the second Sequence parameter, and @c push and
103 * @c pop, which are standard %queue/FIFO operations.
105 template<typename _Tp
, typename _Sequence
>
108 // concept requirements
109 typedef typename
_Sequence::value_type _Sequence_value_type
;
110 __glibcxx_class_requires(_Tp
, _SGIAssignableConcept
)
111 __glibcxx_class_requires(_Sequence
, _FrontInsertionSequenceConcept
)
112 __glibcxx_class_requires(_Sequence
, _BackInsertionSequenceConcept
)
113 __glibcxx_class_requires2(_Tp
, _Sequence_value_type
, _SameTypeConcept
)
115 template<typename _Tp1
, typename _Seq1
>
117 operator==(const queue
<_Tp1
, _Seq1
>&, const queue
<_Tp1
, _Seq1
>&);
119 template<typename _Tp1
, typename _Seq1
>
121 operator<(const queue
<_Tp1
, _Seq1
>&, const queue
<_Tp1
, _Seq1
>&);
124 typedef typename
_Sequence::value_type value_type
;
125 typedef typename
_Sequence::reference reference
;
126 typedef typename
_Sequence::const_reference const_reference
;
127 typedef typename
_Sequence::size_type size_type
;
128 typedef _Sequence container_type
;
132 * 'c' is the underlying container. Maintainers wondering why
133 * this isn't uglified as per style guidelines should note that
134 * this name is specified in the standard, [23.2.3.1]. (Why?
135 * Presumably for the same reason that it's protected instead
136 * of private: to allow derivation. But none of the other
137 * containers allow for derivation. Odd.)
143 * @brief Default constructor creates no elements.
146 queue(const _Sequence
& __c
= _Sequence()) : c(__c
) {}
149 * Returns true if the %queue is empty.
153 { return c
.empty(); }
155 /** Returns the number of elements in the %queue. */
161 * Returns a read/write reference to the data at the first
162 * element of the %queue.
167 __glibcxx_requires_nonempty();
172 * Returns a read-only (constant) reference to the data at the first
173 * element of the %queue.
178 __glibcxx_requires_nonempty();
183 * Returns a read/write reference to the data at the last
184 * element of the %queue.
189 __glibcxx_requires_nonempty();
194 * Returns a read-only (constant) reference to the data at the last
195 * element of the %queue.
200 __glibcxx_requires_nonempty();
205 * @brief Add data to the end of the %queue.
206 * @param x Data to be added.
208 * This is a typical %queue operation. The function creates an
209 * element at the end of the %queue and assigns the given data
210 * to it. The time complexity of the operation depends on the
211 * underlying sequence.
214 push(const value_type
& __x
)
215 { c
.push_back(__x
); }
218 * @brief Removes first element.
220 * This is a typical %queue operation. It shrinks the %queue by one.
221 * The time complexity of the operation depends on the underlying
224 * Note that no data is returned, and if the first element's
225 * data is needed, it should be retrieved before pop() is
231 __glibcxx_requires_nonempty();
238 * @brief Queue equality comparison.
240 * @param y A %queue of the same type as @a x.
241 * @return True iff the size and elements of the queues are equal.
243 * This is an equivalence relation. Complexity and semantics depend on the
244 * underlying sequence type, but the expected rules are: this relation is
245 * linear in the size of the sequences, and queues are considered equivalent
246 * if their sequences compare equal.
248 template<typename _Tp
, typename _Sequence
>
250 operator==(const queue
<_Tp
,_Sequence
>& __x
,
251 const queue
<_Tp
,_Sequence
>& __y
)
252 { return __x
.c
== __y
.c
; }
255 * @brief Queue ordering relation.
257 * @param y A %queue of the same type as @a x.
258 * @return True iff @a x is lexicographically less than @a y.
260 * This is an total ordering relation. Complexity and semantics
261 * depend on the underlying sequence type, but the expected rules
262 * are: this relation is linear in the size of the sequences, the
263 * elements must be comparable with @c <, and
264 * std::lexicographical_compare() is usually used to make the
267 template<typename _Tp
, typename _Sequence
>
269 operator<(const queue
<_Tp
,_Sequence
>& __x
, const queue
<_Tp
,_Sequence
>& __y
)
270 { return __x
.c
< __y
.c
; }
272 /// Based on operator==
273 template<typename _Tp
, typename _Sequence
>
275 operator!=(const queue
<_Tp
,_Sequence
>& __x
,
276 const queue
<_Tp
,_Sequence
>& __y
)
277 { return !(__x
== __y
); }
279 /// Based on operator<
280 template<typename _Tp
, typename _Sequence
>
282 operator>(const queue
<_Tp
,_Sequence
>& __x
, const queue
<_Tp
,_Sequence
>& __y
)
283 { return __y
< __x
; }
285 /// Based on operator<
286 template<typename _Tp
, typename _Sequence
>
288 operator<=(const queue
<_Tp
,_Sequence
>& __x
,
289 const queue
<_Tp
,_Sequence
>& __y
)
290 { return !(__y
< __x
); }
292 /// Based on operator<
293 template<typename _Tp
, typename _Sequence
>
295 operator>=(const queue
<_Tp
,_Sequence
>& __x
,
296 const queue
<_Tp
,_Sequence
>& __y
)
297 { return !(__x
< __y
); }
300 * @brief A standard container automatically sorting its contents.
302 * @ingroup Containers
305 * This is not a true container, but an @e adaptor. It holds
306 * another container, and provides a wrapper interface to that
307 * container. The wrapper is what enforces priority-based sorting
308 * and %queue behavior. Very few of the standard container/sequence
309 * interface requirements are met (e.g., iterators).
311 * The second template parameter defines the type of the underlying
312 * sequence/container. It defaults to std::vector, but it can be
313 * any type that supports @c front(), @c push_back, @c pop_back,
314 * and random-access iterators, such as std::deque or an
315 * appropriate user-defined type.
317 * The third template parameter supplies the means of making
318 * priority comparisons. It defaults to @c less<value_type> but
319 * can be anything defining a strict weak ordering.
321 * Members not found in "normal" containers are @c container_type,
322 * which is a typedef for the second Sequence parameter, and @c
323 * push, @c pop, and @c top, which are standard %queue operations.
325 * @note No equality/comparison operators are provided for
328 * @note Sorting of the elements takes place as they are added to,
329 * and removed from, the %priority_queue using the
330 * %priority_queue's member functions. If you access the elements
331 * by other means, and change their data such that the sorting
332 * order would be different, the %priority_queue will not re-sort
333 * the elements for you. (How could it know to do so?)
335 template<typename _Tp
, typename _Sequence
= vector
<_Tp
>,
336 typename _Compare
= less
<typename
_Sequence::value_type
> >
339 // concept requirements
340 typedef typename
_Sequence::value_type _Sequence_value_type
;
341 __glibcxx_class_requires(_Tp
, _SGIAssignableConcept
)
342 __glibcxx_class_requires(_Sequence
, _SequenceConcept
)
343 __glibcxx_class_requires(_Sequence
, _RandomAccessContainerConcept
)
344 __glibcxx_class_requires2(_Tp
, _Sequence_value_type
, _SameTypeConcept
)
345 __glibcxx_class_requires4(_Compare
, bool, _Tp
,_Tp
,_BinaryFunctionConcept
)
348 typedef typename
_Sequence::value_type value_type
;
349 typedef typename
_Sequence::reference reference
;
350 typedef typename
_Sequence::const_reference const_reference
;
351 typedef typename
_Sequence::size_type size_type
;
352 typedef _Sequence container_type
;
355 // See queue::c for notes on these names.
361 * @brief Default constructor creates no elements.
364 priority_queue(const _Compare
& __x
= _Compare(),
365 const _Sequence
& __s
= _Sequence())
367 { std::make_heap(c
.begin(), c
.end(), comp
); }
370 * @brief Builds a %queue from a range.
371 * @param first An input iterator.
372 * @param last An input iterator.
373 * @param x A comparison functor describing a strict weak ordering.
374 * @param s An initial sequence with which to start.
376 * Begins by copying @a s, inserting a copy of the elements
377 * from @a [first,last) into the copy of @a s, then ordering
378 * the copy according to @a x.
380 * For more information on function objects, see the
381 * documentation on @link s20_3_1_base functor base
384 template<typename _InputIterator
>
385 priority_queue(_InputIterator __first
, _InputIterator __last
,
386 const _Compare
& __x
= _Compare(),
387 const _Sequence
& __s
= _Sequence())
390 __glibcxx_requires_valid_range(__first
, __last
);
391 c
.insert(c
.end(), __first
, __last
);
392 std::make_heap(c
.begin(), c
.end(), comp
);
396 * Returns true if the %queue is empty.
399 empty() const { return c
.empty(); }
401 /** Returns the number of elements in the %queue. */
403 size() const { return c
.size(); }
406 * Returns a read-only (constant) reference to the data at the first
407 * element of the %queue.
412 __glibcxx_requires_nonempty();
417 * @brief Add data to the %queue.
418 * @param x Data to be added.
420 * This is a typical %queue operation.
421 * The time complexity of the operation depends on the underlying
425 push(const value_type
& __x
)
430 std::push_heap(c
.begin(), c
.end(), comp
);
435 __throw_exception_again
;
440 * @brief Removes first element.
442 * This is a typical %queue operation. It shrinks the %queue
443 * by one. The time complexity of the operation depends on the
444 * underlying sequence.
446 * Note that no data is returned, and if the first element's
447 * data is needed, it should be retrieved before pop() is
453 __glibcxx_requires_nonempty();
456 std::pop_heap(c
.begin(), c
.end(), comp
);
462 __throw_exception_again
;
467 // No equality/comparison operators are provided for priority_queue.
470 #endif /* _QUEUE_H */