MySQL 8.0.39
Source Code Documentation
compression_lz4_writer.h
Go to the documentation of this file.
1/*
2 Copyright (c) 2015, 2024, Oracle and/or its affiliates.
3
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License, version 2.0,
6 as published by the Free Software Foundation.
7
8 This program is designed to work with certain software (including
9 but not limited to OpenSSL) that is licensed under separate terms,
10 as designated in a particular file or component or in included license
11 documentation. The authors of MySQL hereby grant you an additional
12 permission to link the program and your derivative works with the
13 separately licensed software that they have either included with
14 the program or referenced in the documentation.
15
16 This program is distributed in the hope that it will be useful,
17 but WITHOUT ANY WARRANTY; without even the implied warranty of
18 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 GNU General Public License, version 2.0, for more details.
20
21 You should have received a copy of the GNU General Public License
22 along with this program; if not, write to the Free Software
23 Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
24*/
25
26#ifndef COMPRESSION_LZ4_WRITER_INCLUDED
27#define COMPRESSION_LZ4_WRITER_INCLUDED
28
29#include <lz4frame.h>
30#include <string.h>
31#include <functional>
32#include <mutex>
33
36#include "my_inttypes.h"
37
38namespace Mysql {
39namespace Tools {
40namespace Dump {
41
42/**
43 Wrapper to another Output Writer, compresses formatted data stream with LZ4.
44 */
47 public:
49 std::function<bool(const Mysql::Tools::Base::Message_data &)>
50 *message_handler,
51 Simple_id_generator *object_id_generator);
52
53 ~Compression_lz4_writer() override;
54
55 bool init() override;
56 void append(const std::string &data_to_append) override;
57
58 // Fix "inherits ... via dominance" warnings
60 I_progress_watcher *new_progress_watcher) override {
62 }
63
64 // Fix "inherits ... via dominance" warnings
65 uint64 get_id() const override { return Abstract_chain_element::get_id(); }
66
67 protected:
68 // Fix "inherits ... via dominance" warnings
70 Item_processing_data *item_processed) override {
72 }
73
74 private:
75 void process_buffer(size_t lz4_result);
76
77 void prepare_buffer(size_t src_size);
78
79 std::mutex m_lz4_mutex;
80 LZ4F_compressionContext_t m_compression_context;
81 std::vector<char> m_buffer;
82};
83
84} // namespace Dump
85} // namespace Tools
86} // namespace Mysql
87
88#endif
Structure to represent message from server sent after executing query.
Definition: message_data.h:49
void register_progress_watcher(I_progress_watcher *new_progress_watcher) override
Add new Progress Watcher to report to.
Definition: abstract_chain_element.h:58
uint64 get_id() const override
Returns an application unique ID of this chain element object.
Definition: abstract_chain_element.cc:36
void item_completion_in_child_callback(Item_processing_data *item_processed) override
This callback can be requested to be called by child for any object processing.
Definition: abstract_chain_element.cc:150
Implementation of common logic for classes that directs execution of dump tasks to Data Formatters.
Definition: abstract_output_writer_wrapper.h:44
Wrapper to another Output Writer, compresses formatted data stream with LZ4.
Definition: compression_lz4_writer.h:46
void append(const std::string &data_to_append) override
Adds new block of data atomically to output.
Definition: compression_lz4_writer.cc:48
bool init() override
Initialize writer.
Definition: compression_lz4_writer.cc:79
void process_buffer(size_t lz4_result)
Definition: compression_lz4_writer.cc:39
std::mutex m_lz4_mutex
Definition: compression_lz4_writer.h:79
void register_progress_watcher(I_progress_watcher *new_progress_watcher) override
Add new Progress Watcher to report to.
Definition: compression_lz4_writer.h:59
std::vector< char > m_buffer
Definition: compression_lz4_writer.h:81
~Compression_lz4_writer() override
Definition: compression_lz4_writer.cc:63
void prepare_buffer(size_t src_size)
Definition: compression_lz4_writer.cc:32
LZ4F_compressionContext_t m_compression_context
Definition: compression_lz4_writer.h:80
void item_completion_in_child_callback(Item_processing_data *item_processed) override
This callback can be requested to be called by child for any object processing.
Definition: compression_lz4_writer.h:69
Compression_lz4_writer(std::function< bool(const Mysql::Tools::Base::Message_data &)> *message_handler, Simple_id_generator *object_id_generator)
Definition: compression_lz4_writer.cc:73
uint64 get_id() const override
Returns an application unique ID of this chain element object.
Definition: compression_lz4_writer.h:65
Definition: i_output_writer.h:37
Definition: i_progress_watcher.h:37
Data structure for objects that are processed in any chain.
Definition: item_processing_data.h:43
Definition: simple_id_generator.h:37
Some integer typedefs for easier portability.
uint64_t uint64
Definition: my_inttypes.h:69
Definition: abstract_connection_program.h:38