summaryrefslogtreecommitdiff
path: root/src/account.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2009-02-17 21:19:31 -0400
committerJohn Wiegley <johnw@newartisans.com>2009-02-17 21:19:31 -0400
commit4ec2dfeef13ead1d87302ef953e05efec102bb25 (patch)
tree0ff109dd6aaccf466ecbd64f80ae3138b9219b6a /src/account.cc
parent93d195f1d97c376c26e5a7e88d6b0fc6e3b8e2d0 (diff)
downloadfork-ledger-4ec2dfeef13ead1d87302ef953e05efec102bb25.tar.gz
fork-ledger-4ec2dfeef13ead1d87302ef953e05efec102bb25.tar.bz2
fork-ledger-4ec2dfeef13ead1d87302ef953e05efec102bb25.zip
Added --flat option, to flatten the balance report
Diffstat (limited to 'src/account.cc')
-rw-r--r--src/account.cc23
1 files changed, 15 insertions, 8 deletions
diff --git a/src/account.cc b/src/account.cc
index b463968b..07c01c7e 100644
--- a/src/account.cc
+++ b/src/account.cc
@@ -125,17 +125,19 @@ string account_t::fullname() const
}
}
-string account_t::partial_name() const
+string account_t::partial_name(bool flat) const
{
string pname = name;
for (const account_t * acct = parent;
acct && acct->parent;
acct = acct->parent) {
- std::size_t count = acct->children_with_flags(ACCOUNT_EXT_MATCHING);
- assert(count > 0);
- if (count > 1)
- break;
+ if (! flat) {
+ std::size_t count = acct->children_with_flags(ACCOUNT_EXT_MATCHING);
+ assert(count > 0);
+ if (count > 1)
+ break;
+ }
pname = acct->name + ":" + pname;
}
return pname;
@@ -148,8 +150,13 @@ std::ostream& operator<<(std::ostream& out, const account_t& account)
}
namespace {
- value_t get_partial_name(account_t& account) {
- return string_value(account.partial_name());
+ value_t get_partial_name(call_scope_t& scope)
+ {
+ account_t& account(find_scope<account_t>(scope));
+
+ var_t<bool> flatten(scope, 0);
+
+ return string_value(account.partial_name(flatten ? *flatten : false));
}
value_t get_account(account_t& account) { // this gets the name
@@ -238,7 +245,7 @@ expr_t::ptr_op_t account_t::lookup(const string& name)
case 'p':
if (name == "partial_account")
- return WRAP_FUNCTOR(get_wrapper<&get_partial_name>);
+ return WRAP_FUNCTOR(get_partial_name);
break;
case 's':