MySQL
8.0.40
Source Code Documentation
i_options_provider.h
Go to the documentation of this file.
1
/*
2
Copyright (c) 2014, 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_OPTIONS_PROVIDER_INCLUDED
27
#define I_OPTIONS_PROVIDER_INCLUDED
28
29
#include <vector>
30
31
#include "
client/base/i_option_changed_listener.h
"
32
#include "
my_getopt.h
"
33
34
namespace
Mysql
{
35
namespace
Tools {
36
namespace
Base {
37
namespace
Options
{
38
39
/**
40
Interface for basic options providers functionality.
41
*/
42
class
I_options_provider
:
public
I_option_changed_listener
{
43
public
:
44
/**
45
Creates list of options provided by this provider.
46
@returns list of my_getopt internal option data structures.
47
*/
48
virtual
std::vector<my_option>
generate_options
() = 0;
49
/**
50
Callback to be called when command-line options parsing have finished.
51
*/
52
virtual
void
options_parsed
() = 0;
53
/**
54
Sets optional option changes listener to which all changes in all options
55
contained in this provider should be reported. This is used when this
56
provider is attached to another.
57
*/
58
virtual
void
set_option_changed_listener
(
59
I_option_changed_listener
*listener) = 0;
60
};
61
62
}
// namespace Options
63
}
// namespace Base
64
}
// namespace Tools
65
}
// namespace Mysql
66
67
#endif
Mysql::Tools::Base::Options::I_option_changed_listener
Interface for listeners on some of option changes.
Definition:
i_option_changed_listener.h:41
Mysql::Tools::Base::Options::I_options_provider
Interface for basic options providers functionality.
Definition:
i_options_provider.h:42
Mysql::Tools::Base::Options::I_options_provider::set_option_changed_listener
virtual void set_option_changed_listener(I_option_changed_listener *listener)=0
Sets optional option changes listener to which all changes in all options contained in this provider ...
Mysql::Tools::Base::Options::I_options_provider::generate_options
virtual std::vector< my_option > generate_options()=0
Creates list of options provided by this provider.
Mysql::Tools::Base::Options::I_options_provider::options_parsed
virtual void options_parsed()=0
Callback to be called when command-line options parsing have finished.
i_option_changed_listener.h
my_getopt.h
HttpMethod::Pos::Options
constexpr pos_type Options
Definition:
http_request.h:261
Mysql
Definition:
abstract_connection_program.h:38
client
base
i_options_provider.h
Generated by
1.9.2