annotate DEPENDENCIES/generic/include/boost/pending/is_heap.hpp @ 133:4acb5d8d80b6 tip

Don't fail environmental check if README.md exists (but .txt and no-suffix don't)
author Chris Cannam
date Tue, 30 Jul 2019 12:25:44 +0100
parents 2665513ce2d3
children
rev   line source
Chris@16 1 //
Chris@16 2 //=======================================================================
Chris@16 3 // Copyright 1997, 1998, 1999, 2000 University of Notre Dame.
Chris@16 4 // Authors: Andrew Lumsdaine, Lie-Quan Lee, Jeremy G. Siek
Chris@16 5 //
Chris@16 6 // Distributed under the Boost Software License, Version 1.0. (See
Chris@16 7 // accompanying file LICENSE_1_0.txt or copy at
Chris@16 8 // http://www.boost.org/LICENSE_1_0.txt)
Chris@16 9 //=======================================================================
Chris@16 10 //
Chris@16 11 #if __KCC
Chris@16 12 namespace std {
Chris@16 13
Chris@16 14 template <class RandomAccessIterator, class Distance>
Chris@16 15 bool __is_heap(RandomAccessIterator first, RandomAccessIterator last,
Chris@16 16 Distance*)
Chris@16 17 {
Chris@16 18 const Distance n = last - first;
Chris@16 19
Chris@16 20 Distance parent = 0;
Chris@16 21 for (Distance child = 1; child < n; ++child) {
Chris@16 22 if (first[parent] < first[child])
Chris@16 23 return false;
Chris@16 24 if ((child & 1) == 0)
Chris@16 25 ++parent;
Chris@16 26 }
Chris@16 27 return true;
Chris@16 28 }
Chris@16 29
Chris@16 30 template <class RandomAccessIterator>
Chris@16 31 inline bool is_heap(RandomAccessIterator first, RandomAccessIterator last)
Chris@16 32 {
Chris@16 33 return __is_heap(first, last, distance_type(first));
Chris@16 34 }
Chris@16 35
Chris@16 36
Chris@16 37 template <class RandomAccessIterator, class Distance, class StrictWeakOrdering>
Chris@16 38 bool __is_heap(RandomAccessIterator first, RandomAccessIterator last,
Chris@16 39 StrictWeakOrdering comp,
Chris@16 40 Distance*)
Chris@16 41 {
Chris@16 42 const Distance n = last - first;
Chris@16 43
Chris@16 44 Distance parent = 0;
Chris@16 45 for (Distance child = 1; child < n; ++child) {
Chris@16 46 if (comp(first[parent], first[child]))
Chris@16 47 return false;
Chris@16 48 if ((child & 1) == 0)
Chris@16 49 ++parent;
Chris@16 50 }
Chris@16 51 return true;
Chris@16 52 }
Chris@16 53
Chris@16 54 template <class RandomAccessIterator, class StrictWeakOrdering>
Chris@16 55 inline bool is_heap(RandomAccessIterator first, RandomAccessIterator last,
Chris@16 56 StrictWeakOrdering comp)
Chris@16 57 {
Chris@16 58 return __is_heap(first, last, comp, distance_type(first));
Chris@16 59 }
Chris@16 60
Chris@16 61 }
Chris@16 62 #endif