7zip/C/BwtSort.h

28 lines
666 B
C
Raw Permalink Normal View History

2021-12-27 01:00:00 +01:00
/* BwtSort.h -- BWT block sorting
2025-07-05 02:00:00 +02:00
: Igor Pavlov : Public domain */
2021-12-27 01:00:00 +01:00
2023-06-21 02:00:00 +02:00
#ifndef ZIP7_INC_BWT_SORT_H
#define ZIP7_INC_BWT_SORT_H
2021-12-27 01:00:00 +01:00
#include "7zTypes.h"
EXTERN_C_BEGIN
/* use BLOCK_SORT_EXTERNAL_FLAGS if blockSize can be > 1M */
/* #define BLOCK_SORT_EXTERNAL_FLAGS */
2025-07-05 02:00:00 +02:00
// #define BLOCK_SORT_EXTERNAL_FLAGS
2021-12-27 01:00:00 +01:00
#ifdef BLOCK_SORT_EXTERNAL_FLAGS
2025-07-05 02:00:00 +02:00
#define BLOCK_SORT_EXTERNAL_SIZE(blockSize) (((blockSize) + 31) >> 5)
2021-12-27 01:00:00 +01:00
#else
#define BLOCK_SORT_EXTERNAL_SIZE(blockSize) 0
#endif
#define BLOCK_SORT_BUF_SIZE(blockSize) ((blockSize) * 2 + BLOCK_SORT_EXTERNAL_SIZE(blockSize) + (1 << 16))
2025-07-05 02:00:00 +02:00
UInt32 BlockSort(UInt32 *indices, const Byte *data, size_t blockSize);
2021-12-27 01:00:00 +01:00
EXTERN_C_END
#endif