summaryrefslogtreecommitdiff
path: root/main.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2004-09-14 19:15:08 -0400
committerJohn Wiegley <johnw@newartisans.com>2004-09-14 19:15:08 -0400
commit5d99b1e24179d65e75431b8d5dfbe6e11acb0d24 (patch)
tree7b3c72dd84407d9940f5c3342075a64b243086fc /main.cc
parent23799b5f4efdc6c211e1d9421964c90c7563345a (diff)
downloadfork-ledger-5d99b1e24179d65e75431b8d5dfbe6e11acb0d24.tar.gz
fork-ledger-5d99b1e24179d65e75431b8d5dfbe6e11acb0d24.tar.bz2
fork-ledger-5d99b1e24179d65e75431b8d5dfbe6e11acb0d24.zip
using main.py is now only 50% slower than using main.cc
Diffstat (limited to 'main.cc')
-rw-r--r--main.cc26
1 files changed, 15 insertions, 11 deletions
diff --git a/main.cc b/main.cc
index 8dd3d9c6..ffab30da 100644
--- a/main.cc
+++ b/main.cc
@@ -237,10 +237,16 @@ int parse_and_report(int argc, char * argv[], char * envp[])
return 1;
}
- // Walk the entries based on the report type and the options
+ // Configure the output stream
TIMER_START(report_gen);
+ std::ostream * out = &std::cout;
+ if (! config.output_file.empty())
+ out = new std::ofstream(config.output_file.c_str());
+
+ // Walk the entries based on the report type and the options
+
item_handler<transaction_t> * formatter;
std::list<item_handler<transaction_t> *> formatter_ptrs;
@@ -248,9 +254,7 @@ int parse_and_report(int argc, char * argv[], char * envp[])
formatter = new set_account_value;
formatter = chain_formatters(command, formatter, formatter_ptrs);
} else {
- std::ostream& out(config.output_stream ?
- *config.output_stream : std::cout);
- formatter = new format_transactions(out, config.format, config.nformat);
+ formatter = new format_transactions(*out, config.format, config.nformat);
formatter = chain_formatters(command, formatter, formatter_ptrs);
}
@@ -263,11 +267,8 @@ int parse_and_report(int argc, char * argv[], char * envp[])
// For the balance and equity reports, output the sum totals.
- std::ostream& out(config.output_stream ?
- *config.output_stream : std::cout);
-
if (command == "b") {
- format_account acct_formatter(out, config.format,
+ format_account acct_formatter(*out, config.format,
config.display_predicate);
sum_accounts(*journal->master);
walk_accounts(*journal->master, acct_formatter, config.sort_order);
@@ -277,13 +278,13 @@ int parse_and_report(int argc, char * argv[], char * envp[])
ACCT_DATA(journal->master)->value = ACCT_DATA(journal->master)->total;
if (ACCT_DATA(journal->master)->dflags & ACCOUNT_TO_DISPLAY) {
- out << "--------------------\n";
- config.format.format(out, details_t(*journal->master));
+ *out << "--------------------\n";
+ config.format.format(*out, details_t(*journal->master));
}
}
}
else if (command == "E") {
- format_equity acct_formatter(out, config.format, config.nformat,
+ format_equity acct_formatter(*out, config.format, config.nformat,
config.display_predicate);
sum_accounts(*journal->master);
walk_accounts(*journal->master, acct_formatter, config.sort_order);
@@ -291,6 +292,9 @@ int parse_and_report(int argc, char * argv[], char * envp[])
}
#if DEBUG_LEVEL >= BETA
+ if (! config.output_file.empty())
+ delete out;
+
for (std::list<item_handler<transaction_t> *>::iterator i
= formatter_ptrs.begin();
i != formatter_ptrs.end();