MySQL
8.0.39
Source Code Documentation
i_chain_element.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 I_CHAIN_ELEMENT_INCLUDED
27
#define I_CHAIN_ELEMENT_INCLUDED
28
29
#include "
client/dump/i_progress_reporter.h
"
30
#include "
my_inttypes.h
"
31
32
namespace
Mysql
{
33
namespace
Tools {
34
namespace
Dump {
35
36
class
Item_processing_data;
37
38
/**
39
Interface for all objects that can process data in any part of dump process.
40
*/
41
class
I_chain_element
:
public
virtual
I_progress_reporter
{
42
public
:
43
~I_chain_element
()
override
;
44
45
/**
46
Returns an application unique ID of this chain element object. This helps
47
progress watching with multiple parts of chain during all objects
48
processing.
49
*/
50
virtual
uint64
get_id
()
const
= 0;
51
52
protected
:
53
/**
54
This callback can be requested to be called by child for any object
55
processing. This will be called when the object processing has completed.
56
Note that this function may be called from multiple threads so all
57
implementations must be thread-safe.
58
*/
59
virtual
void
item_completion_in_child_callback
(
60
Item_processing_data
*item_processed) = 0;
61
};
62
63
}
// namespace Dump
64
}
// namespace Tools
65
}
// namespace Mysql
66
67
#endif
Mysql::Tools::Dump::I_chain_element
Interface for all objects that can process data in any part of dump process.
Definition:
i_chain_element.h:41
Mysql::Tools::Dump::I_chain_element::~I_chain_element
~I_chain_element() override
Mysql::Tools::Dump::I_chain_element::item_completion_in_child_callback
virtual void item_completion_in_child_callback(Item_processing_data *item_processed)=0
This callback can be requested to be called by child for any object processing.
Mysql::Tools::Dump::I_chain_element::get_id
virtual uint64 get_id() const =0
Returns an application unique ID of this chain element object.
Mysql::Tools::Dump::I_progress_reporter
Definition:
i_progress_reporter.h:35
Mysql::Tools::Dump::Item_processing_data
Data structure for objects that are processed in any chain.
Definition:
item_processing_data.h:43
i_progress_reporter.h
my_inttypes.h
Some integer typedefs for easier portability.
uint64
uint64_t uint64
Definition:
my_inttypes.h:69
Mysql
Definition:
abstract_connection_program.h:38
client
dump
i_chain_element.h
Generated by
1.9.2