From 329a0dfcc53354be7873385383ca6d8238e5a97e Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Tue, 10 Nov 2009 02:26:34 -0500 Subject: Corrected the parsing of data file directives --- src/textual.cc | 24 +++++++++++++++--------- 1 file changed, 15 insertions(+), 9 deletions(-) (limited to 'src/textual.cc') diff --git a/src/textual.cc b/src/textual.cc index c3a44be6..5a9e2165 100644 --- a/src/textual.cc +++ b/src/textual.cc @@ -703,60 +703,66 @@ void instance_t::define_directive(char * line) bool instance_t::general_directive(char * line) { - char * p = line; + char buf[8192]; + + std::strcpy(buf, line); + + char * p = buf; + char * arg = next_element(buf); + if (*p == '@' || *p == '!') p++; switch (*p) { case 'a': if (std::strcmp(p, "account") == 0) { - master_account_directive(next_element(line)); + master_account_directive(arg); return true; } else if (std::strcmp(p, "alias") == 0) { - alias_directive(next_element(line)); + alias_directive(arg); return true; } break; case 'b': if (std::strcmp(p, "bucket") == 0) { - default_account_directive(next_element(line)); + default_account_directive(arg); return true; } break; case 'd': if (std::strcmp(p, "def") == 0 || std::strcmp(p, "define") == 0) { - define_directive(next_element(line)); + define_directive(arg); return true; } break; case 'e': if (std::strcmp(p, "end") == 0) { - end_directive(next_element(line)); + end_directive(arg); return true; } break; case 'i': if (std::strcmp(p, "include") == 0) { - include_directive(next_element(line)); + include_directive(arg); return true; } break; case 'p': if (std::strcmp(p, "pop") == 0) { - pop_directive(next_element(line)); + pop_directive(arg); return true; } break; case 't': if (std::strcmp(p, "tag") == 0) { - tag_directive(next_element(line)); + tag_directive(arg); return true; } break; -- cgit v1.2.3