mirror of
https://github.com/MariaDB/server.git
synced 2025-08-01 03:47:19 +03:00
Post-review fixes + some bugs fixed + several minor features
BitKeeper/deleted/.del-client_func.c~3476a8a85cbd3c29: Delete: server-tools/instance-manager/client_func.c server-tools/instance-manager/Makefile.am: clien_func removed server-tools/instance-manager/buffer.cc: several methods added server-tools/instance-manager/buffer.h: Some error-handling fixes. server-tools/instance-manager/commands.cc: check for Buffer errors server-tools/instance-manager/guardian.cc: Guardian rewiriten. Not it works in a finite state machine-way. server-tools/instance-manager/guardian.h: Appropriate (to .cc) changes in the header + some comment added server-tools/instance-manager/instance.cc: added proxy thread to monitor instance. Two kinds of stop() now -- stop() and kill_instance which only sends a signal server-tools/instance-manager/instance.h: appropriate changes server-tools/instance-manager/instance_map.cc: cleanup server-tools/instance-manager/instance_map.h: cleanup server-tools/instance-manager/instance_options.cc: Caching of the pid-file-name is added. some comments added server-tools/instance-manager/instance_options.h: cleanup server-tools/instance-manager/listener.cc: listener my_thread_init added (though it doesn't use any mysys functions). Just in case server-tools/instance-manager/manager.cc: SIGCHLD handler removed. now instance monitoring is implemented through proxy threads. This is to work nicely with LinuxThreads server-tools/instance-manager/options.cc: added option to create a password file entry (this was implemented by Sergei Vojtovich) server-tools/instance-manager/parse.cc: inline function get_word moved to the header server-tools/instance-manager/parse.h: get_word moved here to use form parse_output server-tools/instance-manager/parse_output.cc: get_word() clone removed. now looking through the output linewise server-tools/instance-manager/protocol.cc: Buffer error chech added server-tools/instance-manager/user_map.cc: typo fixed
This commit is contained in:
@ -14,43 +14,38 @@
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
||||
|
||||
#include "parse.h"
|
||||
|
||||
#include <stdio.h>
|
||||
#include <my_global.h>
|
||||
#include <my_sys.h>
|
||||
#include <string.h>
|
||||
|
||||
/* buf should be of appropriate size. Otherwise the word will be truncated */
|
||||
static int get_word(FILE *file, char *buf, size_t size)
|
||||
{
|
||||
int currchar;
|
||||
|
||||
currchar= getc(file);
|
||||
/*
|
||||
Parse output of the given command
|
||||
|
||||
/* skip space */
|
||||
while (my_isspace(default_charset_info, (char) currchar) &&
|
||||
currchar != EOF && size > 1)
|
||||
{
|
||||
currchar= getc(file);
|
||||
}
|
||||
SYNOPSYS
|
||||
parse_output_and_get_value()
|
||||
|
||||
while (!my_isspace(default_charset_info, (char) currchar) &&
|
||||
currchar != EOF && size > 1)
|
||||
{
|
||||
*buf++= (char) currchar;
|
||||
currchar= getc(file);
|
||||
size--;
|
||||
}
|
||||
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)
|
||||
result_len self-explanatory
|
||||
|
||||
*buf= '\0';
|
||||
return 0;
|
||||
}
|
||||
DESCRIPTION
|
||||
|
||||
Parse output of the "command". Find the "word" and return the next one
|
||||
*/
|
||||
|
||||
int parse_output_and_get_value(const char *command, const char *word,
|
||||
char *result, size_t result_len)
|
||||
{
|
||||
FILE *output;
|
||||
int wordlen;
|
||||
uint wordlen;
|
||||
/* should be enought to store the string from the output */
|
||||
enum { MAX_LINE_LEN= 512 };
|
||||
char linebuf[MAX_LINE_LEN];
|
||||
|
||||
wordlen= strlen(word);
|
||||
|
||||
@ -62,19 +57,32 @@ int parse_output_and_get_value(const char *command, const char *word,
|
||||
*/
|
||||
setvbuf(output, NULL, _IOFBF, 0);
|
||||
|
||||
get_word(output, result, result_len);
|
||||
while (strncmp(word, result, wordlen) && *result != '\0')
|
||||
while (fgets(linebuf, sizeof(linebuf) - 1, output))
|
||||
{
|
||||
get_word(output, result, result_len);
|
||||
uint lineword_len= 0;
|
||||
char *linep= linebuf;
|
||||
|
||||
linebuf[sizeof(linebuf) - 1]= '\0'; /* safety */
|
||||
|
||||
/*
|
||||
Get the word, which might contain non-alphanumeric characters. (Usually
|
||||
these are '/', '-' and '.' in the path expressions and filenames)
|
||||
*/
|
||||
get_word((const char **) &linep, &lineword_len, NONSPACE);
|
||||
if (!strncmp(word, linep, wordlen) && *result != '\0')
|
||||
{
|
||||
/*
|
||||
If we have found the word, return the next one. This is usually
|
||||
an option value.
|
||||
*/
|
||||
get_word((const char **) &linep, &lineword_len, NONSPACE);
|
||||
DBUG_ASSERT(result_len > lineword_len);
|
||||
strncpy(result, linep, lineword_len);
|
||||
goto pclose;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
If we have found the word, return the next one. This is usually
|
||||
an option value.
|
||||
*/
|
||||
if (*result != '\0')
|
||||
get_word(output, result, result_len);
|
||||
|
||||
pclose:
|
||||
if (pclose(output))
|
||||
return 1;
|
||||
|
||||
|
Reference in New Issue
Block a user