summaryrefslogtreecommitdiff
path: root/server-tools/instance-manager/parse_output.cc
diff options
context:
space:
mode:
authorunknown <reggie@fedora.(none)>2005-10-31 13:31:06 -0500
committerunknown <reggie@fedora.(none)>2005-10-31 13:31:06 -0500
commit0125760fc86c6f0621e696c3384a2c0b3d7dd195 (patch)
tree64bbde3c4a6d3de2054e56588e1568409ea3b5b2 /server-tools/instance-manager/parse_output.cc
parent11632315c8493725bc80b160dfd3036f15b5a2cf (diff)
downloadmariadb-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.cc17
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);