| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- /*
- * Copyright 2010-2021 Branimir Karadzic. All rights reserved.
- * License: https://github.com/bkaradzic/bx#license-bsd-2-clause
- */
- #ifndef BX_SORT_H_HEADER_GUARD
- #define BX_SORT_H_HEADER_GUARD
- #include "bx.h"
- namespace bx
- {
- ///
- typedef int32_t (*ComparisonFn)(const void* _lhs, const void* _rhs);
- ///
- void quickSort(
- void* _data
- , uint32_t _num
- , uint32_t _stride
- , const ComparisonFn _fn
- );
- ///
- void radixSort(
- uint32_t* _keys
- , uint32_t* _tempKeys
- , uint32_t _size
- );
- ///
- template <typename Ty>
- void radixSort(
- uint32_t* _keys
- , uint32_t* _tempKeys
- , Ty* _values
- , Ty* _tempValues
- , uint32_t _size
- );
- ///
- void radixSort(
- uint64_t* _keys
- , uint64_t* _tempKeys
- , uint32_t _size
- );
- ///
- template <typename Ty>
- void radixSort(
- uint64_t* _keys
- , uint64_t* _tempKeys
- , Ty* _values
- , Ty* _tempValues
- , uint32_t _size
- );
- } // namespace bx
- #include "inline/sort.inl"
- #endif // BX_SORT_H_HEADER_GUARD
|