experiment to use libdeflate
This commit is contained in:
parent
61dbcc2b84
commit
0c877f768a
19
CMake/FindDeflate.cmake
Normal file
19
CMake/FindDeflate.cmake
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
# Find package structure taken from libcurl
|
||||||
|
|
||||||
|
include(FindPackageHandleStandardArgs)
|
||||||
|
|
||||||
|
find_path(DEFLATE_INCLUDE_DIRS libdeflate.h)
|
||||||
|
find_library(DEFLATE_LIBRARY deflate)
|
||||||
|
|
||||||
|
find_package_handle_standard_args(DEFLATE
|
||||||
|
FOUND_VAR
|
||||||
|
DEFLATE_FOUND
|
||||||
|
REQUIRED_VARS
|
||||||
|
DEFLATE_LIBRARY
|
||||||
|
DEFLATE_INCLUDE_DIRS
|
||||||
|
FAIL_MESSAGE
|
||||||
|
"Could NOT find deflate"
|
||||||
|
)
|
||||||
|
|
||||||
|
set(DEFLATE_INCLUDE_DIRS ${DEFLATE_INCLUDE_DIRS})
|
||||||
|
set(DEFLATE_LIBRARIES ${DEFLATE_LIBRARY})
|
@ -202,6 +202,14 @@ if (USE_ZLIB)
|
|||||||
target_compile_definitions(ixwebsocket PUBLIC IXWEBSOCKET_USE_ZLIB)
|
target_compile_definitions(ixwebsocket PUBLIC IXWEBSOCKET_USE_ZLIB)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# brew install libdeflate
|
||||||
|
find_package(DEFLATE)
|
||||||
|
if (DEFLATE_FOUND)
|
||||||
|
include_directories(${DEFLATE_INCLUDE_DIRS})
|
||||||
|
target_link_libraries(ixwebsocket ${DEFLATE_LIBRARIES})
|
||||||
|
target_compile_definitions(ixwebsocket PUBLIC IXWEBSOCKET_USE_DEFLATE)
|
||||||
|
endif()
|
||||||
|
|
||||||
if (WIN32)
|
if (WIN32)
|
||||||
target_link_libraries(ixwebsocket wsock32 ws2_32 shlwapi)
|
target_link_libraries(ixwebsocket wsock32 ws2_32 shlwapi)
|
||||||
add_definitions(-D_CRT_SECURE_NO_WARNINGS)
|
add_definitions(-D_CRT_SECURE_NO_WARNINGS)
|
||||||
|
@ -13,11 +13,55 @@
|
|||||||
#include <zlib.h>
|
#include <zlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef IXWEBSOCKET_USE_DEFLATE
|
||||||
|
#include <libdeflate.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
namespace ix
|
namespace ix
|
||||||
{
|
{
|
||||||
#ifdef IXWEBSOCKET_USE_ZLIB
|
#ifdef IXWEBSOCKET_USE_ZLIB
|
||||||
std::string gzipCompress(const std::string& str)
|
std::string gzipCompress(const std::string& str)
|
||||||
{
|
{
|
||||||
|
#ifdef IXWEBSOCKET_USE_DEFLATE
|
||||||
|
int compressionLevel = 6;
|
||||||
|
struct libdeflate_compressor *compressor =
|
||||||
|
libdeflate_alloc_compressor(compressionLevel);
|
||||||
|
|
||||||
|
const void *uncompressed_data = str.data();
|
||||||
|
size_t uncompressed_size = str.size();
|
||||||
|
void *compressed_data;
|
||||||
|
size_t actual_compressed_size;
|
||||||
|
size_t max_compressed_size;
|
||||||
|
|
||||||
|
max_compressed_size = libdeflate_gzip_compress_bound(compressor,
|
||||||
|
uncompressed_size);
|
||||||
|
compressed_data = malloc(max_compressed_size);
|
||||||
|
if (compressed_data == NULL)
|
||||||
|
{
|
||||||
|
return std::string();
|
||||||
|
}
|
||||||
|
|
||||||
|
actual_compressed_size = libdeflate_gzip_compress(
|
||||||
|
compressor,
|
||||||
|
uncompressed_data,
|
||||||
|
uncompressed_size,
|
||||||
|
compressed_data,
|
||||||
|
max_compressed_size);
|
||||||
|
|
||||||
|
if (actual_compressed_size == 0)
|
||||||
|
{
|
||||||
|
free(compressed_data);
|
||||||
|
return std::string();
|
||||||
|
}
|
||||||
|
|
||||||
|
libdeflate_free_compressor(compressor);
|
||||||
|
|
||||||
|
std::string out;
|
||||||
|
out.append(reinterpret_cast<char*>(compressed_data), actual_compressed_size);
|
||||||
|
free(compressed_data);
|
||||||
|
|
||||||
|
return out;
|
||||||
|
#else
|
||||||
z_stream zs; // z_stream is zlib's control structure
|
z_stream zs; // z_stream is zlib's control structure
|
||||||
memset(&zs, 0, sizeof(zs));
|
memset(&zs, 0, sizeof(zs));
|
||||||
|
|
||||||
@ -57,6 +101,7 @@ namespace ix
|
|||||||
deflateEnd(&zs);
|
deflateEnd(&zs);
|
||||||
|
|
||||||
return outstring;
|
return outstring;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
bool gzipDecompress(const std::string& in, std::string& out)
|
bool gzipDecompress(const std::string& in, std::string& out)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user