summaryrefslogtreecommitdiff
path: root/gnucash.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2005-10-25 05:29:40 +0000
committerJohn Wiegley <johnw@newartisans.com>2008-04-13 02:41:20 -0400
commitb18977e51fbe87264ae9b3b8e5ef0bfa567c3016 (patch)
treef32608a3bf7e11dc8208440ecee3c738d1158ae7 /gnucash.cc
parent8eae667ba523f1590509cb436a2c45ff60d36414 (diff)
downloadfork-ledger-b18977e51fbe87264ae9b3b8e5ef0bfa567c3016.tar.gz
fork-ledger-b18977e51fbe87264ae9b3b8e5ef0bfa567c3016.tar.bz2
fork-ledger-b18977e51fbe87264ae9b3b8e5ef0bfa567c3016.zip
(endElement): Changed the parser a bit to always prefer the
transaction commodity over the account commodity.
Diffstat (limited to 'gnucash.cc')
-rw-r--r--gnucash.cc71
1 files changed, 47 insertions, 24 deletions
diff --git a/gnucash.cc b/gnucash.cc
index 665f555f..6d4d8b28 100644
--- a/gnucash.cc
+++ b/gnucash.cc
@@ -138,6 +138,9 @@ static void endElement(void *userData, const char *name)
}
else if (std::strcmp(name, "gnc:transaction") == 0) {
assert(curr_entry);
+
+ // Add the new entry (what gnucash calls a 'transaction') to the
+ // journal
if (! curr_journal->add_entry(curr_entry)) {
print_entry(std::cerr, *curr_entry);
have_error = "The above entry does not balance";
@@ -150,8 +153,48 @@ static void endElement(void *userData, const char *name)
curr_entry->end_line = XML_GetCurrentLineNumber(parser) - offset;
count++;
}
+
+ // Clear the relevant variables for the next run
curr_entry = NULL;
+ entry_comm = NULL;
+ }
+ else if (std::strcmp(name, "trn:split") == 0) {
+ transaction_t * xact = curr_entry->transactions.back();
+
+ // Identify the commodity to use for the value of this
+ // transaction. The quantity indicates how many times that value
+ // the transaction is worth.
+ amount_t value;
+ commodity_t * default_commodity = NULL;
+ if (entry_comm) {
+ default_commodity = entry_comm;
+ } else {
+ account_comm_map::iterator ac = account_comms.find(xact->account);
+ if (ac != account_comms.end())
+ default_commodity = (*ac).second;
+ }
+
+ if (default_commodity) {
+ curr_quant.set_commodity(*default_commodity);
+ value = curr_quant.round(default_commodity->precision);
+
+ if (curr_value.commodity() == *default_commodity)
+ curr_value = value;
+ } else {
+ value = curr_quant;
+ }
+
+ xact->state = curr_state;
+ xact->amount = value;
+ if (value != curr_value)
+ xact->cost = new amount_t(curr_value);
+
+ // Clear the relevant variables for the next run
+ curr_state = transaction_t::UNCLEARED;
+ curr_value = amount_t();
+ curr_quant = amount_t();
}
+
action = NO_ACTION;
}
@@ -246,9 +289,11 @@ static void dataHandler(void *userData, const char *s, int len)
case XACT_STATE:
if (*s == 'y')
- curr_state = transaction_t::PENDING;
- else
curr_state = transaction_t::CLEARED;
+ else if (*s == 'n')
+ curr_state = transaction_t::UNCLEARED;
+ else
+ curr_state = transaction_t::PENDING;
break;
case XACT_VALUE: {
@@ -278,28 +323,6 @@ static void dataHandler(void *userData, const char *s, int len)
have_error = (std::string("Could not find account ") +
std::string(s, len));
}
-
- amount_t value;
-
- account_comm_map::iterator ac = account_comms.find(xact->account);
- if (ac != account_comms.end()) {
- commodity_t * default_commodity = (*ac).second;
-
- curr_quant.set_commodity(*default_commodity);
- value = curr_quant.round(default_commodity->precision);
-
- if (curr_value.commodity() == *default_commodity)
- curr_value = value;
- } else {
- value = curr_quant;
- }
-
- xact->state = curr_state;
- xact->amount = value;
- if (value != curr_value)
- xact->cost = new amount_t(curr_value);
-
- curr_state = transaction_t::UNCLEARED;
break;
}