summaryrefslogtreecommitdiff
path: root/parse.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2003-09-30 03:22:38 +0000
committerJohn Wiegley <johnw@newartisans.com>2003-09-30 03:22:38 +0000
commitef6161fefb09253b9de6d228c92ce41b3a0063dc (patch)
tree513811f9b3aad8617d8795b4715c8448fb26afab /parse.cc
parent7bf86bc48a564ffffa46461c15ae2ab34b258fe8 (diff)
downloadfork-ledger-ef6161fefb09253b9de6d228c92ce41b3a0063dc.tar.gz
fork-ledger-ef6161fefb09253b9de6d228c92ce41b3a0063dc.tar.bz2
fork-ledger-ef6161fefb09253b9de6d228c92ce41b3a0063dc.zip
*** empty log message ***
Diffstat (limited to 'parse.cc')
-rw-r--r--parse.cc46
1 files changed, 41 insertions, 5 deletions
diff --git a/parse.cc b/parse.cc
index 5e134dc2..749e3cbd 100644
--- a/parse.cc
+++ b/parse.cc
@@ -135,13 +135,49 @@ bool parse_ledger(std::istream& in)
else if (std::isspace(line[0])) {
transaction * xact = new transaction();
- xact->cost = create_amount(next_element(line, true));
+ char * p = line;
+ while (std::isspace(*p))
+ p++;
+
+ // The call to `next_element' will skip past the account name,
+ // and return a pointer to the beginning of the amount. Once
+ // we know where the amount is, we can strip off any
+ // transaction note, and parse it.
+
+ char * cost_str = next_element(p, true);
+ char * note_str;
+
+ // If there is no amount given, it is intended as an implicit
+ // amount; we must use the opposite of the value of the
+ // preceding transaction.
+ if (! cost_str || *cost_str == ';') {
+ if (cost_str) {
+ while (*cost_str == ';' || std::isspace(*cost_str))
+ cost_str++;
+ xact->note = cost_str;
+ }
+ xact->cost = curr->xacts.back()->cost->copy();
+ xact->cost->negate();
+ }
+ else {
+ note_str = std::strchr(cost_str, ';');
+ if (note_str) {
+ *note_str++ = '\0';
+ while (std::isspace(*note_str))
+ note_str++;
+ xact->note = note_str;
+ }
+
+ for (char * t = cost_str + (std::strlen(cost_str) - 1);
+ std::isspace(*t);
+ t--)
+ *t = '\0';
+
+ xact->cost = create_amount(cost_str);
+ }
- // jww (2003-09-28): Reverse parse the account name to find the
- // correct account. This means that each account needs to know
- // its children.
account * current = NULL;
- for (char * tok = std::strtok(line, ":");
+ for (char * tok = std::strtok(p, ":");
tok;
tok = std::strtok(NULL, ":")) {
if (! current) {