Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
afd5975c
Commit
afd5975c
authored
Jun 07, 2005
by
petr@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge pchardin@bk-internal.mysql.com:/home/bk/mysql-5.0
into mysql.com:/home/cps/mysql/trees/mysql-5.0
parents
054139fc
65d79b9d
Changes
12
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
170 additions
and
73 deletions
+170
-73
server-tools/instance-manager/buffer.h
server-tools/instance-manager/buffer.h
+1
-1
server-tools/instance-manager/commands.cc
server-tools/instance-manager/commands.cc
+4
-9
server-tools/instance-manager/instance.cc
server-tools/instance-manager/instance.cc
+2
-2
server-tools/instance-manager/instance.h
server-tools/instance-manager/instance.h
+1
-1
server-tools/instance-manager/instance_map.cc
server-tools/instance-manager/instance_map.cc
+2
-2
server-tools/instance-manager/instance_options.cc
server-tools/instance-manager/instance_options.cc
+115
-36
server-tools/instance-manager/instance_options.h
server-tools/instance-manager/instance_options.h
+11
-2
server-tools/instance-manager/listener.cc
server-tools/instance-manager/listener.cc
+1
-1
server-tools/instance-manager/log.cc
server-tools/instance-manager/log.cc
+1
-1
server-tools/instance-manager/options.cc
server-tools/instance-manager/options.cc
+1
-1
server-tools/instance-manager/parse_output.cc
server-tools/instance-manager/parse_output.cc
+27
-16
server-tools/instance-manager/parse_output.h
server-tools/instance-manager/parse_output.h
+4
-1
No files found.
server-tools/instance-manager/buffer.h
View file @
afd5975c
...
@@ -52,7 +52,7 @@ public:
...
@@ -52,7 +52,7 @@ public:
~
Buffer
()
~
Buffer
()
{
{
free
(
buffer
);
my_free
(
buffer
,
MYF
(
0
)
);
}
}
public:
public:
...
...
server-tools/instance-manager/commands.cc
View file @
afd5975c
...
@@ -203,15 +203,14 @@ int Show_instance_status::execute(struct st_net *net,
...
@@ -203,15 +203,14 @@ int Show_instance_status::execute(struct st_net *net,
if
(
!
(
instance
=
instance_map
->
find
(
instance_name
,
strlen
(
instance_name
))))
if
(
!
(
instance
=
instance_map
->
find
(
instance_name
,
strlen
(
instance_name
))))
goto
err
;
goto
err
;
if
(
instance
->
is_running
())
if
(
instance
->
is_running
())
{
store_to_string
(
&
send_buff
,
(
char
*
)
"online"
,
&
position
);
store_to_string
(
&
send_buff
,
(
char
*
)
"online"
,
&
position
);
store_to_string
(
&
send_buff
,
"unknown"
,
&
position
);
}
else
else
{
store_to_string
(
&
send_buff
,
(
char
*
)
"offline"
,
&
position
);
store_to_string
(
&
send_buff
,
(
char
*
)
"offline"
,
&
position
);
if
(
instance
->
options
.
mysqld_version
)
store_to_string
(
&
send_buff
,
instance
->
options
.
mysqld_version
,
&
position
);
else
store_to_string
(
&
send_buff
,
(
char
*
)
"unknown"
,
&
position
);
store_to_string
(
&
send_buff
,
(
char
*
)
"unknown"
,
&
position
);
}
if
(
send_buff
.
is_error
()
||
if
(
send_buff
.
is_error
()
||
...
@@ -645,10 +644,6 @@ Set_option::Set_option(Instance_map *instance_map_arg,
...
@@ -645,10 +644,6 @@ Set_option::Set_option(Instance_map *instance_map_arg,
{
{
strmake
(
option
,
option_arg
,
option_len_arg
);
strmake
(
option
,
option_arg
,
option_len_arg
);
strmake
(
option_value
,
option_value_arg
,
option_value_len_arg
);
strmake
(
option_value
,
option_value_arg
,
option_value_len_arg
);
/* strncpy(option, option_arg, option_len_arg);
option[option_len_arg]= 0;
strncpy(option_value, option_value_arg, option_value_len_arg);
option_value[option_value_len_arg]= 0; */
}
}
else
else
{
{
...
...
server-tools/instance-manager/instance.cc
View file @
afd5975c
...
@@ -326,8 +326,8 @@ int Instance::init(const char *name_arg)
...
@@ -326,8 +326,8 @@ int Instance::init(const char *name_arg)
int
Instance
::
complete_initialization
(
Instance_map
*
instance_map_arg
,
int
Instance
::
complete_initialization
(
Instance_map
*
instance_map_arg
,
const
char
*
mysqld_path
,
const
char
*
mysqld_path
,
int
only_instanc
e
)
uint
instance_typ
e
)
{
{
instance_map
=
instance_map_arg
;
instance_map
=
instance_map_arg
;
return
options
.
complete_initialization
(
mysqld_path
,
only_instanc
e
);
return
options
.
complete_initialization
(
mysqld_path
,
instance_typ
e
);
}
}
server-tools/instance-manager/instance.h
View file @
afd5975c
...
@@ -33,7 +33,7 @@ public:
...
@@ -33,7 +33,7 @@ public:
~
Instance
();
~
Instance
();
int
init
(
const
char
*
name
);
int
init
(
const
char
*
name
);
int
complete_initialization
(
Instance_map
*
instance_map_arg
,
int
complete_initialization
(
Instance_map
*
instance_map_arg
,
const
char
*
mysqld_path
,
int
only_instance
=
0
);
const
char
*
mysqld_path
,
uint
instance_type
);
bool
is_running
();
bool
is_running
();
int
start
();
int
start
();
...
...
server-tools/instance-manager/instance_map.cc
View file @
afd5975c
...
@@ -202,14 +202,14 @@ int Instance_map::complete_initialization()
...
@@ -202,14 +202,14 @@ int Instance_map::complete_initialization()
hash_free should handle it's deletion => goto err, not
hash_free should handle it's deletion => goto err, not
err_instance.
err_instance.
*/
*/
if
(
instance
->
complete_initialization
(
this
,
mysqld_path
,
1
))
if
(
instance
->
complete_initialization
(
this
,
mysqld_path
,
DEFAULT_SINGLE_INSTANCE
))
goto
err
;
goto
err
;
}
}
else
else
while
(
i
<
hash
.
records
)
while
(
i
<
hash
.
records
)
{
{
instance
=
(
Instance
*
)
hash_element
(
&
hash
,
i
);
instance
=
(
Instance
*
)
hash_element
(
&
hash
,
i
);
if
(
instance
->
complete_initialization
(
this
,
mysqld_path
))
if
(
instance
->
complete_initialization
(
this
,
mysqld_path
,
USUAL_INSTANCE
))
goto
err
;
goto
err
;
i
++
;
i
++
;
}
}
...
...
server-tools/instance-manager/instance_options.cc
View file @
afd5975c
...
@@ -27,6 +27,39 @@
...
@@ -27,6 +27,39 @@
#include <signal.h>
#include <signal.h>
#include <m_string.h>
#include <m_string.h>
#ifdef __WIN__
#define NEWLINE_LEN 2
#else
#define NEWLINE_LEN 1
#endif
/* Create "mysqld ..." command in the buffer */
static
inline
int
create_mysqld_command
(
Buffer
*
buf
,
const
char
*
mysqld_path_str
,
uint
mysqld_path_len
,
const
char
*
option
,
uint
option_len
)
{
int
position
=
0
;
if
(
buf
->
get_size
())
/* malloc succeeded */
{
buf
->
append
(
position
,
mysqld_path_str
,
mysqld_path_len
);
position
+=
mysqld_path_len
;
/* here the '\0' character is copied from the option string */
buf
->
append
(
position
,
option
,
option_len
);
if
(
buf
->
is_error
())
return
1
;
}
else
return
1
;
return
0
;
}
/*
/*
Get compiled-in value of default_option
Get compiled-in value of default_option
...
@@ -50,44 +83,82 @@
...
@@ -50,44 +83,82 @@
int
Instance_options
::
get_default_option
(
char
*
result
,
size_t
result_len
,
int
Instance_options
::
get_default_option
(
char
*
result
,
size_t
result_len
,
const
char
*
option_name
)
const
char
*
option_name
)
{
{
int
position
=
0
;
int
rc
=
1
;
int
rc
=
1
;
char
verbose_option
[]
=
" --no-defaults --verbose --help"
;
char
verbose_option
[]
=
" --no-defaults --verbose --help"
;
Buffer
cmd
(
strlen
(
mysqld_path
)
+
sizeof
(
verbose_option
)
+
1
);
/* reserve space fot the path + option + final '\0' */
if
(
cmd
.
get_size
())
/* malloc succeeded */
Buffer
cmd
(
mysqld_path_len
+
sizeof
(
verbose_option
));
{
cmd
.
append
(
position
,
mysqld_path
,
strlen
(
mysqld_path
));
position
+=
strlen
(
mysqld_path
);
cmd
.
append
(
position
,
verbose_option
,
sizeof
(
verbose_option
)
-
1
);
position
+=
sizeof
(
verbose_option
)
-
1
;
cmd
.
append
(
position
,
"
\0
"
,
1
);
if
(
cmd
.
is_error
())
if
(
create_mysqld_command
(
&
cmd
,
mysqld_path
,
mysqld_path_len
,
verbose_option
,
sizeof
(
verbose_option
)))
goto
err
;
goto
err
;
/* get the value from "mysqld --help --verbose" */
/* +2 eats first "--" from the option string (E.g. "--datadir") */
rc
=
parse_output_and_get_value
(
cmd
.
buffer
,
option_name
+
2
,
rc
=
parse_output_and_get_value
(
cmd
.
buffer
,
option_name
+
2
,
result
,
result_len
);
result
,
result_len
,
GET_VALUE
);
return
rc
;
err:
return
1
;
}
/*
Fill mysqld_version option (used at initialization stage)
SYNOPSYS
fill_instance_version()
DESCRIPTION
Get mysqld version string from "mysqld --version" output.
RETURN
0 - ok
1 - error occured
*/
int
Instance_options
::
fill_instance_version
()
{
enum
{
MAX_VERSION_STRING_LENGTH
=
160
};
char
result
[
MAX_VERSION_STRING_LENGTH
];
char
version_option
[]
=
" --no-defaults --version"
;
int
rc
=
1
;
Buffer
cmd
(
mysqld_path_len
+
sizeof
(
version_option
));
if
(
create_mysqld_command
(
&
cmd
,
mysqld_path
,
mysqld_path_len
,
version_option
,
sizeof
(
version_option
)))
goto
err
;
rc
=
parse_output_and_get_value
(
cmd
.
buffer
,
mysqld_path
,
result
,
MAX_VERSION_STRING_LENGTH
,
GET_LINE
);
if
(
*
result
!=
'\0'
)
{
/* chop the newline from the end of the version string */
result
[
strlen
(
result
)
-
NEWLINE_LEN
]
=
'\0'
;
mysqld_version
=
strdup_root
(
&
alloc
,
result
);
}
}
return
rc
;
return
rc
;
err:
err:
return
1
;
return
1
;
}
}
/*
/*
Get compiled-in value of default_option
Fill various log options
SYNOPSYS
SYNOPSYS
get_default_option()
fill_log_options()
result buffer to put found value
result_len buffer size
option_name the name of the option, prefixed with "--"
DESCRIPTION
DESCRIPTION
Get compile-in value of requested option from server
Compute paths to enabled log files. If the path is not specified in the
instance explicitly (I.e. log=/home/user/mysql.log), we try to guess the
file name and placement.
RETURN
RETURN
0 - ok
0 - ok
...
@@ -126,8 +197,8 @@ int Instance_options::fill_log_options()
...
@@ -126,8 +197,8 @@ int Instance_options::fill_log_options()
goto
err
;
goto
err
;
}
}
else
/* below is safe, as --datadir always has a value */
else
/* below is safe, as --datadir always has a value */
str
ncpy
(
datadir
,
strchr
(
mysqld_datadir
,
'='
)
+
1
,
str
make
(
datadir
,
strchr
(
mysqld_datadir
,
'='
)
+
1
,
MAX_LOG_OPTION_LENGTH
);
MAX_LOG_OPTION_LENGTH
-
1
);
if
(
gethostname
(
hostname
,
sizeof
(
hostname
)
-
1
)
<
0
)
if
(
gethostname
(
hostname
,
sizeof
(
hostname
)
-
1
)
<
0
)
strmov
(
hostname
,
"mysql"
);
strmov
(
hostname
,
"mysql"
);
...
@@ -160,7 +231,7 @@ int Instance_options::fill_log_options()
...
@@ -160,7 +231,7 @@ int Instance_options::fill_log_options()
if
((
MAX_LOG_OPTION_LENGTH
-
strlen
(
full_name
))
>
if
((
MAX_LOG_OPTION_LENGTH
-
strlen
(
full_name
))
>
strlen
(
log_files
->
default_suffix
))
strlen
(
log_files
->
default_suffix
))
{
{
str
cpy
(
full_name
+
strlen
(
full_name
),
str
mov
(
full_name
+
strlen
(
full_name
),
log_files
->
default_suffix
);
log_files
->
default_suffix
);
}
}
else
else
...
@@ -266,7 +337,7 @@ pid_t Instance_options::get_pid()
...
@@ -266,7 +337,7 @@ pid_t Instance_options::get_pid()
int
Instance_options
::
complete_initialization
(
const
char
*
default_path
,
int
Instance_options
::
complete_initialization
(
const
char
*
default_path
,
int
only_instanc
e
)
uint
instance_typ
e
)
{
{
const
char
*
tmp
;
const
char
*
tmp
;
...
@@ -276,6 +347,8 @@ int Instance_options::complete_initialization(const char *default_path,
...
@@ -276,6 +347,8 @@ int Instance_options::complete_initialization(const char *default_path,
goto
err
;
goto
err
;
}
}
mysqld_path_len
=
strlen
(
mysqld_path
);
if
(
mysqld_port
)
if
(
mysqld_port
)
mysqld_port_val
=
atoi
(
strchr
(
mysqld_port
,
'='
)
+
1
);
mysqld_port_val
=
atoi
(
strchr
(
mysqld_port
,
'='
)
+
1
);
...
@@ -295,18 +368,23 @@ int Instance_options::complete_initialization(const char *default_path,
...
@@ -295,18 +368,23 @@ int Instance_options::complete_initialization(const char *default_path,
found, we would like to model mysqld pid file values.
found, we would like to model mysqld pid file values.
*/
*/
if
(
!
gethostname
(
hostname
,
sizeof
(
hostname
)
-
1
))
if
(
!
gethostname
(
hostname
,
sizeof
(
hostname
)
-
1
))
(
only_instance
==
0
)
?
{
if
(
instance_type
&
DEFAULT_SINGLE_INSTANCE
)
strxnmov
(
pidfilename
,
MAX_PATH_LEN
-
1
,
"--pid-file="
,
instance_name
,
"-"
,
strxnmov
(
pidfilename
,
MAX_PATH_LEN
-
1
,
"--pid-file="
,
instance_name
,
"-"
,
hostname
,
".pid"
,
NullS
)
:
hostname
,
".pid"
,
NullS
);
else
strxnmov
(
pidfilename
,
MAX_PATH_LEN
-
1
,
"--pid-file="
,
hostname
,
strxnmov
(
pidfilename
,
MAX_PATH_LEN
-
1
,
"--pid-file="
,
hostname
,
".pid"
,
NullS
);
".pid"
,
NullS
);
}
else
else
(
only_instance
==
0
)
?
{
if
(
instance_type
&
DEFAULT_SINGLE_INSTANCE
)
strxnmov
(
pidfilename
,
MAX_PATH_LEN
-
1
,
"--pid-file="
,
instance_name
,
strxnmov
(
pidfilename
,
MAX_PATH_LEN
-
1
,
"--pid-file="
,
instance_name
,
".pid"
,
NullS
)
:
".pid"
,
NullS
);
else
strxnmov
(
pidfilename
,
MAX_PATH_LEN
-
1
,
"--pid-file="
,
"mysql"
,
strxnmov
(
pidfilename
,
MAX_PATH_LEN
-
1
,
"--pid-file="
,
"mysql"
,
".pid"
,
NullS
);
".pid"
,
NullS
);
}
add_option
(
pidfilename
);
add_option
(
pidfilename
);
}
}
...
@@ -330,7 +408,8 @@ int Instance_options::complete_initialization(const char *default_path,
...
@@ -330,7 +408,8 @@ int Instance_options::complete_initialization(const char *default_path,
options_array
.
elements
*
sizeof
(
char
*
));
options_array
.
elements
*
sizeof
(
char
*
));
argv
[
filled_default_options
+
options_array
.
elements
]
=
0
;
argv
[
filled_default_options
+
options_array
.
elements
]
=
0
;
fill_log_options
();
if
(
fill_log_options
()
||
fill_instance_version
())
goto
err
;
return
0
;
return
0
;
...
...
server-tools/instance-manager/instance_options.h
View file @
afd5975c
...
@@ -34,18 +34,20 @@
...
@@ -34,18 +34,20 @@
don't have to synchronize between threads.
don't have to synchronize between threads.
*/
*/
enum
{
USUAL_INSTANCE
=
0
,
DEFAULT_SINGLE_INSTANCE
};
class
Instance_options
class
Instance_options
{
{
public:
public:
Instance_options
()
:
Instance_options
()
:
mysqld_socket
(
0
),
mysqld_datadir
(
0
),
mysqld_
version
(
0
),
mysqld_
socket
(
0
),
mysqld_datadir
(
0
),
mysqld_bind_address
(
0
),
mysqld_pid_file
(
0
),
mysqld_port
(
0
),
mysqld_bind_address
(
0
),
mysqld_pid_file
(
0
),
mysqld_port
(
0
),
mysqld_port_val
(
0
),
mysqld_path
(
0
),
nonguarded
(
0
),
shutdown_delay
(
0
),
mysqld_port_val
(
0
),
mysqld_path
(
0
),
nonguarded
(
0
),
shutdown_delay
(
0
),
shutdown_delay_val
(
0
),
filled_default_options
(
0
)
shutdown_delay_val
(
0
),
filled_default_options
(
0
)
{}
{}
~
Instance_options
();
~
Instance_options
();
/* fills in argv */
/* fills in argv */
int
complete_initialization
(
const
char
*
default_path
,
int
only_instanc
e
);
int
complete_initialization
(
const
char
*
default_path
,
uint
instance_typ
e
);
int
add_option
(
const
char
*
option
);
int
add_option
(
const
char
*
option
);
int
init
(
const
char
*
instance_name_arg
);
int
init
(
const
char
*
instance_name_arg
);
...
@@ -64,6 +66,11 @@ public:
...
@@ -64,6 +66,11 @@ public:
enum
{
MEM_ROOT_BLOCK_SIZE
=
512
};
enum
{
MEM_ROOT_BLOCK_SIZE
=
512
};
char
pid_file_with_path
[
MAX_PATH_LEN
];
char
pid_file_with_path
[
MAX_PATH_LEN
];
char
**
argv
;
char
**
argv
;
/*
Here we cache the version string, obtained from mysqld --version.
In the case when mysqld binary is not found we get NULL here.
*/
const
char
*
mysqld_version
;
/* We need the some options, so we store them as a separate pointers */
/* We need the some options, so we store them as a separate pointers */
const
char
*
mysqld_socket
;
const
char
*
mysqld_socket
;
const
char
*
mysqld_datadir
;
const
char
*
mysqld_datadir
;
...
@@ -74,6 +81,7 @@ public:
...
@@ -74,6 +81,7 @@ public:
const
char
*
instance_name
;
const
char
*
instance_name
;
uint
instance_name_len
;
uint
instance_name_len
;
const
char
*
mysqld_path
;
const
char
*
mysqld_path
;
uint
mysqld_path_len
;
const
char
*
nonguarded
;
const
char
*
nonguarded
;
const
char
*
shutdown_delay
;
const
char
*
shutdown_delay
;
uint
shutdown_delay_val
;
uint
shutdown_delay_val
;
...
@@ -84,6 +92,7 @@ public:
...
@@ -84,6 +92,7 @@ public:
DYNAMIC_ARRAY
options_array
;
DYNAMIC_ARRAY
options_array
;
private:
private:
int
fill_log_options
();
int
fill_log_options
();
int
fill_instance_version
();
int
add_to_argv
(
const
char
*
option
);
int
add_to_argv
(
const
char
*
option
);
int
get_default_option
(
char
*
result
,
size_t
result_len
,
int
get_default_option
(
char
*
result
,
size_t
result_len
,
const
char
*
option_name
);
const
char
*
option_name
);
...
...
server-tools/instance-manager/listener.cc
View file @
afd5975c
...
@@ -163,7 +163,7 @@ void Listener_thread::run()
...
@@ -163,7 +163,7 @@ void Listener_thread::run()
unix_socket_address
.
sun_family
=
AF_UNIX
;
unix_socket_address
.
sun_family
=
AF_UNIX
;
strmake
(
unix_socket_address
.
sun_path
,
options
.
socket_file_name
,
strmake
(
unix_socket_address
.
sun_path
,
options
.
socket_file_name
,
sizeof
(
unix_socket_address
.
sun_path
));
sizeof
(
unix_socket_address
.
sun_path
));
unlink
(
unix_socket_address
.
sun_path
);
/
/ in case we have stale socket file
unlink
(
unix_socket_address
.
sun_path
);
/
* in case we have stale socket file */
{
{
/*
/*
...
...
server-tools/instance-manager/log.cc
View file @
afd5975c
...
@@ -76,7 +76,7 @@ static inline void log(FILE *file, const char *format, va_list args)
...
@@ -76,7 +76,7 @@ static inline void log(FILE *file, const char *format, va_list args)
if
(
buff_msg
==
0
)
if
(
buff_msg
==
0
)
{
{
strmake
(
buff_stack
,
"log(): message is too big, my_malloc() failed"
,
strmake
(
buff_stack
,
"log(): message is too big, my_malloc() failed"
,
sizeof
(
buff_stack
));
sizeof
(
buff_stack
)
-
1
);
buff_msg
=
buff_stack
;
buff_msg
=
buff_stack
;
break
;
break
;
}
}
...
...
server-tools/instance-manager/options.cc
View file @
afd5975c
...
@@ -224,10 +224,10 @@ int Options::load(int argc, char **argv)
...
@@ -224,10 +224,10 @@ int Options::load(int argc, char **argv)
/* config-file options are prepended to command-line ones */
/* config-file options are prepended to command-line ones */
load_defaults
(
"my"
,
default_groups
,
&
argc
,
&
argv
);
load_defaults
(
"my"
,
default_groups
,
&
argc
,
&
argv
);
Options
::
saved_argv
=
argv
;
if
((
rc
=
handle_options
(
&
argc
,
&
argv
,
my_long_options
,
get_one_option
))
!=
0
)
if
((
rc
=
handle_options
(
&
argc
,
&
argv
,
my_long_options
,
get_one_option
))
!=
0
)
return
rc
;
return
rc
;
Options
::
saved_argv
=
argv
;
return
0
;
return
0
;
}
}
...
...
server-tools/instance-manager/parse_output.cc
View file @
afd5975c
...
@@ -16,10 +16,11 @@
...
@@ -16,10 +16,11 @@
#include <my_global.h>
#include <my_global.h>
#include "parse.h"
#include "parse.h"
#include "parse_output.h"
#include <stdio.h>
#include <stdio.h>
#include <my_sys.h>
#include <my_sys.h>
#include <string.h>
#include <
m_
string.h>
/*
/*
...
@@ -31,11 +32,14 @@
...
@@ -31,11 +32,14 @@
command the command to execue with popen.
command the command to execue with popen.
word the word to look for (usually an option name)
word the word to look for (usually an option name)
result the buffer to store the next word (option value)
result the buffer to store the next word (option value)
result_len self-explanatory
input_buffer_len self-explanatory
flag this equals to GET_LINE if we want to get all the line after
the matched word and GET_VALUE otherwise.
DESCRIPTION
DESCRIPTION
Parse output of the "command". Find the "word" and return the next one
Parse output of the "command". Find the "word" and return the next one
if flag is GET_VALUE. Return the rest of the parsed string otherwise.
RETURN
RETURN
0 - ok
0 - ok
...
@@ -43,7 +47,8 @@
...
@@ -43,7 +47,8 @@
*/
*/
int
parse_output_and_get_value
(
const
char
*
command
,
const
char
*
word
,
int
parse_output_and_get_value
(
const
char
*
command
,
const
char
*
word
,
char
*
result
,
size_t
result_len
)
char
*
result
,
size_t
input_buffer_len
,
uint
flag
)
{
{
FILE
*
output
;
FILE
*
output
;
uint
wordlen
;
uint
wordlen
;
...
@@ -64,7 +69,7 @@ int parse_output_and_get_value(const char *command, const char *word,
...
@@ -64,7 +69,7 @@ int parse_output_and_get_value(const char *command, const char *word,
while
(
fgets
(
linebuf
,
sizeof
(
linebuf
)
-
1
,
output
))
while
(
fgets
(
linebuf
,
sizeof
(
linebuf
)
-
1
,
output
))
{
{
uint
line
word_len
=
0
;
uint
found_
word_len
=
0
;
char
*
linep
=
linebuf
;
char
*
linep
=
linebuf
;
linebuf
[
sizeof
(
linebuf
)
-
1
]
=
'\0'
;
/* safety */
linebuf
[
sizeof
(
linebuf
)
-
1
]
=
'\0'
;
/* safety */
...
@@ -73,19 +78,25 @@ int parse_output_and_get_value(const char *command, const char *word,
...
@@ -73,19 +78,25 @@ int parse_output_and_get_value(const char *command, const char *word,
Get the word, which might contain non-alphanumeric characters. (Usually
Get the word, which might contain non-alphanumeric characters. (Usually
these are '/', '-' and '.' in the path expressions and filenames)
these are '/', '-' and '.' in the path expressions and filenames)
*/
*/
get_word
((
const
char
**
)
&
linep
,
&
line
word_len
,
NONSPACE
);
get_word
((
const
char
**
)
&
linep
,
&
found_
word_len
,
NONSPACE
);
if
(
!
strncmp
(
word
,
linep
,
wordlen
))
if
(
!
strncmp
(
word
,
linep
,
wordlen
))
{
{
/*
/*
If we have found the word, return the next one
. T
his is usually
If we have found the word, return the next one
(t
his is usually
an option value
.
an option value
) or the whole line (if flag)
*/
*/
linep
+=
lineword_len
;
/* swallow the previous one */
linep
+=
found_word_len
;
/* swallow the previous one */
get_word
((
const
char
**
)
&
linep
,
&
lineword_len
,
NONSPACE
);
if
(
flag
&
GET_VALUE
)
/* not GET_LINE */
if
(
result_len
<=
lineword_len
)
{
get_word
((
const
char
**
)
&
linep
,
&
found_word_len
,
NONSPACE
);
if
(
input_buffer_len
<=
found_word_len
)
goto
err
;
goto
err
;
strncpy
(
result
,
linep
,
lineword_len
);
strmake
(
result
,
linep
,
found_word_len
);
result
[
lineword_len
]
=
'\0'
;
}
else
/* currently there are only two options */
{
strmake
(
result
,
linep
,
input_buffer_len
-
1
);
}
goto
pclose
;
goto
pclose
;
}
}
}
}
...
...
server-tools/instance-manager/parse_output.h
View file @
afd5975c
...
@@ -16,7 +16,10 @@
...
@@ -16,7 +16,10 @@
along with this program; if not, write to the Free Software
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
enum
{
GET_VALUE
=
1
,
GET_LINE
};
int
parse_output_and_get_value
(
const
char
*
command
,
const
char
*
word
,
int
parse_output_and_get_value
(
const
char
*
command
,
const
char
*
word
,
char
*
result
,
size_t
result_len
);
char
*
result
,
size_t
input_buffer_len
,
uint
flag
);
#endif
/* INCLUDES_MYSQL_INSTANCE_MANAGER_PARSE_OUTPUT_H */
#endif
/* INCLUDES_MYSQL_INSTANCE_MANAGER_PARSE_OUTPUT_H */
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment