/* * 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