2005-01-25 13:54:56 +03:00
|
|
|
/* Copyright (C) 2004 MySQL AB
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
|
2005-06-07 15:47:02 +04:00
|
|
|
#include "parse_output.h"
|
2005-02-11 14:21:59 +03:00
|
|
|
|
2006-05-18 18:57:50 +04:00
|
|
|
#include <my_global.h>
|
2005-01-25 13:54:56 +03:00
|
|
|
#include <my_sys.h>
|
2005-06-07 15:47:02 +04:00
|
|
|
#include <m_string.h>
|
2006-05-18 18:57:50 +04:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
#include "parse.h"
|
2005-08-05 20:44:52 +02:00
|
|
|
#include "portability.h"
|
2005-01-25 13:54:56 +03:00
|
|
|
|
|
|
|
|
2005-10-31 13:31:06 -05:00
|
|
|
void trim_space(const char **text, uint *word_len)
|
|
|
|
{
|
2005-11-02 09:30:01 -06:00
|
|
|
const char *start= *text;
|
2005-10-31 13:31:07 -05:00
|
|
|
while (*start != 0 && *start == ' ')
|
|
|
|
start++;
|
|
|
|
*text= start;
|
|
|
|
|
|
|
|
int len= strlen(start);
|
2005-11-02 09:30:01 -06:00
|
|
|
const char *end= start + len - 1;
|
2005-11-02 06:51:44 -06:00
|
|
|
while (end > start && my_isspace(&my_charset_latin1, *end))
|
2005-10-31 13:31:07 -05:00
|
|
|
end--;
|
|
|
|
*word_len= (end - start)+1;
|
2005-10-31 13:31:06 -05:00
|
|
|
}
|
|
|
|
|
2005-02-11 14:21:59 +03:00
|
|
|
/*
|
|
|
|
Parse output of the given command
|
2005-01-25 13:54:56 +03:00
|
|
|
|
Port cleanups, trivial refactoring and code rearrangements from
Alik's patch for BUG#22306: STOP INSTANCE can not be applied for
instances in Crashed, Failed and Abandoned" to ease review process.
Evaluate global variable linuxthreads before starting threads to avoid
a race.
server-tools/instance-manager/buffer.cc:
Fix spelling.
server-tools/instance-manager/command.h:
Fix spelling.
server-tools/instance-manager/commands.cc:
Fix spelling.
server-tools/instance-manager/commands.h:
Fix spelling, tidy up.
server-tools/instance-manager/guardian.cc:
Cleanup logging, options.get_shutdown_delay() is a method, tidy up.
server-tools/instance-manager/instance.cc:
Rearrange methods to be the same as in Alik's patch, fix spelling errors,
clean up logging texts, port comments from Alik's patch,
implement some basic renames from his patch.
No real changes.
server-tools/instance-manager/instance.h:
Tidy up, renames.
server-tools/instance-manager/instance_map.cc:
Fix spellings, port some refactoring from Alik's patch.
server-tools/instance-manager/instance_map.h:
Cleanup.
server-tools/instance-manager/instance_options.cc:
Cleanup. Implement Instance_options::get_shutdown_delay() and
Instance_options::get_mysqld_port().
server-tools/instance-manager/instance_options.h:
Cleanup.
server-tools/instance-manager/listener.cc:
Cleanup.
server-tools/instance-manager/log.cc:
Fix spelling.
server-tools/instance-manager/manager.cc:
Cleanup.
server-tools/instance-manager/manager.h:
Add getters for Manager members.
server-tools/instance-manager/mysqlmanager.cc:
Evaluate linuxthreads before starting threads to avoid a race.
server-tools/instance-manager/parse_output.cc:
Fix spelling.
server-tools/instance-manager/priv.cc:
Cleanup.
server-tools/instance-manager/priv.h:
Cleanup.
server-tools/instance-manager/user_management_commands.cc:
Fix spelling.
server-tools/instance-manager/user_management_commands.h:
Fix spelling.
server-tools/instance-manager/user_map.cc:
Fix spelling.
2006-11-18 01:34:44 +03:00
|
|
|
SYNOPSIS
|
2005-02-11 14:21:59 +03:00
|
|
|
parse_output_and_get_value()
|
2005-01-25 13:54:56 +03:00
|
|
|
|
2005-06-07 15:47:02 +04:00
|
|
|
command the command to execue with popen.
|
|
|
|
word the word to look for (usually an option name)
|
|
|
|
result the buffer to store the next word (option value)
|
|
|
|
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.
|
2005-01-25 13:54:56 +03:00
|
|
|
|
2005-02-11 14:21:59 +03:00
|
|
|
DESCRIPTION
|
2005-01-25 13:54:56 +03:00
|
|
|
|
2005-02-11 14:21:59 +03:00
|
|
|
Parse output of the "command". Find the "word" and return the next one
|
2005-06-07 15:47:02 +04:00
|
|
|
if flag is GET_VALUE. Return the rest of the parsed string otherwise.
|
2005-02-13 15:13:33 +03:00
|
|
|
|
|
|
|
RETURN
|
2005-08-29 23:29:35 +04:00
|
|
|
0 - ok, the word has been found
|
|
|
|
1 - error occured or the word is not found
|
2005-02-11 14:21:59 +03:00
|
|
|
*/
|
2005-01-25 13:54:56 +03:00
|
|
|
|
|
|
|
int parse_output_and_get_value(const char *command, const char *word,
|
2005-06-07 15:47:02 +04:00
|
|
|
char *result, size_t input_buffer_len,
|
|
|
|
uint flag)
|
2005-01-25 13:54:56 +03:00
|
|
|
{
|
|
|
|
FILE *output;
|
2005-02-11 14:21:59 +03:00
|
|
|
uint wordlen;
|
2005-04-09 14:28:39 +04:00
|
|
|
/* should be enough to store the string from the output */
|
2005-02-11 14:21:59 +03:00
|
|
|
enum { MAX_LINE_LEN= 512 };
|
|
|
|
char linebuf[MAX_LINE_LEN];
|
2005-08-29 23:29:35 +04:00
|
|
|
int rc= 1;
|
2005-01-25 13:54:56 +03:00
|
|
|
|
|
|
|
wordlen= strlen(word);
|
|
|
|
|
2005-08-29 23:29:35 +04:00
|
|
|
/*
|
|
|
|
Successful return of popen does not tell us whether the command has been
|
|
|
|
executed successfully: if the command was not found, we'll get EOF
|
|
|
|
when reading the output buffer below.
|
|
|
|
*/
|
2005-02-27 18:41:34 +03:00
|
|
|
if (!(output= popen(command, "r")))
|
2005-02-13 15:13:33 +03:00
|
|
|
goto err;
|
2005-01-25 13:54:56 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
We want fully buffered stream. We also want system to
|
|
|
|
allocate appropriate buffer.
|
|
|
|
*/
|
|
|
|
setvbuf(output, NULL, _IOFBF, 0);
|
|
|
|
|
2005-02-11 14:21:59 +03:00
|
|
|
while (fgets(linebuf, sizeof(linebuf) - 1, output))
|
2005-01-25 13:54:56 +03:00
|
|
|
{
|
2005-06-07 15:47:02 +04:00
|
|
|
uint found_word_len= 0;
|
2005-02-11 14:21:59 +03:00
|
|
|
char *linep= linebuf;
|
|
|
|
|
|
|
|
linebuf[sizeof(linebuf) - 1]= '\0'; /* safety */
|
|
|
|
|
|
|
|
/*
|
2006-04-17 09:38:50 -07:00
|
|
|
Find the word(s) we are looking for in the line
|
2005-02-11 14:21:59 +03:00
|
|
|
*/
|
2006-04-17 09:38:50 -07:00
|
|
|
if ((linep= strstr(linep, word)))
|
2005-02-11 14:21:59 +03:00
|
|
|
{
|
|
|
|
/*
|
2005-11-02 06:51:44 -06:00
|
|
|
If we have found our word(s), then move linep past the word(s)
|
2005-02-11 14:21:59 +03:00
|
|
|
*/
|
2006-04-17 09:38:50 -07:00
|
|
|
linep+= wordlen;
|
2005-06-07 17:57:20 +04:00
|
|
|
if (flag & GET_VALUE)
|
2005-06-01 04:40:22 +04:00
|
|
|
{
|
2005-11-02 06:51:44 -06:00
|
|
|
trim_space((const char**) &linep, &found_word_len);
|
2005-06-07 15:47:02 +04:00
|
|
|
if (input_buffer_len <= found_word_len)
|
2005-06-01 04:40:22 +04:00
|
|
|
goto err;
|
2005-06-07 15:47:02 +04:00
|
|
|
strmake(result, linep, found_word_len);
|
2005-06-01 04:40:22 +04:00
|
|
|
}
|
2005-06-07 15:47:02 +04:00
|
|
|
else /* currently there are only two options */
|
|
|
|
strmake(result, linep, input_buffer_len - 1);
|
2005-08-29 23:29:35 +04:00
|
|
|
rc= 0;
|
|
|
|
break;
|
2005-02-11 14:21:59 +03:00
|
|
|
}
|
2005-01-25 13:54:56 +03:00
|
|
|
}
|
|
|
|
|
2005-02-15 04:38:33 +03:00
|
|
|
/* we are not interested in the termination status */
|
|
|
|
pclose(output);
|
2005-01-25 13:54:56 +03:00
|
|
|
|
2005-02-13 15:13:33 +03:00
|
|
|
err:
|
2005-08-29 23:29:35 +04:00
|
|
|
return rc;
|
2005-01-25 13:54:56 +03:00
|
|
|
}
|
2005-04-09 14:28:39 +04:00
|
|
|
|