tor
master
|
Compression backend for Zstandard. More...
#include "orconfig.h"
#include "util.h"
#include "torlog.h"
#include "compress.h"
#include "compress_zstd.h"
Data Structures | |
struct | tor_zstd_compress_state_t |
Macros | |
#define | VERSION_STR_MAX_LEN 16 /* more than enough space for 99.99.99 */ |
Functions | |
int | tor_zstd_method_supported (void) |
const char * | tor_zstd_get_version_str (void) |
const char * | tor_zstd_get_header_version_str (void) |
int | tor_zstd_can_use_static_apis (void) |
tor_zstd_compress_state_t * | tor_zstd_compress_new (int compress, compress_method_t method, compression_level_t level) |
tor_compress_output_t | tor_zstd_compress_process (tor_zstd_compress_state_t *state, char **out, size_t *out_len, const char **in, size_t *in_len, int finish) |
void | tor_zstd_compress_free_ (tor_zstd_compress_state_t *state) |
size_t | tor_zstd_compress_state_size (const tor_zstd_compress_state_t *state) |
size_t | tor_zstd_get_total_allocation (void) |
void | tor_zstd_init (void) |
void | tor_zstd_warn_if_version_mismatched (void) |
Compression backend for Zstandard.
This module should never be invoked directly. Use the compress module instead.
int tor_zstd_can_use_static_apis | ( | void | ) |
Return true iff we can use the "static-only" APIs.
void tor_zstd_compress_free_ | ( | tor_zstd_compress_state_t * | state | ) |
Deallocate state.
tor_zstd_compress_state_t* tor_zstd_compress_new | ( | int | compress, |
compress_method_t | method, | ||
compression_level_t | level | ||
) |
Construct and return a tor_zstd_compress_state_t object using method. If compress, it's for compression; otherwise it's for decompression.
tor_compress_output_t tor_zstd_compress_process | ( | tor_zstd_compress_state_t * | state, |
char ** | out, | ||
size_t * | out_len, | ||
const char ** | in, | ||
size_t * | in_len, | ||
int | finish | ||
) |
Compress/decompress some bytes using state. Read up to *in_len bytes from *in, and write up to *out_len bytes to *out, adjusting the values as we go. If finish is true, we've reached the end of the input.
Return TOR_COMPRESS_DONE if we've finished the entire compression/decompression. Return TOR_COMPRESS_OK if we're processed everything from the input. Return TOR_COMPRESS_BUFFER_FULL if we're out of space on out. Return TOR_COMPRESS_ERROR if the stream is corrupt.
size_t tor_zstd_compress_state_size | ( | const tor_zstd_compress_state_t * | state | ) |
Return the approximate number of bytes allocated for state.
const char* tor_zstd_get_header_version_str | ( | void | ) |
Return a string representation of the version of the version of libzstd used at compilation time. Returns NULL if Zstandard is unsupported.
size_t tor_zstd_get_total_allocation | ( | void | ) |
Return the approximate number of bytes allocated for all Zstandard states.
const char* tor_zstd_get_version_str | ( | void | ) |
Return a string representation of the version of the currently running version of libzstd. Returns NULL if Zstandard is unsupported.
void tor_zstd_init | ( | void | ) |
Initialize the zstd module
int tor_zstd_method_supported | ( | void | ) |
Return 1 if Zstandard compression is supported; otherwise 0.
void tor_zstd_warn_if_version_mismatched | ( | void | ) |
Warn if the header and library versions don't match.