summaryrefslogtreecommitdiff
path: root/src/output.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/output.cc')
-rw-r--r--src/output.cc95
1 files changed, 44 insertions, 51 deletions
diff --git a/src/output.cc b/src/output.cc
index 02bd7120..b10dcff6 100644
--- a/src/output.cc
+++ b/src/output.cc
@@ -117,12 +117,6 @@ format_accounts::format_accounts(report_t& _report,
{
TRACE_CTOR(format_accounts, "report&, const string&");
- if (report.HANDLED(display_)) {
- DEBUG("account.display",
- "Account display predicate: " << report.HANDLER(display_).str());
- disp_pred.predicate.parse(report.HANDLER(display_).str());
- }
-
const char * f = format.c_str();
if (const char * p = std::strstr(f, "%/")) {
@@ -142,48 +136,62 @@ format_accounts::format_accounts(report_t& _report,
void format_accounts::post_account(account_t& account)
{
- bind_scope_t bound_scope(report, account);
- bool format_account = false;
+ if (account.xdata().has_flags(ACCOUNT_EXT_TO_DISPLAY)) {
+ account.xdata().add_flags(ACCOUNT_EXT_DISPLAYED);
+
+ bind_scope_t bound_scope(report, account);
+ account_line_format.format(report.output_stream, bound_scope);
+ }
+}
- DEBUG("account.display", "Should we display " << account.fullname());
+std::pair<std::size_t, std::size_t>
+format_accounts::mark_accounts(account_t& account, const bool flat)
+{
+ std::size_t visited = 0;
+ std::size_t to_display = 0;
- if (account.has_flags(ACCOUNT_EXT_MATCHING) ||
- (! report.HANDLED(flat) &&
- account.children_with_flags(ACCOUNT_EXT_MATCHING) > 1)) {
- DEBUG("account.display", " Yes, because it matched");
- format_account = true;
+ foreach (accounts_map::value_type& pair, account.accounts) {
+ std::pair<std::size_t, std::size_t> i = mark_accounts(*pair.second, flat);
+ visited += i.first;
+ to_display += i.second;
}
- else if (! report.HANDLED(flat) &&
- account.children_with_flags(ACCOUNT_EXT_VISITED) &&
- ! account.children_with_flags(ACCOUNT_EXT_MATCHING)) {
- DEBUG("account.display",
- " Maybe, because it has visited, but no matching, children");
- if (disp_pred(bound_scope)) {
- DEBUG("account.display",
- " And yes, because it matches the display predicate");
- format_account = true;
- } else {
- DEBUG("account.display",
- " And no, because it didn't match the display predicate");
+
+#if defined(DEBUG_ON)
+ DEBUG("account.display", "Considering account: " << account.fullname());
+ if (account.has_flags(ACCOUNT_EXT_VISITED))
+ DEBUG("account.display", " it was visited itself");
+ DEBUG("account.display", " it has " << visited << " visited children");
+ DEBUG("account.display",
+ " it has " << to_display << " children to display");
+#endif
+
+ if (account.has_flags(ACCOUNT_EXT_VISITED) || (! flat && visited > 0)) {
+ bind_scope_t bound_scope(report, account);
+ if (disp_pred(bound_scope) && (flat || to_display != 1)) {
+ account.xdata().add_flags(ACCOUNT_EXT_TO_DISPLAY);
+ DEBUG("account.display", "Marking account as TO_DISPLAY");
+ to_display = 1;
}
- }
- else {
- DEBUG("account.display",
- " No, neither it nor its children were eligible for display");
+ visited = 1;
}
- if (format_account) {
- account.xdata().add_flags(ACCOUNT_EXT_DISPLAYED);
- account_line_format.format(report.output_stream, bound_scope);
- }
+ return std::pair<std::size_t, std::size_t>(visited, to_display);
}
void format_accounts::flush()
{
std::ostream& out(report.output_stream);
+ if (report.HANDLED(display_)) {
+ DEBUG("account.display",
+ "Account display predicate: " << report.HANDLER(display_).str());
+ disp_pred.predicate.parse(report.HANDLER(display_).str());
+ }
+
std::size_t top_displayed = 0;
+ mark_accounts(*report.session.master, report.HANDLED(flat));
+
foreach (account_t * account, posted_accounts) {
post_account(*account);
@@ -194,8 +202,9 @@ void format_accounts::flush()
if (! report.HANDLED(flat)) {
foreach (accounts_map::value_type pair, report.session.master->accounts) {
if (pair.second->has_flags(ACCOUNT_EXT_DISPLAYED) ||
- pair.second->children_with_flags(ACCOUNT_EXT_DISPLAYED))
+ pair.second->children_with_flags(ACCOUNT_EXT_DISPLAYED)) {
top_displayed++;
+ }
}
}
@@ -211,22 +220,6 @@ void format_accounts::flush()
void format_accounts::operator()(account_t& account)
{
- DEBUG("account.display",
- "Proposing to format account: " << account.fullname());
-
- if (account.has_flags(ACCOUNT_EXT_VISITED)) {
- DEBUG("account.display", " Account or its children was visited");
-
- bind_scope_t bound_scope(report, account);
- if (disp_pred(bound_scope)) {
- DEBUG("account.display",
- " And the account matched the display predicate");
- account.xdata().add_flags(ACCOUNT_EXT_MATCHING);
- } else {
- DEBUG("account.display",
- " But it did not match the display predicate");
- }
- }
posted_accounts.push_back(&account);
}