summaryrefslogtreecommitdiff
path: root/src/token.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2010-06-13 00:42:25 -0400
committerJohn Wiegley <johnw@newartisans.com>2010-06-13 00:42:25 -0400
commit40f553228f5a28034c6635fdcb4c86af28a385ed (patch)
tree2c40305c9f9841a4c3d453a4a5c49ec69056b4b2 /src/token.cc
parent556211e623cad88213e5087b5c9c36e754d9aa02 (diff)
parentb1b4e2aadff5983d443d70c09ea86a41b015873f (diff)
downloadfork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.tar.gz
fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.tar.bz2
fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.zip
Merge branch 'next'
Diffstat (limited to 'src/token.cc')
-rw-r--r--src/token.cc132
1 files changed, 66 insertions, 66 deletions
diff --git a/src/token.cc b/src/token.cc
index 905e13fe..9dfff065 100644
--- a/src/token.cc
+++ b/src/token.cc
@@ -50,74 +50,74 @@ int expr_t::token_t::parse_reserved_word(std::istream& in)
switch (buf[0]) {
case 'a':
if (std::strcmp(buf, "and") == 0) {
- symbol[0] = '&';
- symbol[1] = '\0';
- kind = KW_AND;
- return 1;
+ symbol[0] = '&';
+ symbol[1] = '\0';
+ kind = KW_AND;
+ return 1;
}
break;
case 'd':
if (std::strcmp(buf, "div") == 0) {
- symbol[0] = '/';
- symbol[1] = '/';
- symbol[2] = '\0';
- kind = KW_DIV;
- return 1;
+ symbol[0] = '/';
+ symbol[1] = '/';
+ symbol[2] = '\0';
+ kind = KW_DIV;
+ return 1;
}
break;
case 'e':
if (std::strcmp(buf, "else") == 0) {
- symbol[0] = 'L';
- symbol[1] = 'S';
- symbol[2] = '\0';
- kind = KW_ELSE;
- return 1;
+ symbol[0] = 'L';
+ symbol[1] = 'S';
+ symbol[2] = '\0';
+ kind = KW_ELSE;
+ return 1;
}
break;
case 'f':
if (std::strcmp(buf, "false") == 0) {
- kind = VALUE;
- value = false;
- return 1;
+ kind = VALUE;
+ value = false;
+ return 1;
}
break;
case 'i':
if (std::strcmp(buf, "if") == 0) {
- symbol[0] = 'i';
- symbol[1] = 'f';
- symbol[2] = '\0';
- kind = KW_IF;
- return 1;
+ symbol[0] = 'i';
+ symbol[1] = 'f';
+ symbol[2] = '\0';
+ kind = KW_IF;
+ return 1;
}
break;
case 'o':
if (std::strcmp(buf, "or") == 0) {
- symbol[0] = '|';
- symbol[1] = '\0';
- kind = KW_OR;
- return 1;
+ symbol[0] = '|';
+ symbol[1] = '\0';
+ kind = KW_OR;
+ return 1;
}
break;
case 'n':
if (std::strcmp(buf, "not") == 0) {
- symbol[0] = '!';
- symbol[1] = '\0';
- kind = EXCLAM;
- return 1;
+ symbol[0] = '!';
+ symbol[1] = '\0';
+ kind = EXCLAM;
+ return 1;
}
break;
case 't':
if (std::strcmp(buf, "true") == 0) {
- kind = VALUE;
- value = true;
- return 1;
+ kind = VALUE;
+ value = true;
+ return 1;
}
break;
}
@@ -129,7 +129,7 @@ int expr_t::token_t::parse_reserved_word(std::istream& in)
void expr_t::token_t::parse_ident(std::istream& in)
{
- kind = IDENT;
+ kind = IDENT;
length = 0;
char c, buf[256];
@@ -139,7 +139,7 @@ void expr_t::token_t::parse_ident(std::istream& in)
}
void expr_t::token_t::next(std::istream& in, const parse_flags_t& pflags,
- const char expecting)
+ const char expecting)
{
if (in.eof()) {
kind = TOK_EOF;
@@ -210,7 +210,7 @@ void expr_t::token_t::next(std::istream& in, const parse_flags_t& pflags,
optional<date_t> begin = timespan.begin();
if (! begin)
throw_(parse_error,
- _("Date specifier does not refer to a starting date"));
+ _("Date specifier does not refer to a starting date"));
kind = VALUE;
value = *begin;
break;
@@ -302,12 +302,12 @@ void expr_t::token_t::next(std::istream& in, const parse_flags_t& pflags,
in.get(c);
if (pflags.has_flags(PARSE_OP_CONTEXT)) { // operator context
kind = SLASH;
- } else { // terminal context
+ } else { // terminal context
// Read in the regexp
char buf[256];
READ_INTO_(in, buf, 255, c, length, c != '/');
if (c != '/')
- expected('/', c);
+ expected('/', c);
in.get(c);
length++;
@@ -395,7 +395,7 @@ void expr_t::token_t::next(std::istream& in, const parse_flags_t& pflags,
in.clear();
in.seekg(pos, std::ios::beg);
if (in.fail())
- throw_(parse_error, _("Failed to reset input stream"));
+ throw_(parse_error, _("Failed to reset input stream"));
}
// When in relaxed parsing mode, we want to migrate commodity flags
@@ -411,30 +411,30 @@ void expr_t::token_t::next(std::istream& in, const parse_flags_t& pflags,
try {
amount_t temp;
if (! temp.parse(in, parse_flags.plus_flags(PARSE_SOFT_FAIL))) {
- // If the amount had no commodity, it must be an unambiguous
- // variable reference
-
- in.clear();
- in.seekg(pos, std::ios::beg);
- if (in.fail())
- throw_(parse_error, _("Failed to reset input stream"));
-
- c = static_cast<char>(in.peek());
- if (std::isdigit(c) || c == '.')
- expected('\0', c);
-
- parse_ident(in);
-
- if (value.as_string().length() == 0) {
- kind = ERROR;
- symbol[0] = c;
- symbol[1] = '\0';
- unexpected(expecting);
- }
+ // If the amount had no commodity, it must be an unambiguous
+ // variable reference
+
+ in.clear();
+ in.seekg(pos, std::ios::beg);
+ if (in.fail())
+ throw_(parse_error, _("Failed to reset input stream"));
+
+ c = static_cast<char>(in.peek());
+ if (std::isdigit(c) || c == '.')
+ expected('\0', c);
+
+ parse_ident(in);
+
+ if (value.as_string().length() == 0) {
+ kind = ERROR;
+ symbol[0] = c;
+ symbol[1] = '\0';
+ unexpected(expecting);
+ }
} else {
- kind = VALUE;
- value = temp;
- length = static_cast<std::size_t>(in.tellg() - pos);
+ kind = VALUE;
+ value = temp;
+ length = static_cast<std::size_t>(in.tellg() - pos);
}
}
catch (const std::exception& err) {
@@ -476,16 +476,16 @@ void expr_t::token_t::unexpected(const char wanted)
switch (prev_kind) {
case TOK_EOF:
throw_(parse_error,
- _("Unexpected end of expression (wanted '%1')") << wanted);
+ _("Unexpected end of expression (wanted '%1')") << wanted);
case IDENT:
throw_(parse_error,
- _("Unexpected symbol '%1' (wanted '%2')") << value << wanted);
+ _("Unexpected symbol '%1' (wanted '%2')") << value << wanted);
case VALUE:
throw_(parse_error,
- _("Unexpected value '%1' (wanted '%2')") << value << wanted);
+ _("Unexpected value '%1' (wanted '%2')") << value << wanted);
default:
throw_(parse_error, _("Unexpected expression token '%1' (wanted '%2')")
- << symbol << wanted);
+ << symbol << wanted);
}
}
}