Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(53)

Side by Side Diff: third_party/WebKit/Source/wtf/NonCopyingSort.h

Issue 2755793004: Move files in wtf/ to platform/wtf/ (Part 3). (Closed)
Patch Set: Created 3 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 * Copyright (C) 2010 Apple Inc. All Rights Reserved. 2 // Use of this source code is governed by a BSD-style license that can be
3 * 3 // found in the LICENSE file.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
6 * are met:
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
12 *
13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24 *
25 */
26 4
27 #ifndef WTF_NonCopyingSort_h 5 #include "platform/wtf/NonCopyingSort.h"
28 #define WTF_NonCopyingSort_h
29 6
30 namespace WTF { 7 // The contents of this header was moved to platform/wtf as part of
31 8 // WTF migration project. See the following post for details:
32 using std::swap; 9 // https://groups.google.com/a/chromium.org/d/msg/blink-dev/tLdAZCTlcAA/bYXVT8gY CAAJ
33
34 template <typename RandomAccessIterator, typename Predicate>
35 inline void siftDown(RandomAccessIterator array,
36 ptrdiff_t start,
37 ptrdiff_t end,
38 Predicate compareLess) {
39 ptrdiff_t root = start;
40
41 while (root * 2 + 1 <= end) {
42 ptrdiff_t child = root * 2 + 1;
43 if (child < end && compareLess(array[child], array[child + 1]))
44 child++;
45
46 if (compareLess(array[root], array[child])) {
47 swap(array[root], array[child]);
48 root = child;
49 } else {
50 return;
51 }
52 }
53 }
54
55 template <typename RandomAccessIterator, typename Predicate>
56 inline void heapify(RandomAccessIterator array,
57 ptrdiff_t count,
58 Predicate compareLess) {
59 ptrdiff_t start = (count - 2) / 2;
60
61 while (start >= 0) {
62 siftDown(array, start, count - 1, compareLess);
63 start--;
64 }
65 }
66
67 template <typename RandomAccessIterator, typename Predicate>
68 void heapSort(RandomAccessIterator start,
69 RandomAccessIterator end,
70 Predicate compareLess) {
71 ptrdiff_t count = end - start;
72 heapify(start, count, compareLess);
73
74 ptrdiff_t endIndex = count - 1;
75 while (endIndex > 0) {
76 swap(start[endIndex], start[0]);
77 siftDown(start, 0, endIndex - 1, compareLess);
78 endIndex--;
79 }
80 }
81
82 template <typename RandomAccessIterator, typename Predicate>
83 inline void nonCopyingSort(RandomAccessIterator start,
84 RandomAccessIterator end,
85 Predicate compareLess) {
86 // heapsort happens to use only swaps, not copies, but the essential thing
87 // about this function is the fact that it does not copy, not the specific
88 // algorithm
89 heapSort(start, end, compareLess);
90 }
91
92 } // namespace WTF
93
94 using WTF::nonCopyingSort;
95
96 #endif // WTF_NonCopyingSort_h
OLDNEW
« no previous file with comments | « third_party/WebKit/Source/platform/wtf/TriState.h ('k') | third_party/WebKit/Source/wtf/NotFound.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698