1 // Queue implementation -*- C++ -*-
3 // Copyright (C) 2001-2013 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 3, 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 // Under Section 7 of GPL version 3, you are granted additional
17 // permissions described in the GCC Runtime Library Exception, version
18 // 3.1, as published by the Free Software Foundation.
20 // You should have received a copy of the GNU General Public License and
21 // a copy of the GCC Runtime Library Exception along with this program;
22 // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
23 // <http://www.gnu.org/licenses/>.
28 * Hewlett-Packard Company
30 * Permission to use, copy, modify, distribute and sell this software
31 * and its documentation for any purpose is hereby granted without fee,
32 * provided that the above copyright notice appear in all copies and
33 * that both that copyright notice and this permission notice appear
34 * in supporting documentation. Hewlett-Packard Company makes no
35 * representations about the suitability of this software for any
36 * purpose. It is provided "as is" without express or implied warranty.
39 * Copyright (c) 1996,1997
40 * Silicon Graphics Computer Systems, Inc.
42 * Permission to use, copy, modify, distribute and sell this software
43 * and its documentation for any purpose is hereby granted without fee,
44 * provided that the above copyright notice appear in all copies and
45 * that both that copyright notice and this permission notice appear
46 * in supporting documentation. Silicon Graphics makes no
47 * representations about the suitability of this software for any
48 * purpose. It is provided "as is" without express or implied warranty.
51 /** @file bits/stl_queue.h
52 * This is an internal header file, included by other library headers.
53 * Do not attempt to use it directly. @headername{queue}
57 #define _STL_QUEUE_H 1
59 #include <bits/concept_check.h>
60 #include <debug/debug.h>
62 namespace std _GLIBCXX_VISIBILITY(default)
64 _GLIBCXX_BEGIN_NAMESPACE_VERSION
67 * @brief A standard container giving FIFO behavior.
71 * @tparam _Tp Type of element.
72 * @tparam _Sequence Type of underlying sequence, defaults to deque<_Tp>.
74 * Meets many of the requirements of a
75 * <a href="tables.html#65">container</a>,
76 * but does not define anything to do with iterators. Very few of the
77 * other standard container interfaces are defined.
79 * This is not a true container, but an @e adaptor. It holds another
80 * container, and provides a wrapper interface to that container. The
81 * wrapper is what enforces strict first-in-first-out %queue behavior.
83 * The second template parameter defines the type of the underlying
84 * sequence/container. It defaults to std::deque, but it can be any type
85 * that supports @c front, @c back, @c push_back, and @c pop_front,
86 * such as std::list or an appropriate user-defined type.
88 * Members not found in @a normal containers are @c container_type,
89 * which is a typedef for the second Sequence parameter, and @c push and
90 * @c pop, which are standard %queue/FIFO operations.
92 template<typename _Tp, typename _Sequence = deque<_Tp> >
95 // concept requirements
96 typedef typename _Sequence::value_type _Sequence_value_type;
97 __glibcxx_class_requires(_Tp, _SGIAssignableConcept)
98 __glibcxx_class_requires(_Sequence, _FrontInsertionSequenceConcept)
99 __glibcxx_class_requires(_Sequence, _BackInsertionSequenceConcept)
100 __glibcxx_class_requires2(_Tp, _Sequence_value_type, _SameTypeConcept)
102 template<typename _Tp1, typename _Seq1>
104 operator==(const queue<_Tp1, _Seq1>&, const queue<_Tp1, _Seq1>&);
106 template<typename _Tp1, typename _Seq1>
108 operator<(const queue<_Tp1, _Seq1>&, const queue<_Tp1, _Seq1>&);
111 typedef typename _Sequence::value_type value_type;
112 typedef typename _Sequence::reference reference;
113 typedef typename _Sequence::const_reference const_reference;
114 typedef typename _Sequence::size_type size_type;
115 typedef _Sequence container_type;
119 * 'c' is the underlying container. Maintainers wondering why
120 * this isn't uglified as per style guidelines should note that
121 * this name is specified in the standard, [23.2.3.1]. (Why?
122 * Presumably for the same reason that it's protected instead
123 * of private: to allow derivation. But none of the other
124 * containers allow for derivation. Odd.)
130 * @brief Default constructor creates no elements.
132 #if __cplusplus < 201103L
134 queue(const _Sequence& __c = _Sequence())
138 queue(const _Sequence& __c)
142 queue(_Sequence&& __c = _Sequence())
143 : c(std::move(__c)) { }
147 * Returns true if the %queue is empty.
151 { return c.empty(); }
153 /** Returns the number of elements in the %queue. */
159 * Returns a read/write reference to the data at the first
160 * element of the %queue.
165 __glibcxx_requires_nonempty();
170 * Returns a read-only (constant) reference to the data at the first
171 * element of the %queue.
176 __glibcxx_requires_nonempty();
181 * Returns a read/write reference to the data at the last
182 * element of the %queue.
187 __glibcxx_requires_nonempty();
192 * Returns a read-only (constant) reference to the data at the last
193 * element of the %queue.
198 __glibcxx_requires_nonempty();
203 * @brief Add data to the end of the %queue.
204 * @param __x Data to be added.
206 * This is a typical %queue operation. The function creates an
207 * element at the end of the %queue and assigns the given data
208 * to it. The time complexity of the operation depends on the
209 * underlying sequence.
212 push(const value_type& __x)
213 { c.push_back(__x); }
215 #if __cplusplus >= 201103L
217 push(value_type&& __x)
218 { c.push_back(std::move(__x)); }
220 template<typename... _Args>
222 emplace(_Args&&... __args)
223 { c.emplace_back(std::forward<_Args>(__args)...); }
227 * @brief Removes first element.
229 * This is a typical %queue operation. It shrinks the %queue by one.
230 * The time complexity of the operation depends on the underlying
233 * Note that no data is returned, and if the first element's
234 * data is needed, it should be retrieved before pop() is
240 __glibcxx_requires_nonempty();
244 #if __cplusplus >= 201103L
247 noexcept(noexcept(swap(c, __q.c)))
256 * @brief Queue equality comparison.
257 * @param __x A %queue.
258 * @param __y A %queue of the same type as @a __x.
259 * @return True iff the size and elements of the queues are equal.
261 * This is an equivalence relation. Complexity and semantics depend on the
262 * underlying sequence type, but the expected rules are: this relation is
263 * linear in the size of the sequences, and queues are considered equivalent
264 * if their sequences compare equal.
266 template<typename _Tp, typename _Seq>
268 operator==(const queue<_Tp, _Seq>& __x, const queue<_Tp, _Seq>& __y)
269 { return __x.c == __y.c; }
272 * @brief Queue ordering relation.
273 * @param __x A %queue.
274 * @param __y A %queue of the same type as @a x.
275 * @return True iff @a __x is lexicographically less than @a __y.
277 * This is an total ordering relation. Complexity and semantics
278 * depend on the underlying sequence type, but the expected rules
279 * are: this relation is linear in the size of the sequences, the
280 * elements must be comparable with @c <, and
281 * std::lexicographical_compare() is usually used to make the
284 template<typename _Tp, typename _Seq>
286 operator<(const queue<_Tp, _Seq>& __x, const queue<_Tp, _Seq>& __y)
287 { return __x.c < __y.c; }
289 /// Based on operator==
290 template<typename _Tp, typename _Seq>
292 operator!=(const queue<_Tp, _Seq>& __x, const queue<_Tp, _Seq>& __y)
293 { return !(__x == __y); }
295 /// Based on operator<
296 template<typename _Tp, typename _Seq>
298 operator>(const queue<_Tp, _Seq>& __x, const queue<_Tp, _Seq>& __y)
299 { return __y < __x; }
301 /// Based on operator<
302 template<typename _Tp, typename _Seq>
304 operator<=(const queue<_Tp, _Seq>& __x, const queue<_Tp, _Seq>& __y)
305 { return !(__y < __x); }
307 /// Based on operator<
308 template<typename _Tp, typename _Seq>
310 operator>=(const queue<_Tp, _Seq>& __x, const queue<_Tp, _Seq>& __y)
311 { return !(__x < __y); }
313 #if __cplusplus >= 201103L
314 template<typename _Tp, typename _Seq>
316 swap(queue<_Tp, _Seq>& __x, queue<_Tp, _Seq>& __y)
317 noexcept(noexcept(__x.swap(__y)))
320 template<typename _Tp, typename _Seq, typename _Alloc>
321 struct uses_allocator<queue<_Tp, _Seq>, _Alloc>
322 : public uses_allocator<_Seq, _Alloc>::type { };
326 * @brief A standard container automatically sorting its contents.
330 * @tparam _Tp Type of element.
331 * @tparam _Sequence Type of underlying sequence, defaults to vector<_Tp>.
332 * @tparam _Compare Comparison function object type, defaults to
333 * less<_Sequence::value_type>.
335 * This is not a true container, but an @e adaptor. It holds
336 * another container, and provides a wrapper interface to that
337 * container. The wrapper is what enforces priority-based sorting
338 * and %queue behavior. Very few of the standard container/sequence
339 * interface requirements are met (e.g., iterators).
341 * The second template parameter defines the type of the underlying
342 * sequence/container. It defaults to std::vector, but it can be
343 * any type that supports @c front(), @c push_back, @c pop_back,
344 * and random-access iterators, such as std::deque or an
345 * appropriate user-defined type.
347 * The third template parameter supplies the means of making
348 * priority comparisons. It defaults to @c less<value_type> but
349 * can be anything defining a strict weak ordering.
351 * Members not found in @a normal containers are @c container_type,
352 * which is a typedef for the second Sequence parameter, and @c
353 * push, @c pop, and @c top, which are standard %queue operations.
355 * @note No equality/comparison operators are provided for
358 * @note Sorting of the elements takes place as they are added to,
359 * and removed from, the %priority_queue using the
360 * %priority_queue's member functions. If you access the elements
361 * by other means, and change their data such that the sorting
362 * order would be different, the %priority_queue will not re-sort
363 * the elements for you. (How could it know to do so?)
365 template<typename _Tp, typename _Sequence = vector<_Tp>,
366 typename _Compare = less<typename _Sequence::value_type> >
369 // concept requirements
370 typedef typename _Sequence::value_type _Sequence_value_type;
371 __glibcxx_class_requires(_Tp, _SGIAssignableConcept)
372 __glibcxx_class_requires(_Sequence, _SequenceConcept)
373 __glibcxx_class_requires(_Sequence, _RandomAccessContainerConcept)
374 __glibcxx_class_requires2(_Tp, _Sequence_value_type, _SameTypeConcept)
375 __glibcxx_class_requires4(_Compare, bool, _Tp, _Tp,
376 _BinaryFunctionConcept)
379 typedef typename _Sequence::value_type value_type;
380 typedef typename _Sequence::reference reference;
381 typedef typename _Sequence::const_reference const_reference;
382 typedef typename _Sequence::size_type size_type;
383 typedef _Sequence container_type;
386 // See queue::c for notes on these names.
392 * @brief Default constructor creates no elements.
394 #if __cplusplus < 201103L
396 priority_queue(const _Compare& __x = _Compare(),
397 const _Sequence& __s = _Sequence())
399 { std::make_heap(c.begin(), c.end(), comp); }
402 priority_queue(const _Compare& __x,
403 const _Sequence& __s)
405 { std::make_heap(c.begin(), c.end(), comp); }
408 priority_queue(const _Compare& __x = _Compare(),
409 _Sequence&& __s = _Sequence())
410 : c(std::move(__s)), comp(__x)
411 { std::make_heap(c.begin(), c.end(), comp); }
415 * @brief Builds a %queue from a range.
416 * @param __first An input iterator.
417 * @param __last An input iterator.
418 * @param __x A comparison functor describing a strict weak ordering.
419 * @param __s An initial sequence with which to start.
421 * Begins by copying @a __s, inserting a copy of the elements
422 * from @a [first,last) into the copy of @a __s, then ordering
423 * the copy according to @a __x.
425 * For more information on function objects, see the
426 * documentation on @link functors functor base
429 #if __cplusplus < 201103L
430 template<typename _InputIterator>
431 priority_queue(_InputIterator __first, _InputIterator __last,
432 const _Compare& __x = _Compare(),
433 const _Sequence& __s = _Sequence())
436 __glibcxx_requires_valid_range(__first, __last);
437 c.insert(c.end(), __first, __last);
438 std::make_heap(c.begin(), c.end(), comp);
441 template<typename _InputIterator>
442 priority_queue(_InputIterator __first, _InputIterator __last,
444 const _Sequence& __s)
447 __glibcxx_requires_valid_range(__first, __last);
448 c.insert(c.end(), __first, __last);
449 std::make_heap(c.begin(), c.end(), comp);
452 template<typename _InputIterator>
453 priority_queue(_InputIterator __first, _InputIterator __last,
454 const _Compare& __x = _Compare(),
455 _Sequence&& __s = _Sequence())
456 : c(std::move(__s)), comp(__x)
458 __glibcxx_requires_valid_range(__first, __last);
459 c.insert(c.end(), __first, __last);
460 std::make_heap(c.begin(), c.end(), comp);
465 * Returns true if the %queue is empty.
469 { return c.empty(); }
471 /** Returns the number of elements in the %queue. */
477 * Returns a read-only (constant) reference to the data at the first
478 * element of the %queue.
483 __glibcxx_requires_nonempty();
488 * @brief Add data to the %queue.
489 * @param __x Data to be added.
491 * This is a typical %queue operation.
492 * The time complexity of the operation depends on the underlying
496 push(const value_type& __x)
499 std::push_heap(c.begin(), c.end(), comp);
502 #if __cplusplus >= 201103L
504 push(value_type&& __x)
506 c.push_back(std::move(__x));
507 std::push_heap(c.begin(), c.end(), comp);
510 template<typename... _Args>
512 emplace(_Args&&... __args)
514 c.emplace_back(std::forward<_Args>(__args)...);
515 std::push_heap(c.begin(), c.end(), comp);
520 * @brief Removes first element.
522 * This is a typical %queue operation. It shrinks the %queue
523 * by one. The time complexity of the operation depends on the
524 * underlying sequence.
526 * Note that no data is returned, and if the first element's
527 * data is needed, it should be retrieved before pop() is
533 __glibcxx_requires_nonempty();
534 std::pop_heap(c.begin(), c.end(), comp);
538 #if __cplusplus >= 201103L
540 swap(priority_queue& __pq)
541 noexcept(noexcept(swap(c, __pq.c)) && noexcept(swap(comp, __pq.comp)))
545 swap(comp, __pq.comp);
550 // No equality/comparison operators are provided for priority_queue.
552 #if __cplusplus >= 201103L
553 template<typename _Tp, typename _Sequence, typename _Compare>
555 swap(priority_queue<_Tp, _Sequence, _Compare>& __x,
556 priority_queue<_Tp, _Sequence, _Compare>& __y)
557 noexcept(noexcept(__x.swap(__y)))
560 template<typename _Tp, typename _Sequence, typename _Compare,
562 struct uses_allocator<priority_queue<_Tp, _Sequence, _Compare>, _Alloc>
563 : public uses_allocator<_Sequence, _Alloc>::type { };
566 _GLIBCXX_END_NAMESPACE_VERSION
569 #endif /* _STL_QUEUE_H */