MySQL 8.0.40
Source Code Documentation
char_array_option.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 CHAR_ARRAY_OPTION_INCLUDED
27#define CHAR_ARRAY_OPTION_INCLUDED
28
30
31namespace Mysql {
32namespace Tools {
33namespace Base {
34namespace Options {
35
36/**
37 Option class to get string parameter value and set to char* type object.
38 */
40 public:
41 /**
42 Constructs new string option.
43 @param value Pointer to char* object to receive option value.
44 @param allocated Specifies if value set should be some static string or
45 dynamically allocated string with my_strdup.
46 @param name Name of option. It is used in command line option name as
47 --name.
48 @param description Description of option to be printed in --help.
49 */
50 Char_array_option(char **value, bool allocated, std::string name,
51 std::string description);
52
53 /**
54 Sets value for this option. If it is specified before handling commandline
55 options then supplied value is used as default value of this option.
56 */
57 Char_array_option *set_value(char *value);
58};
59
60} // namespace Options
61} // namespace Base
62} // namespace Tools
63} // namespace Mysql
64
65#endif
Abstract option to handle options accepting value argument.
Definition: abstract_value_option.h:43
Option class to get string parameter value and set to char* type object.
Definition: char_array_option.h:39
Char_array_option * set_value(char *value)
Sets value for this option.
Definition: char_array_option.cc:40
Char_array_option(char **value, bool allocated, std::string name, std::string description)
Constructs new string option.
Definition: char_array_option.cc:33
constexpr pos_type Options
Definition: http_request.h:261
Definition: abstract_connection_program.h:38
case opt name
Definition: sslopt-case.h:33