diff options
author | unknown <reggie@fedora.(none)> | 2005-10-31 13:31:06 -0500 |
---|---|---|
committer | unknown <reggie@fedora.(none)> | 2005-10-31 13:31:06 -0500 |
commit | 0125760fc86c6f0621e696c3384a2c0b3d7dd195 (patch) | |
tree | 64bbde3c4a6d3de2054e56588e1568409ea3b5b2 /server-tools/instance-manager/parse_output.cc | |
parent | 11632315c8493725bc80b160dfd3036f15b5a2cf (diff) | |
download | mariadb-git-0125760fc86c6f0621e696c3384a2c0b3d7dd195.tar.gz |
fix some issues with IM and long pathnames (with spaces)
server-tools/instance-manager/instance_options.cc:
small cleanup
-and-
convert mysqld_path to the proper syntax after reading
server-tools/instance-manager/parse_output.cc:
stop using get_word since it stops at spaces. Now we just read the entire line and trim spaces.
Diffstat (limited to 'server-tools/instance-manager/parse_output.cc')
-rw-r--r-- | server-tools/instance-manager/parse_output.cc | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/server-tools/instance-manager/parse_output.cc b/server-tools/instance-manager/parse_output.cc index b5af3cb83a7..96b0b0fbbc6 100644 --- a/server-tools/instance-manager/parse_output.cc +++ b/server-tools/instance-manager/parse_output.cc @@ -24,6 +24,20 @@ #include "portability.h" +void trim_space(const char **text, uint *word_len) +{ + const char* start = *text; + while (*start != 0 && *start == ' ') + start++; + *text = start; + + int len= strlen(start); + const char* end= start + len - 1; + while (end > start && (*end == ' ' || *end == '\r' || *end == '\n')) + end--; + *word_len= (end - start)+1; +} + /* Parse output of the given command @@ -85,14 +99,13 @@ int parse_output_and_get_value(const char *command, const char *word, Get the word, which might contain non-alphanumeric characters. (Usually these are '/', '-' and '.' in the path expressions and filenames) */ - get_word((const char **) &linep, &found_word_len, NONSPACE); if (!strncmp(word, linep, wordlen)) { /* If we have found the word, return the next one (this is usually an option value) or the whole line (if flag) */ - linep+= found_word_len; /* swallow the previous one */ + linep+= wordlen; /* swallow the previous one */ if (flag & GET_VALUE) { get_word((const char **) &linep, &found_word_len, NONSPACE); |