summaryrefslogtreecommitdiff
path: root/valexpr.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2004-08-17 04:57:38 -0400
committerJohn Wiegley <johnw@newartisans.com>2004-08-17 04:57:38 -0400
commit325cf53ea74f7a7fe51fc30103594a3a92989f37 (patch)
tree4fe4cd9a0a943a6bd7c39c9487bdd0b592c954cd /valexpr.cc
parent9e235d04a1aa9d38fa6f1503902873d2f7ad8419 (diff)
downloadfork-ledger-325cf53ea74f7a7fe51fc30103594a3a92989f37.tar.gz
fork-ledger-325cf53ea74f7a7fe51fc30103594a3a92989f37.tar.bz2
fork-ledger-325cf53ea74f7a7fe51fc30103594a3a92989f37.zip
several significant speed improvements (removed excessive copying of strings)
Diffstat (limited to 'valexpr.cc')
-rw-r--r--valexpr.cc71
1 files changed, 23 insertions, 48 deletions
diff --git a/valexpr.cc b/valexpr.cc
index cd6664b1..74d4587b 100644
--- a/valexpr.cc
+++ b/valexpr.cc
@@ -1,6 +1,8 @@
#include "valexpr.h"
#include "error.h"
#include "datetime.h"
+#include "debug.h"
+#include "util.h"
#include <vector>
@@ -344,32 +346,20 @@ value_expr_t * parse_value_term(std::istream& in)
char c = peek_next_nonws(in);
if (std::isdigit(c) || c == '.' || c == '{') {
- std::string ident;
-
+ static char buf[2048];
if (c == '{') {
in.get(c);
- c = in.peek();
- while (! in.eof() && c != '}') {
- in.get(c);
- ident += c;
- c = in.peek();
- }
+ READ_INTO(in, buf, 2048, c, c != '}');
if (c == '}')
in.get(c);
else
throw value_expr_error("Missing '}'");
} else {
- while (! in.eof() && std::isdigit(c) || c == '.') {
- in.get(c);
- ident += c;
- c = in.peek();
- }
+ READ_INTO(in, buf, 2048, c, std::isdigit(c) || c == '.');
}
- if (! ident.empty()) {
- node = new value_expr_t(value_expr_t::CONSTANT_A);
- node->constant_a.parse(ident);
- }
+ node = new value_expr_t(value_expr_t::CONSTANT_A);
+ node->constant_a.parse(buf);
return node;
}
@@ -443,7 +433,6 @@ value_expr_t * parse_value_term(std::istream& in)
// Other
case '/': {
- std::string ident;
bool payee_mask = false;
c = peek_next_nonws(in);
@@ -453,22 +442,15 @@ value_expr_t * parse_value_term(std::istream& in)
c = in.peek();
}
- while (! in.eof() && c != '/') {
- in.get(c);
- if (c == '\\')
- in.get(c);
- ident += c;
- c = in.peek();
- }
-
- if (c == '/') {
- in.get(c);
- node = new value_expr_t(payee_mask ?
- value_expr_t::F_PAYEE_MASK : value_expr_t::F_ACCOUNT_MASK);
- node->mask = new mask_t(ident);
- } else {
+ static char buf[4096];
+ READ_INTO(in, buf, 4096, c, c != '/');
+ if (c != '/')
throw value_expr_error("Missing closing '/'");
- }
+
+ in.get(c);
+ node = new value_expr_t(payee_mask ? value_expr_t::F_PAYEE_MASK :
+ value_expr_t::F_ACCOUNT_MASK);
+ node->mask = new mask_t(buf);
break;
}
@@ -481,22 +463,15 @@ value_expr_t * parse_value_term(std::istream& in)
break;
case '[': {
- std::string ident;
-
- c = in.peek();
- while (! in.eof() && c != ']') {
- in.get(c);
- ident += c;
- c = in.peek();
- }
- if (c == ']') {
- in.get(c);
- node = new value_expr_t(value_expr_t::CONSTANT_T);
- if (! parse_date(ident.c_str(), &node->constant_t))
- throw value_expr_error("Failed to parse date");
- } else {
+ static char buf[1024];
+ READ_INTO(in, buf, 1024, c, c != ']');
+ if (c != ']')
throw value_expr_error("Missing ']'");
- }
+
+ in.get(c);
+ node = new value_expr_t(value_expr_t::CONSTANT_T);
+ if (! parse_date(buf, &node->constant_t))
+ throw value_expr_error("Failed to parse date");
break;
}