summaryrefslogtreecommitdiff
path: root/main.cc
diff options
context:
space:
mode:
Diffstat (limited to 'main.cc')
-rw-r--r--main.cc188
1 files changed, 99 insertions, 89 deletions
diff --git a/main.cc b/main.cc
index 70a3f015..78afc938 100644
--- a/main.cc
+++ b/main.cc
@@ -1,9 +1,11 @@
#include "ledger.h"
-#include "constraint.h"
+#include "balance.h"
#include "textual.h"
#include "binary.h"
-#include "balance.h"
-#include "report.h"
+#include "constraint.h"
+#include "item.h"
+#include "expr.h"
+#include "format.h"
#include <fstream>
#include <cstring>
@@ -20,23 +22,20 @@ namespace ledger {
static const std::string bal_fmt = "%20T%2_%-n\n";
-void show_balances(std::ostream& out,
- report::items_deque& items,
- const constraints_t& constraints,
- const report::format_t& format,
- const report::item_t * displayed_parent)
+void show_balances(std::ostream& out,
+ items_deque& items,
+ const constraints_t& constraints,
+ const format_t& format,
+ const item_t * displayed_parent)
{
- if (format.sort_order)
- std::sort(items.begin(), items.end(), report::cmp_items(format));
-
- for (report::items_deque::const_iterator i = items.begin();
+ for (items_deque::const_iterator i = items.begin();
i != items.end();
i++) {
- const report::item_t * parent = displayed_parent;
+ const item_t * parent = displayed_parent;
bool by_exclusion = false;
std::string name = maximal_account_name(*i, parent);
- const bool match = (format.show_expanded ||
+ const bool match = (constraints.show_expanded ||
(! constraints.account_masks.empty() &&
matches(constraints.account_masks, name,
&by_exclusion) &&
@@ -45,27 +44,33 @@ void show_balances(std::ostream& out,
(constraints.account_masks.empty() &&
displayed_parent->parent == NULL));
- if (match && reportable(format, *i, true) &&
+ if (match && constraints(*i) &&
((*i)->subitems.size() != 1 ||
(*i)->total != (*i)->subitems[0]->total)) {
- out << format_string(*i, format, parent);
+ out << format.report_line(*i, parent);
parent = *i;
}
+ if (constraints.sort_order)
+ (*i)->sort(constraints.sort_order);
+
show_balances(out, (*i)->subitems, constraints, format, parent);
}
}
void balance_report(std::ostream& out,
- report::item_t * top,
+ item_t * top,
const constraints_t& constraints,
- const report::format_t& format)
+ const format_t& format)
{
+ if (constraints.sort_order)
+ top->sort(constraints.sort_order);
+
show_balances(out, top->subitems, constraints, format, top);
- if (format.show_subtotals && top->subitems.size() > 1 && top->total)
+ if (constraints.show_subtotals && top->subitems.size() > 1 && top->total)
std::cout << "--------------------\n"
- << report::format_string(top, format);
+ << format.report_line(top);
}
@@ -75,7 +80,7 @@ void balance_report(std::ostream& out,
//
static const std::string reg_fmt
- = "%?10d %?-.20p %/%-.22N %12.66t %12.80T\n";
+ = "%10d %-.20p %/%-.22N %12.66t %12.80T\n";
static bool show_commodities_revalued = false;
static bool show_commodities_revalued_only = false;
@@ -84,7 +89,8 @@ static void report_value_change(std::ostream& out,
const std::time_t date,
const balance_pair_t& balance,
const balance_pair_t& prev_balance,
- report::format_t& format,
+ const constraints_t& constraints,
+ const format_t& format,
const std::string& first_line_format,
const std::string& next_lines_format)
{
@@ -95,7 +101,7 @@ static void report_value_change(std::ostream& out,
return;
}
- report::item_t temp;
+ item_t temp;
temp.date = prev_date;
temp.total = prev_balance;
balance_t prev_bal = format.compute_total(&temp);
@@ -109,26 +115,33 @@ static void report_value_change(std::ostream& out,
temp.total = balance;
temp.payee = "Commodities revalued";
- if (reportable(format, &temp)) {
- format.format_string = first_line_format;
- out << format_string(&temp, format, NULL);
+ if (constraints(&temp)) {
+ format_t copy = format;
+
+ copy.format_string = first_line_format;
+ out << copy.report_line(&temp);
+
+ copy.format_string = next_lines_format;
+ out << copy.report_line(&temp);
- format.format_string = next_lines_format;
- out << format_string(&temp, format, NULL);
+ // Prevent double-deletion
+ copy.value_style = NULL;
+ copy.total_style = NULL;
}
}
prev_date = date;
}
-void register_report(std::ostream& out, report::item_t * top,
- const report::format_t& format)
+void register_report(std::ostream& out,
+ item_t * top,
+ const constraints_t& constraints,
+ const format_t& format)
{
- if (format.sort_order)
- std::sort(top->subitems.begin(), top->subitems.end(),
- report::cmp_items(format));
+ if (constraints.sort_order)
+ top->sort(constraints.sort_order);
- report::format_t copy = format;
+ format_t copy = format;
std::string first_line_format;
std::string next_lines_format;
@@ -146,53 +159,55 @@ void register_report(std::ostream& out, report::item_t * top,
balance_pair_t last_reported;
account_t splits(NULL, "<Total>");
- for (report::items_deque::const_iterator i = top->subitems.begin();
+ for (items_deque::const_iterator i = top->subitems.begin();
i != top->subitems.end();
i++) {
copy.format_string = first_line_format;
- std::string header = format_string(*i, copy, top);
+ std::string header = copy.report_line(*i, top);
unsigned int header_len = header.length();
copy.format_string = next_lines_format;
bool first = true;
- if ((*i)->subitems.size() > 1 && ! format.show_expanded) {
- report::item_t summary;
+ if ((*i)->subitems.size() > 1 && ! constraints.show_expanded) {
+ item_t summary;
summary.date = (*i)->date;
summary.parent = *i;
summary.account = &splits;
- for (report::items_deque::const_iterator j = (*i)->subitems.begin();
+ for (items_deque::const_iterator j = (*i)->subitems.begin();
j != (*i)->subitems.end();
j++)
summary.value += (*j)->value;
summary.total = balance + summary.value;
- bool show = reportable(format, &summary);
+ bool show = constraints(&summary);
if (show && show_commodities_revalued)
- report_value_change(out, summary.date, balance, last_reported, copy,
- first_line_format, next_lines_format);
+ report_value_change(out, summary.date, balance, last_reported,
+ constraints, copy, first_line_format,
+ next_lines_format);
balance += summary.value;
if (show) {
if (! show_commodities_revalued_only)
- out << header << format_string(&summary, copy, *i);
+ out << header << copy.report_line(&summary, *i);
if (show_commodities_revalued)
last_reported = balance;
}
} else {
- for (report::items_deque::const_iterator j = (*i)->subitems.begin();
+ for (items_deque::const_iterator j = (*i)->subitems.begin();
j != (*i)->subitems.end();
j++) {
(*j)->total = balance + (*j)->value;
- bool show = reportable(format, *j);
+ bool show = constraints(*j);
if (show && first && show_commodities_revalued) {
- report_value_change(out, (*i)->date, balance, last_reported, copy,
- first_line_format, next_lines_format);
+ report_value_change(out, (*i)->date, balance, last_reported,
+ constraints, copy, first_line_format,
+ next_lines_format);
if (show_commodities_revalued_only)
first = false;
}
@@ -208,7 +223,7 @@ void register_report(std::ostream& out, report::item_t * top,
out.width(header_len);
out << " ";
}
- out << format_string(*j, copy, *i);
+ out << copy.report_line(*j, *i);
}
if (show_commodities_revalued)
last_reported = balance;
@@ -218,12 +233,11 @@ void register_report(std::ostream& out, report::item_t * top,
}
if (show_commodities_revalued)
- report_value_change(out, copy.end(), balance, last_reported, copy,
- first_line_format, next_lines_format);
+ report_value_change(out, constraints.end(), balance, last_reported,
+ constraints, copy, first_line_format,
+ next_lines_format);
// To stop these from getting deleted when copy goes out of scope
- copy.predicate = NULL;
- copy.sort_order = NULL;
copy.value_style = NULL;
copy.total_style = NULL;
}
@@ -493,7 +507,7 @@ int main(int argc, char * argv[])
std::list<std::string> files;
ledger::ledger_t * book = NULL;
ledger::constraints_t constraints;
- ledger::report::format_t format;
+ ledger::format_t format;
std::string sort_order;
std::string value_style = "a";
@@ -623,19 +637,19 @@ int main(int argc, char * argv[])
break;
case 'M':
- format.period = ledger::report::PERIOD_MONTHLY;
+ constraints.period = ledger::PERIOD_MONTHLY;
break;
case 'E':
- format.show_empty = true;
+ constraints.show_empty = true;
break;
case 'n':
- format.show_subtotals = false;
+ constraints.show_subtotals = false;
break;
case 's':
- format.show_expanded = true;
+ constraints.show_expanded = true;
break;
case 'S':
@@ -643,11 +657,11 @@ int main(int argc, char * argv[])
break;
case 'o':
- format.show_related = true;
+ constraints.show_related = true;
break;
case 'l':
- format.predicate = ledger::report::parse_expr(optarg, book);
+ constraints.predicate = ledger::parse_expr(optarg, book);
break;
// Commodity reporting
@@ -791,20 +805,18 @@ int main(int argc, char * argv[])
// Copy the constraints to the format object, and compile the value
// and total style strings
- format.constraints = constraints;
if (! sort_order.empty())
- format.sort_order = ledger::report::parse_expr(sort_order, book);
- format.value_style = ledger::report::parse_expr(value_style, book);
- format.total_style = ledger::report::parse_expr(total_style, book);
+ constraints.sort_order = ledger::parse_expr(sort_order, book);
+ format.value_style = ledger::parse_expr(value_style, book);
+ format.total_style = ledger::parse_expr(total_style, book);
// Now handle the command that was identified above.
if (command == "print") {
#if 0
- ledger::report::item_t * top
- = ledger::report::walk_entries(book->entries.begin(),
- book->entries.end(),
- constraints, format);
+ ledger::item_t * top
+ = ledger::walk_entries(book->entries.begin(), book->entries.end(),
+ constraints, format);
ledger::entry_report(std::cout, top, format);
#ifdef DEBUG
delete top;
@@ -813,9 +825,9 @@ int main(int argc, char * argv[])
}
else if (command == "equity") {
#if 0
- ledger::report::item_t * top
- = ledger::report::walk_accounts(book->master, constraints,
- format.show_subtotals);
+ ledger::item_t * top
+ = ledger::walk_accounts(book->master, constraints,
+ constraints.show_subtotals);
ledger::entry_report(std::cout, top, constraints, format);
@@ -824,15 +836,15 @@ int main(int argc, char * argv[])
#endif
#endif
}
- else if (format.period == ledger::report::PERIOD_NONE &&
- ! format.sort_order && ! format.show_related &&
+ else if (constraints.period == ledger::PERIOD_NONE &&
+ ! constraints.sort_order && ! constraints.show_related &&
(command == "balance" || command == "bal")) {
if (format.format_string.empty())
format.format_string = ledger::bal_fmt;
- if (ledger::report::item_t * top
- = ledger::report::walk_accounts(book->master, constraints,
- format.show_subtotals)) {
+ if (ledger::item_t * top
+ = ledger::walk_accounts(book->master, constraints,
+ constraints.show_subtotals)) {
ledger::balance_report(std::cout, top, constraints, format);
#ifdef DEBUG
delete top;
@@ -843,13 +855,12 @@ int main(int argc, char * argv[])
if (format.format_string.empty())
format.format_string = ledger::bal_fmt;
- if (ledger::report::item_t * list
- = ledger::report::walk_entries(book->entries.begin(),
- book->entries.end(),
- constraints, format))
- if (ledger::report::item_t * top
- = ledger::report::walk_items(list, book->master, constraints,
- format.show_subtotals)) {
+ if (ledger::item_t * list
+ = ledger::walk_entries(book->entries.begin(),
+ book->entries.end(), constraints))
+ if (ledger::item_t * top
+ = ledger::walk_items(list, book->master, constraints,
+ constraints.show_subtotals)) {
ledger::balance_report(std::cout, top, constraints, format);
#ifdef DEBUG
delete top;
@@ -861,14 +872,13 @@ int main(int argc, char * argv[])
if (format.format_string.empty())
format.format_string = ledger::reg_fmt;
- if (format.show_related)
- format.show_inverted = true;
+ if (constraints.show_related)
+ constraints.show_inverted = true;
- if (ledger::report::item_t * top
- = ledger::report::walk_entries(book->entries.begin(),
- book->entries.end(),
- constraints, format)) {
- ledger::register_report(std::cout, top, format);
+ if (ledger::item_t * top
+ = ledger::walk_entries(book->entries.begin(),
+ book->entries.end(), constraints)) {
+ ledger::register_report(std::cout, top, constraints, format);
#ifdef DEBUG
delete top;
#endif