From 84fe84bbd2185d3bd997a3ebac99417f99376cfb Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Sat, 7 Aug 2004 22:09:14 -0400 Subject: equity reports are restored --- main.cc | 51 +++++++++++++++++++++++++++++++++++++++++++++------ 1 file changed, 45 insertions(+), 6 deletions(-) (limited to 'main.cc') diff --git a/main.cc b/main.cc index 73248450..5a8cd8b9 100644 --- a/main.cc +++ b/main.cc @@ -20,6 +20,9 @@ static const std::string reg_fmt static const std::string print_fmt = "\n%10d %X%C%p\n %-34N %12o\n%/ %-34N %12o\n"; +static const std::string equity_fmt + = "\n%10d %X%C%p\n%/ %-34N %12t\n"; + void set_price_conversion(const std::string& setting) { @@ -575,8 +578,12 @@ int main(int argc, char * argv[]) predicate.reset(parse_expr(predicate_string)); } - if (display_predicate_string.empty() && command == "b" && ! show_empty) - display_predicate_string = "T"; + if (! show_empty && display_predicate_string.empty()) { + if (command == "b") + display_predicate_string = "T"; + else if (command == "E") + display_predicate_string = "a"; + } if (! display_predicate_string.empty()) { #ifdef DEBUG @@ -601,10 +608,13 @@ int main(int argc, char * argv[]) unsigned int xact_display_flags = MATCHING_TRANSACTIONS; - if (command == "p" || command == "e" || command == "E") { + if (command == "p" || command == "e") { xact_display_flags |= OTHER_TRANSACTIONS; show_expanded = true; } + else if (command == "E") { + show_expanded = true; + } else if (show_related) { if (command == "r") { xact_display_flags = OTHER_TRANSACTIONS; @@ -621,6 +631,8 @@ int main(int argc, char * argv[]) f = bal_fmt.c_str(); else if (command == "r") f = reg_fmt.c_str(); + else if (command == "E") + f = equity_fmt.c_str(); else f = print_fmt.c_str(); @@ -638,7 +650,27 @@ int main(int argc, char * argv[]) format_account(std::cout, format)(journal->master, true, display_predicate.get()); } - } else { + } + else if (command == "E") { + std::string first_line_format; + std::string next_lines_format; + + if (const char * p = std::strstr(f, "%/")) { + first_line_format = std::string(f, 0, p - f); + next_lines_format = std::string(p + 2); + } else { + first_line_format = next_lines_format = f; + } + + format_t format(first_line_format); + format_t nformat(next_lines_format); + + format_equity formatter(std::cout, format, nformat, + display_predicate.get()); + walk_accounts(journal->master, formatter, predicate.get(), + xact_display_flags, true, 0, sort_order.get()); + } + else { std::string first_line_format; std::string next_lines_format; @@ -675,8 +707,15 @@ int main(int argc, char * argv[]) xact_display_flags); std::stable_sort(transactions_pool.begin(), transactions_pool.end(), compare_items(sort_order.get())); - walk_transactions(transactions_pool.begin(), transactions_pool.end(), - formatter); + if (show_commodities_revalued) { + changed_value_filter + filtered_formatter(formatter); + walk_transactions(transactions_pool.begin(), transactions_pool.end(), + filtered_formatter); + } else { + walk_transactions(transactions_pool.begin(), transactions_pool.end(), + formatter); + } } } -- cgit v1.2.3