mirror of
				https://github.com/facebook/zstd.git
				synced 2025-10-26 00:37:36 +03:00 
			
		
		
		
	ensure new ZSTD_strategy starts at value 1
This commit is contained in:
		| @@ -2753,23 +2753,26 @@ static void ZSTD_compressBlock_btultra_extDict(ZSTD_CCtx* ctx, const void* src, | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* ZSTD_selectBlockCompressor() : | ||||||
|  |  * assumption : strat is a valid strategy */ | ||||||
| typedef void (*ZSTD_blockCompressor) (ZSTD_CCtx* ctx, const void* src, size_t srcSize); | typedef void (*ZSTD_blockCompressor) (ZSTD_CCtx* ctx, const void* src, size_t srcSize); | ||||||
|  |  | ||||||
| static ZSTD_blockCompressor ZSTD_selectBlockCompressor(ZSTD_strategy strat, int extDict) | static ZSTD_blockCompressor ZSTD_selectBlockCompressor(ZSTD_strategy strat, int extDict) | ||||||
| { | { | ||||||
|     static const ZSTD_blockCompressor blockCompressor[2][(unsigned)ZSTD_btultra+1] = { |     static const ZSTD_blockCompressor blockCompressor[2][(unsigned)ZSTD_btultra+1] = { | ||||||
|         { NULL, |         { ZSTD_compressBlock_fast  /* default for 0 */, | ||||||
|           ZSTD_compressBlock_fast, ZSTD_compressBlock_doubleFast, ZSTD_compressBlock_greedy, |           ZSTD_compressBlock_fast, ZSTD_compressBlock_doubleFast, ZSTD_compressBlock_greedy, | ||||||
|           ZSTD_compressBlock_lazy, ZSTD_compressBlock_lazy2, ZSTD_compressBlock_btlazy2, |           ZSTD_compressBlock_lazy, ZSTD_compressBlock_lazy2, ZSTD_compressBlock_btlazy2, | ||||||
|           ZSTD_compressBlock_btopt, ZSTD_compressBlock_btultra }, |           ZSTD_compressBlock_btopt, ZSTD_compressBlock_btultra }, | ||||||
|         { NULL, |         { ZSTD_compressBlock_fast_extDict  /* default for 0 */, | ||||||
|           ZSTD_compressBlock_fast_extDict, ZSTD_compressBlock_doubleFast_extDict, ZSTD_compressBlock_greedy_extDict, |           ZSTD_compressBlock_fast_extDict, ZSTD_compressBlock_doubleFast_extDict, ZSTD_compressBlock_greedy_extDict, | ||||||
|           ZSTD_compressBlock_lazy_extDict,ZSTD_compressBlock_lazy2_extDict, ZSTD_compressBlock_btlazy2_extDict, |           ZSTD_compressBlock_lazy_extDict,ZSTD_compressBlock_lazy2_extDict, ZSTD_compressBlock_btlazy2_extDict, | ||||||
|           ZSTD_compressBlock_btopt_extDict, ZSTD_compressBlock_btultra_extDict } |           ZSTD_compressBlock_btopt_extDict, ZSTD_compressBlock_btultra_extDict } | ||||||
|     }; |     }; | ||||||
|     ZSTD_STATIC_ASSERT((unsigned)ZSTD_fast == 1); |     ZSTD_STATIC_ASSERT((unsigned)ZSTD_fast == 1); | ||||||
|  |     assert((U32)strat >= (U32)ZSTD_fast); | ||||||
|  |     assert((U32)strat <= (U32)ZSTD_btultra); | ||||||
|  |  | ||||||
|     return blockCompressor[extDict][(U32)strat]; |     return blockCompressor[extDict!=0][(U32)strat]; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -15,13 +15,15 @@ | |||||||
|  #endif |  #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Note : All prototypes defined in this file must be considered experimental. | /* Note : All prototypes defined in this file are labelled experimental. | ||||||
|  *        There is no guarantee of API continuity on any of these prototypes */ |  *        No guarantee of API continuity is provided on any of them. | ||||||
|  |  *        In fact, the expectation is that these prototypes will be replaced | ||||||
|  |  *        by ZSTD_compress_generic() API in the near future */ | ||||||
|  |  | ||||||
| /* ===   Dependencies   === */ | /* ===   Dependencies   === */ | ||||||
| #include <stddef.h>   /* size_t */ | #include <stddef.h>                /* size_t */ | ||||||
| #define ZSTD_STATIC_LINKING_ONLY   /* ZSTD_parameters */ | #define ZSTD_STATIC_LINKING_ONLY   /* ZSTD_parameters */ | ||||||
| #include "zstd.h"     /* ZSTD_inBuffer, ZSTD_outBuffer, ZSTDLIB_API */ | #include "zstd.h"            /* ZSTD_inBuffer, ZSTD_outBuffer, ZSTDLIB_API */ | ||||||
|  |  | ||||||
|  |  | ||||||
| /* ===   Memory management   === */ | /* ===   Memory management   === */ | ||||||
| @@ -32,7 +34,6 @@ ZSTDLIB_API ZSTDMT_CCtx* ZSTDMT_createCCtx_advanced(unsigned nbThreads, | |||||||
| ZSTDLIB_API size_t ZSTDMT_freeCCtx(ZSTDMT_CCtx* mtctx); | ZSTDLIB_API size_t ZSTDMT_freeCCtx(ZSTDMT_CCtx* mtctx); | ||||||
|  |  | ||||||
| ZSTDLIB_API size_t ZSTDMT_sizeof_CCtx(ZSTDMT_CCtx* mtctx); | ZSTDLIB_API size_t ZSTDMT_sizeof_CCtx(ZSTDMT_CCtx* mtctx); | ||||||
| ZSTDLIB_API size_t ZSTDMT_estimateCCtxSize(ZSTD_compressionParameters cParams, unsigned nbThreads);   /* not ready yet */ |  | ||||||
|  |  | ||||||
|  |  | ||||||
| /* ===   Simple buffer-to-butter one-pass function   === */ | /* ===   Simple buffer-to-butter one-pass function   === */ | ||||||
| @@ -87,7 +88,7 @@ ZSTDLIB_API size_t ZSTDMT_setMTCtxParameter(ZSTDMT_CCtx* mtctx, ZSDTMT_parameter | |||||||
|  |  | ||||||
| /*! ZSTDMT_compressStream_generic() : | /*! ZSTDMT_compressStream_generic() : | ||||||
|  *  Combines ZSTDMT_compressStream() with ZSTDMT_flushStream() or ZSTDMT_endStream() |  *  Combines ZSTDMT_compressStream() with ZSTDMT_flushStream() or ZSTDMT_endStream() | ||||||
|  *  depending on flush directive |  *  depending on flush directive. | ||||||
|  * @return : minimum amount of data still to be flushed |  * @return : minimum amount of data still to be flushed | ||||||
|  *           0 if fully flushed |  *           0 if fully flushed | ||||||
|  *           or an error code */ |  *           or an error code */ | ||||||
|   | |||||||
| @@ -251,8 +251,8 @@ The list of available _options_: | |||||||
|     Specify a strategy used by a match finder. |     Specify a strategy used by a match finder. | ||||||
|  |  | ||||||
|     There are 8 strategies numbered from 0 to 7, from faster to stronger: |     There are 8 strategies numbered from 0 to 7, from faster to stronger: | ||||||
|     0=ZSTD\_fast, 1=ZSTD\_dfast, 2=ZSTD\_greedy, 3=ZSTD\_lazy, |     1=ZSTD\_fast, 2=ZSTD\_dfast, 3=ZSTD\_greedy, 4=ZSTD\_lazy, | ||||||
|     4=ZSTD\_lazy2, 5=ZSTD\_btlazy2, 6=ZSTD\_btopt, 7=ZSTD\_btultra. |     5=ZSTD\_lazy2, 6=ZSTD\_btlazy2, 7=ZSTD\_btopt, 8=ZSTD\_btultra. | ||||||
|  |  | ||||||
| - `windowLog`=_wlog_, `wlog`=_wlog_: | - `windowLog`=_wlog_, `wlog`=_wlog_: | ||||||
|     Specify the maximum number of bits for a match distance. |     Specify the maximum number of bits for a match distance. | ||||||
|   | |||||||
| @@ -298,7 +298,7 @@ static unsigned parseCompressionParameters(const char* stringPtr, ZSTD_compressi | |||||||
|         if (longCommandWArg(&stringPtr, "searchLog=") || longCommandWArg(&stringPtr, "slog=")) { params->searchLog = readU32FromChar(&stringPtr); if (stringPtr[0]==',') { stringPtr++; continue; } else break; } |         if (longCommandWArg(&stringPtr, "searchLog=") || longCommandWArg(&stringPtr, "slog=")) { params->searchLog = readU32FromChar(&stringPtr); if (stringPtr[0]==',') { stringPtr++; continue; } else break; } | ||||||
|         if (longCommandWArg(&stringPtr, "searchLength=") || longCommandWArg(&stringPtr, "slen=")) { params->searchLength = readU32FromChar(&stringPtr); if (stringPtr[0]==',') { stringPtr++; continue; } else break; } |         if (longCommandWArg(&stringPtr, "searchLength=") || longCommandWArg(&stringPtr, "slen=")) { params->searchLength = readU32FromChar(&stringPtr); if (stringPtr[0]==',') { stringPtr++; continue; } else break; } | ||||||
|         if (longCommandWArg(&stringPtr, "targetLength=") || longCommandWArg(&stringPtr, "tlen=")) { params->targetLength = readU32FromChar(&stringPtr); if (stringPtr[0]==',') { stringPtr++; continue; } else break; } |         if (longCommandWArg(&stringPtr, "targetLength=") || longCommandWArg(&stringPtr, "tlen=")) { params->targetLength = readU32FromChar(&stringPtr); if (stringPtr[0]==',') { stringPtr++; continue; } else break; } | ||||||
|         if (longCommandWArg(&stringPtr, "strategy=") || longCommandWArg(&stringPtr, "strat=")) { params->strategy = (ZSTD_strategy)(1 + readU32FromChar(&stringPtr)); if (stringPtr[0]==',') { stringPtr++; continue; } else break; } |         if (longCommandWArg(&stringPtr, "strategy=") || longCommandWArg(&stringPtr, "strat=")) { params->strategy = (ZSTD_strategy)(readU32FromChar(&stringPtr)); if (stringPtr[0]==',') { stringPtr++; continue; } else break; } | ||||||
|         if (longCommandWArg(&stringPtr, "overlapLog=") || longCommandWArg(&stringPtr, "ovlog=")) { g_overlapLog = readU32FromChar(&stringPtr); if (stringPtr[0]==',') { stringPtr++; continue; } else break; } |         if (longCommandWArg(&stringPtr, "overlapLog=") || longCommandWArg(&stringPtr, "ovlog=")) { g_overlapLog = readU32FromChar(&stringPtr); if (stringPtr[0]==',') { stringPtr++; continue; } else break; } | ||||||
|         return 0; |         return 0; | ||||||
|     } |     } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user