forked from Kitware/VTK
-
Notifications
You must be signed in to change notification settings - Fork 0
/
vtkLZ4DataCompressor.h
75 lines (60 loc) · 2.55 KB
/
vtkLZ4DataCompressor.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*=========================================================================
Program: Visualization Toolkit
Module: vtkLZ4DataCompressor.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
/**
* @class vtkLZ4DataCompressor
* @brief Data compression using LZ4.
*
* vtkLZ4DataCompressor provides a concrete vtkDataCompressor class
* using LZ4 for compressing and uncompressing data.
*/
#ifndef vtkLZ4DataCompressor_h
#define vtkLZ4DataCompressor_h
#include "vtkDataCompressor.h"
#include "vtkIOCoreModule.h" // For export macro
class VTKIOCORE_EXPORT vtkLZ4DataCompressor : public vtkDataCompressor
{
public:
vtkTypeMacro(vtkLZ4DataCompressor, vtkDataCompressor);
void PrintSelf(ostream& os, vtkIndent indent) override;
static vtkLZ4DataCompressor* New();
/**
* Get the maximum space that may be needed to store data of the
* given uncompressed size after compression. This is the minimum
* size of the output buffer that can be passed to the four-argument
* Compress method.
*/
size_t GetMaximumCompressionSpace(size_t size) override;
/**
* Get/Set the compression level.
*/
// Compression level getter required by vtkDataCompressor.
int GetCompressionLevel() override;
// Compression level setter required by vtkDataCompresor.
void SetCompressionLevel(int compressionLevel) override;
// Direct setting of AccelerationLevel allows more direct
// control over LZ4 compressor
vtkSetClampMacro(AccelerationLevel, int, 1, VTK_INT_MAX);
vtkGetMacro(AccelerationLevel, int);
protected:
vtkLZ4DataCompressor();
~vtkLZ4DataCompressor() override;
int AccelerationLevel;
// Compression method required by vtkDataCompressor.
size_t CompressBuffer(unsigned char const* uncompressedData, size_t uncompressedSize,
unsigned char* compressedData, size_t compressionSpace) override;
// Decompression method required by vtkDataCompressor.
size_t UncompressBuffer(unsigned char const* compressedData, size_t compressedSize,
unsigned char* uncompressedData, size_t uncompressedSize) override;
private:
vtkLZ4DataCompressor(const vtkLZ4DataCompressor&) = delete;
void operator=(const vtkLZ4DataCompressor&) = delete;
};
#endif