summaryrefslogtreecommitdiff
path: root/parse.cc
diff options
context:
space:
mode:
Diffstat (limited to 'parse.cc')
-rw-r--r--parse.cc67
1 files changed, 35 insertions, 32 deletions
diff --git a/parse.cc b/parse.cc
index 8ff5207a..309b90a4 100644
--- a/parse.cc
+++ b/parse.cc
@@ -50,38 +50,33 @@ static inline void finalize_entry(entry * curr)
// Ledger parser
//
-bool parse_ledger(std::istream& in)
+bool parse_ledger(std::istream& in, bool compute_balances)
{
- static std::time_t now = std::time(NULL);
- static struct std::tm * now_tm = std::localtime(&now);
- static int current_year = now_tm->tm_year + 1900;
+ std::time_t now = std::time(NULL);
+ struct std::tm * now_tm = std::localtime(&now);
+ int current_year = now_tm->tm_year + 1900;
- static char line[1024];
+ char line[1024];
- static struct std::tm moment;
+ struct std::tm moment;
memset(&moment, 0, sizeof(struct std::tm));
entry * curr = NULL;
// Compile the regular expression used for parsing amounts
- static pcre * entry_re = NULL;
- if (! entry_re) {
- const char *error;
- int erroffset;
- static const std::string regexp =
- "^(([0-9]{4})[./])?([0-9]+)[./]([0-9]+)\\s+(\\*\\s+)?"
- "(\\(([^)]+)\\)\\s+)?(.+)";
- entry_re = pcre_compile(regexp.c_str(), 0, &error, &erroffset, NULL);
- }
+ const char *error;
+ int erroffset;
+ static const std::string regexp =
+ "^(([0-9]{4})[./])?([0-9]+)[./]([0-9]+)\\s+(\\*\\s+)?"
+ "(\\(([^)]+)\\)\\s+)?(.+)";
+ pcre * entry_re = pcre_compile(regexp.c_str(), 0,
+ &error, &erroffset, NULL);
while (! in.eof()) {
in.getline(line, 1023);
linenum++;
- if (in.eof()) {
- break;
- }
- else if (line[0] == '\n') {
+ if (line[0] == '\n') {
continue;
}
else if (std::isdigit(line[0])) {
@@ -96,28 +91,28 @@ bool parse_ledger(std::istream& in)
continue;
}
+ // If we haven't finished with the last entry yet, do so now
+
if (curr)
finalize_entry(curr);
+
curr = new entry;
// Parse the date
- int mday, mon, year = current_year;
-
+ int year = current_year;
if (ovector[1 * 2] >= 0) {
pcre_copy_substring(line, ovector, matched, 2, buf, 255);
year = std::atoi(buf);
}
- if (ovector[3 * 2] >= 0) {
- pcre_copy_substring(line, ovector, matched, 3, buf, 255);
- mon = std::atoi(buf);
- }
+ assert(ovector[3 * 2] >= 0);
+ pcre_copy_substring(line, ovector, matched, 3, buf, 255);
+ int mon = std::atoi(buf);
- if (ovector[4 * 2] >= 0) {
- pcre_copy_substring(line, ovector, matched, 4, buf, 255);
- mday = std::atoi(buf);
- }
+ assert(ovector[4 * 2] >= 0);
+ pcre_copy_substring(line, ovector, matched, 4, buf, 255);
+ int mday = std::atoi(buf);
moment.tm_mday = mday;
moment.tm_mon = mon - 1;
@@ -125,6 +120,8 @@ bool parse_ledger(std::istream& in)
curr->date = std::mktime(&moment);
+ // Parse the remaining entry details
+
if (ovector[5 * 2] >= 0)
curr->cleared = true;
@@ -164,6 +161,7 @@ bool parse_ledger(std::istream& in)
cost_str++;
xact->note = cost_str;
}
+
xact->cost = curr->xacts.front()->cost->copy();
xact->cost->negate();
}
@@ -198,7 +196,8 @@ bool parse_ledger(std::istream& in)
#endif
xact->acct = main_ledger.find_account(p);
- xact->acct->balance.credit(xact->cost);
+ if (compute_balances)
+ xact->acct->balance.credit(xact->cost);
curr->xacts.push_back(xact);
@@ -215,9 +214,11 @@ bool parse_ledger(std::istream& in)
temp = xact->cost->value();
t->cost = temp->value(huquq);
delete temp;
- t->acct->balance.credit(t->cost);
curr->xacts.push_back(t);
+ if (compute_balances)
+ t->acct->balance.credit(t->cost);
+
// Balance the above transaction by recording the inverse in
// Expenses:Huququ'llah.
t = new transaction();
@@ -226,8 +227,10 @@ bool parse_ledger(std::istream& in)
t->cost = temp->value(huquq);
delete temp;
t->cost->negate();
- t->acct->balance.credit(t->cost);
curr->xacts.push_back(t);
+
+ if (compute_balances)
+ t->acct->balance.credit(t->cost);
}
#endif
}