summaryrefslogtreecommitdiff
path: root/libstdc++-v3
diff options
context:
space:
mode:
authorpaolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4>2007-02-13 00:25:30 +0000
committerpaolo <paolo@138bc75d-0d04-0410-961f-82ee72b054a4>2007-02-13 00:25:30 +0000
commitbbdcb80e468177600fb14b0b8aed45672f73f15a (patch)
tree425fc9e1ce06d50cf40508800cd51b380d82dd05 /libstdc++-v3
parentf19a87eaf2c46ca19f90a54b475ef80dfa413396 (diff)
downloadgcc-bbdcb80e468177600fb14b0b8aed45672f73f15a.tar.gz
2007-02-12 Paolo Carlini <pcarlini@suse.de>
PR libstdc++/21172 * include/bits/stl_heap.h (__adjust_heap(_RandomAccessIterator, _Distance, _Distance, _Tp), __adjust_heap(_RandomAccessIterator, _Distance, _Distance, _Tp, _Compare)): Avoid potential integer overflow. * include/bits/stl_heap.h (__is_heap(_RandomAccessIterator, _RandomAccessIterator), __is_heap(_RandomAccessIterator, _RandomAccessIterator, _StrictWeakOrdering): Mark inline. (make_heap(_RandomAccessIterator, _RandomAccessIterator, _Compare)): Do not mark inline. * include/bits/stl_heap.h (push_heap(_RandomAccessIterator, _RandomAccessIterator), sort_heap(_RandomAccessIterator, _RandomAccessIterator)): Uncomment __glibcxx_requires_heap. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@121875 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libstdc++-v3')
-rw-r--r--libstdc++-v3/ChangeLog18
-rw-r--r--libstdc++-v3/include/bits/stl_heap.h38
2 files changed, 39 insertions, 17 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index 26f1a67e84f..cd928efb7b6 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,3 +1,21 @@
+2007-02-12 Paolo Carlini <pcarlini@suse.de>
+
+ PR libstdc++/21172
+ * include/bits/stl_heap.h (__adjust_heap(_RandomAccessIterator,
+ _Distance, _Distance, _Tp), __adjust_heap(_RandomAccessIterator,
+ _Distance, _Distance, _Tp, _Compare)): Avoid potential integer
+ overflow.
+
+ * include/bits/stl_heap.h (__is_heap(_RandomAccessIterator,
+ _RandomAccessIterator), __is_heap(_RandomAccessIterator,
+ _RandomAccessIterator, _StrictWeakOrdering): Mark inline.
+ (make_heap(_RandomAccessIterator, _RandomAccessIterator,
+ _Compare)): Do not mark inline.
+
+ * include/bits/stl_heap.h (push_heap(_RandomAccessIterator,
+ _RandomAccessIterator), sort_heap(_RandomAccessIterator,
+ _RandomAccessIterator)): Uncomment __glibcxx_requires_heap.
+
2007-02-09 Richard Sandiford <richard@codesourcery.com>
* testsuite/22_locale/time_put/put/wchar_t/1.cc: XFAIL if
diff --git a/libstdc++-v3/include/bits/stl_heap.h b/libstdc++-v3/include/bits/stl_heap.h
index 2f0d04c5e4d..2965a12e8ac 100644
--- a/libstdc++-v3/include/bits/stl_heap.h
+++ b/libstdc++-v3/include/bits/stl_heap.h
@@ -1,6 +1,7 @@
// Heap implementation -*- C++ -*-
-// Copyright (C) 2001, 2004, 2005, 2006 Free Software Foundation, Inc.
+// Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007
+// Free Software Foundation, Inc.
//
// This file is part of the GNU ISO C++ Library. This library is free
// software; you can redistribute it and/or modify it under the
@@ -100,14 +101,14 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
}
template<typename _RandomAccessIterator>
- bool
+ inline bool
__is_heap(_RandomAccessIterator __first, _RandomAccessIterator __last)
{ return std::__is_heap(__first, std::distance(__first, __last)); }
template<typename _RandomAccessIterator, typename _StrictWeakOrdering>
- bool
+ inline bool
__is_heap(_RandomAccessIterator __first, _RandomAccessIterator __last,
- _StrictWeakOrdering __comp)
+ _StrictWeakOrdering __comp)
{ return std::__is_heap(__first, __comp, std::distance(__first, __last)); }
// Heap-manipulation functions: push_heap, pop_heap, make_heap, sort_heap.
@@ -150,7 +151,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
_RandomAccessIterator>)
__glibcxx_function_requires(_LessThanComparableConcept<_ValueType>)
__glibcxx_requires_valid_range(__first, __last);
- // __glibcxx_requires_heap(__first, __last - 1);
+ __glibcxx_requires_heap(__first, __last - 1);
std::__push_heap(__first, _DistanceType((__last - __first) - 1),
_DistanceType(0), _ValueType(*(__last - 1)));
@@ -210,17 +211,18 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
_Distance __len, _Tp __value)
{
const _Distance __topIndex = __holeIndex;
- _Distance __secondChild = 2 * __holeIndex + 2;
- while (__secondChild < __len)
+ _Distance __secondChild = __holeIndex;
+ while (__secondChild < (__len - 1) / 2)
{
+ __secondChild = 2 * (__secondChild + 1);
if (*(__first + __secondChild) < *(__first + (__secondChild - 1)))
__secondChild--;
*(__first + __holeIndex) = *(__first + __secondChild);
__holeIndex = __secondChild;
- __secondChild = 2 * (__secondChild + 1);
}
- if (__secondChild == __len)
+ if ((__len & 1) == 0 && __secondChild == (__len - 2) / 2)
{
+ __secondChild = 2 * (__secondChild + 1);
*(__first + __holeIndex) = *(__first + (__secondChild - 1));
__holeIndex = __secondChild - 1;
}
@@ -273,18 +275,19 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
_Distance __len, _Tp __value, _Compare __comp)
{
const _Distance __topIndex = __holeIndex;
- _Distance __secondChild = 2 * __holeIndex + 2;
- while (__secondChild < __len)
+ _Distance __secondChild = __holeIndex;
+ while (__secondChild < (__len - 1) / 2)
{
+ __secondChild = 2 * (__secondChild + 1);
if (__comp(*(__first + __secondChild),
*(__first + (__secondChild - 1))))
__secondChild--;
*(__first + __holeIndex) = *(__first + __secondChild);
__holeIndex = __secondChild;
- __secondChild = 2 * (__secondChild + 1);
}
- if (__secondChild == __len)
+ if ((__len & 1) == 0 && __secondChild == (__len - 2) / 2)
{
+ __secondChild = 2 * (__secondChild + 1);
*(__first + __holeIndex) = *(__first + (__secondChild - 1));
__holeIndex = __secondChild - 1;
}
@@ -319,14 +322,15 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
pop_heap(_RandomAccessIterator __first,
_RandomAccessIterator __last, _Compare __comp)
{
+ typedef typename iterator_traits<_RandomAccessIterator>::value_type
+ _ValueType;
+
// concept requirements
__glibcxx_function_requires(_Mutable_RandomAccessIteratorConcept<
_RandomAccessIterator>)
__glibcxx_requires_valid_range(__first, __last);
__glibcxx_requires_heap_pred(__first, __last, __comp);
- typedef typename iterator_traits<_RandomAccessIterator>::value_type
- _ValueType;
std::__pop_heap(__first, __last - 1, __last - 1,
_ValueType(*(__last - 1)), __comp);
}
@@ -380,7 +384,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
* Comparisons are made using comp.
*/
template<typename _RandomAccessIterator, typename _Compare>
- inline void
+ void
make_heap(_RandomAccessIterator __first, _RandomAccessIterator __last,
_Compare __comp)
{
@@ -427,7 +431,7 @@ _GLIBCXX_BEGIN_NAMESPACE(std)
__glibcxx_function_requires(_LessThanComparableConcept<
typename iterator_traits<_RandomAccessIterator>::value_type>)
__glibcxx_requires_valid_range(__first, __last);
- // __glibcxx_requires_heap(__first, __last);
+ __glibcxx_requires_heap(__first, __last);
while (__last - __first > 1)
std::pop_heap(__first, _RandomAccessIterator(__last--));