summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/textual.cc121
1 files changed, 62 insertions, 59 deletions
diff --git a/src/textual.cc b/src/textual.cc
index badbdee5..238098f1 100644
--- a/src/textual.cc
+++ b/src/textual.cc
@@ -125,7 +125,7 @@ namespace {
void tag_directive(char * line);
void pop_directive(char * line);
void define_directive(char * line);
- void general_directive(char * line);
+ bool general_directive(char * line);
post_t * parse_post(char * line,
std::streamsize len,
@@ -354,51 +354,53 @@ void instance_t::read_next_directive()
period_xact_directive(line);
break;
-#if defined(TIMELOG_SUPPORT)
- case 'i':
- clock_in_directive(line, false);
- break;
- case 'I':
- clock_in_directive(line, true);
- break;
-
- case 'o':
- clock_out_directive(line, false);
- break;
- case 'O':
- clock_out_directive(line, true);
- break;
-
- case 'h':
- case 'b':
- break;
-#endif // TIMELOG_SUPPORT
-
- case 'A': // a default account for unbalanced posts
- default_account_directive(line);
- break;
- case 'C': // a set of conversions
- price_conversion_directive(line);
- break;
- case 'D': // a default commodity for "xact"
- default_commodity_directive(line);
- break;
- case 'N': // don't download prices
- nomarket_directive(line);
- break;
- case 'P': // a pricing xact
- price_xact_directive(line);
- break;
- case 'Y': // set the current year
- year_directive(line);
- break;
-
case '@':
case '!':
line++;
// fall through...
default: // some other directive
- general_directive(line);
+ if (! general_directive(line)) {
+ switch (line[0]) {
+#if defined(TIMELOG_SUPPORT)
+ case 'i':
+ clock_in_directive(line, false);
+ break;
+ case 'I':
+ clock_in_directive(line, true);
+ break;
+
+ case 'o':
+ clock_out_directive(line, false);
+ break;
+ case 'O':
+ clock_out_directive(line, true);
+ break;
+
+ case 'h':
+ case 'b':
+ break;
+#endif // TIMELOG_SUPPORT
+
+ case 'A': // a default account for unbalanced posts
+ default_account_directive(line);
+ break;
+ case 'C': // a set of conversions
+ price_conversion_directive(line);
+ break;
+ case 'D': // a default commodity for "xact"
+ default_commodity_directive(line);
+ break;
+ case 'N': // don't download prices
+ nomarket_directive(line);
+ break;
+ case 'P': // a pricing xact
+ price_xact_directive(line);
+ break;
+ case 'Y': // set the current year
+ year_directive(line);
+ break;
+ }
+ }
break;
}
}
@@ -689,58 +691,56 @@ void instance_t::define_directive(char * line)
def.compile(scope); // causes definitions to be established
}
-void instance_t::general_directive(char * line)
+bool instance_t::general_directive(char * line)
{
- char * p = line;
- char * arg = next_element(line);
-
+ char * p = line;
if (*p == '@' || *p == '!')
p++;
switch (*p) {
case 'a':
if (std::strcmp(p, "account") == 0) {
- account_directive(arg);
- return;
+ account_directive(next_element(line));
+ return true;
}
else if (std::strcmp(p, "alias") == 0) {
- alias_directive(arg);
- return;
+ alias_directive(next_element(line));
+ return true;
}
break;
case 'd':
if (std::strcmp(p, "def") == 0) {
- define_directive(arg);
- return;
+ define_directive(next_element(line));
+ return true;
}
break;
case 'e':
if (std::strcmp(p, "end") == 0) {
- end_directive(arg);
- return;
+ end_directive(next_element(line));
+ return true;
}
break;
case 'i':
if (std::strcmp(p, "include") == 0) {
- include_directive(arg);
- return;
+ include_directive(next_element(line));
+ return true;
}
break;
case 'p':
if (std::strcmp(p, "pop") == 0) {
- pop_directive(arg);
- return;
+ pop_directive(next_element(line));
+ return true;
}
break;
case 't':
if (std::strcmp(p, "tag") == 0) {
- tag_directive(arg);
- return;
+ tag_directive(next_element(line));
+ return true;
}
break;
}
@@ -749,7 +749,10 @@ void instance_t::general_directive(char * line)
call_scope_t args(*this);
args.push_back(string_value(p));
op->as_function()(args);
+ return true;
}
+
+ return false;
}
post_t * instance_t::parse_post(char * line,