Index: src/pathops/TSearch.h |
=================================================================== |
--- src/pathops/TSearch.h (revision 0) |
+++ src/pathops/TSearch.h (revision 0) |
@@ -0,0 +1,101 @@ |
+/* |
+ * Copyright 2012 Google Inc. |
+ * |
+ * Use of this source code is governed by a BSD-style license that can be |
+ * found in the LICENSE file. |
+ */ |
+#ifndef TSearch_DEFINED |
+#define TSearch_DEFINED |
+ |
+// FIXME: Move this templated version into SKTSearch.h |
+ |
+template <typename T> |
+static T* QSort_Partition(T* left, T* right, T* pivot) |
+{ |
+ T pivotValue = *pivot; |
+ SkTSwap(*pivot, *right); |
+ T* newPivot = left; |
+ while (left < right) { |
+ if (*left < pivotValue) { |
+ SkTSwap(*left, *newPivot); |
+ newPivot += 1; |
+ } |
+ left += 1; |
+ } |
+ SkTSwap(*newPivot, *right); |
+ return newPivot; |
+} |
+ |
+template <typename T> |
+void QSort(T* left, T* right) |
+{ |
+ if (left >= right) { |
+ return; |
+ } |
+ T* pivot = left + (right - left >> 1); |
+ pivot = QSort_Partition(left, right, pivot); |
+ QSort(left, pivot - 1); |
+ QSort(pivot + 1, right); |
+} |
+ |
+template <typename T> |
+static T** QSort_Partition(T** left, T** right, T** pivot) |
+{ |
+ T* pivotValue = *pivot; |
+ SkTSwap(*pivot, *right); |
+ T** newPivot = left; |
+ while (left < right) { |
+ if (**left < *pivotValue) { |
+ SkTSwap(*left, *newPivot); |
+ newPivot += 1; |
+ } |
+ left += 1; |
+ } |
+ SkTSwap(*newPivot, *right); |
+ return newPivot; |
+} |
+ |
+template <typename T> |
+void QSort(T** left, T** right) |
+{ |
+ if (left >= right) { |
+ return; |
+ } |
+ T** pivot = left + (right - left >> 1); |
+ pivot = QSort_Partition(left, right, pivot); |
+ QSort(left, pivot - 1); |
+ QSort(pivot + 1, right); |
+} |
+ |
+template <typename S, typename T> |
+static T* QSort_Partition(S& context, T* left, T* right, T* pivot, |
+ bool (*lessThan)(S&, const T, const T)) |
+{ |
+ T pivotValue = *pivot; |
+ SkTSwap(*pivot, *right); |
+ T* newPivot = left; |
+ while (left < right) { |
+ if (lessThan(context, *left, pivotValue)) { |
+ SkTSwap(*left, *newPivot); |
+ newPivot += 1; |
+ } |
+ left += 1; |
+ } |
+ SkTSwap(*newPivot, *right); |
+ return newPivot; |
+} |
+ |
+template <typename S, typename T> |
+void QSort(S& context, T* left, T* right, |
+ bool (*lessThan)(S& , const T, const T)) |
+{ |
+ if (left >= right) { |
+ return; |
+ } |
+ T* pivot = left + (right - left >> 1); |
+ pivot = QSort_Partition(context, left, right, pivot, lessThan); |
+ QSort(context, left, pivot - 1, lessThan); |
+ QSort(context, pivot + 1, right, lessThan); |
+} |
+ |
+#endif |