diff options
author | John Wiegley <johnw@newartisans.com> | 2009-12-09 14:03:57 -0500 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2009-12-09 14:03:57 -0500 |
commit | e3c8b91b5faedafd6b8f6a9a4c54638eba78c769 (patch) | |
tree | eeef84ba9b48e11296793c64a1ce20436cfd4316 | |
parent | 12db51e6bb8876102ab2d535d77869981411176d (diff) | |
parent | f1a2a5a18d5e7104ad308b2f56a9188f441bb7f2 (diff) | |
download | fork-ledger-e3c8b91b5faedafd6b8f6a9a4c54638eba78c769.tar.gz fork-ledger-e3c8b91b5faedafd6b8f6a9a4c54638eba78c769.tar.bz2 fork-ledger-e3c8b91b5faedafd6b8f6a9a4c54638eba78c769.zip |
Merge branch 'next'
-rw-r--r-- | src/draft.cc | 3 | ||||
-rw-r--r-- | src/pool.cc | 4 | ||||
-rw-r--r-- | src/textual.cc | 17 |
3 files changed, 18 insertions, 6 deletions
diff --git a/src/draft.cc b/src/draft.cc index 8478a31d..fc53e956 100644 --- a/src/draft.cc +++ b/src/draft.cc @@ -458,6 +458,9 @@ xact_t * draft_t::insert(journal_t& journal) *post.cost *= new_post->amount; post.cost->set_commodity(cost_commodity); } + else if (new_post->amount.sign() < 0) { + new_post->cost->in_place_negate(); + } new_post->cost = *post.cost; DEBUG("derive.xact", "Copied over posting cost"); diff --git a/src/pool.cc b/src/pool.cc index 70f4eed6..f895a8bc 100644 --- a/src/pool.cc +++ b/src/pool.cc @@ -247,7 +247,7 @@ commodity_pool_t::exchange(const amount_t& amount, current_annotation = &as_annotated_commodity(commodity).details; amount_t per_unit_cost = - (is_per_unit || amount.is_realzero() ? cost : cost / amount).abs(); + (is_per_unit || amount.is_realzero()) ? cost.abs() : (cost / amount).abs(); DEBUG("commodity.prices.add", "exchange: per-unit-cost = " << per_unit_cost); @@ -255,7 +255,7 @@ commodity_pool_t::exchange(const amount_t& amount, exchange(commodity, per_unit_cost, moment ? *moment : CURRENT_TIME()); cost_breakdown_t breakdown; - breakdown.final_cost = ! is_per_unit ? cost : cost * amount; + breakdown.final_cost = ! is_per_unit ? cost : cost * amount.abs(); DEBUG("commodity.prices.add", "exchange: final-cost = " << breakdown.final_cost); diff --git a/src/textual.cc b/src/textual.cc index cf670cae..cbeb6358 100644 --- a/src/textual.cc +++ b/src/textual.cc @@ -663,20 +663,26 @@ void instance_t::include_directive(char * line) { path filename; + DEBUG("textual.include", "include: " << line); + if (line[0] != '/' && line[0] != '\\' && line[0] != '~') { + DEBUG("textual.include", "received a relative path"); + DEBUG("textual.include", "parent file path: " << pathname.string()); string::size_type pos = pathname.string().rfind('/'); if (pos == string::npos) pos = pathname.string().rfind('\\'); - if (pos != string::npos) + if (pos != string::npos) { filename = path(string(pathname.string(), 0, pos + 1)) / line; + DEBUG("textual.include", "normalized path: " << filename.string()); + } else { + filename = path(string(".")) / line; + } } else { filename = line; } filename = resolve_path(filename); - - DEBUG("textual.include", "Line " << linenum << ": " << - "Including path '" << filename << "'"); + DEBUG("textual.include", "resolved path: " << filename.string()); if (! exists(filename)) throw_(std::runtime_error, @@ -1044,6 +1050,9 @@ post_t * instance_t::parse_post(char * line, *post->cost *= post->amount; post->cost->set_commodity(cost_commodity); } + else if (post->amount.sign() < 0) { + post->cost->in_place_negate(); + } DEBUG("textual.parse", "line " << linenum << ": " << "Total cost is " << *post->cost); |