summaryrefslogtreecommitdiff
path: root/src/print.cc
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2010-06-13 00:42:25 -0400
committerJohn Wiegley <johnw@newartisans.com>2010-06-13 00:42:25 -0400
commit40f553228f5a28034c6635fdcb4c86af28a385ed (patch)
tree2c40305c9f9841a4c3d453a4a5c49ec69056b4b2 /src/print.cc
parent556211e623cad88213e5087b5c9c36e754d9aa02 (diff)
parentb1b4e2aadff5983d443d70c09ea86a41b015873f (diff)
downloadfork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.tar.gz
fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.tar.bz2
fork-ledger-40f553228f5a28034c6635fdcb4c86af28a385ed.zip
Merge branch 'next'
Diffstat (limited to 'src/print.cc')
-rw-r--r--src/print.cc188
1 files changed, 94 insertions, 94 deletions
diff --git a/src/print.cc b/src/print.cc
index 84aa441f..de35a31d 100644
--- a/src/print.cc
+++ b/src/print.cc
@@ -41,10 +41,10 @@
namespace ledger {
namespace {
- void print_note(std::ostream& out,
- const string& note,
- const std::size_t columns,
- const std::size_t prior_width)
+ void print_note(std::ostream& out,
+ const string& note,
+ const std::size_t columns,
+ const std::size_t prior_width)
{
// The 4 is for four leading spaces at the beginning of the posting, and
// the 3 is for two spaces and a semi-colon before the note.
@@ -56,20 +56,20 @@ namespace {
bool need_separator = false;
for (const char * p = note.c_str(); *p; p++) {
if (*p == '\n') {
- need_separator = true;
+ need_separator = true;
} else {
- if (need_separator) {
- out << "\n ;";
- need_separator = false;
- }
- out << *p;
+ if (need_separator) {
+ out << "\n ;";
+ need_separator = false;
+ }
+ out << *p;
}
}
}
void print_xact(report_t& report, std::ostream& out, xact_t& xact)
{
- format_type_t format_type = FMT_WRITTEN;
+ format_type_t format_type = FMT_WRITTEN;
optional<const char *> format;
if (report.HANDLED(date_format_)) {
@@ -80,15 +80,15 @@ namespace {
std::ostringstream buf;
buf << format_date(item_t::use_effective_date ?
- xact.date() : xact.actual_date(),
- format_type, format);
+ xact.date() : xact.actual_date(),
+ format_type, format);
if (! item_t::use_effective_date && xact.effective_date())
buf << '=' << format_date(*xact.effective_date(),
- format_type, format);
+ format_type, format);
buf << ' ';
buf << (xact.state() == item_t::CLEARED ? "* " :
- (xact.state() == item_t::PENDING ? "! " : ""));
+ (xact.state() == item_t::PENDING ? "! " : ""));
if (xact.code)
buf << '(' << *xact.code << ") ";
@@ -99,7 +99,7 @@ namespace {
out << leader;
std::size_t columns = (report.HANDLED(columns_) ?
- report.HANDLER(columns_).value.to_long() : 80);
+ report.HANDLER(columns_).value.to_long() : 80);
if (xact.note)
print_note(out, *xact.note, columns, unistring(leader).length());
@@ -107,112 +107,112 @@ namespace {
if (xact.metadata) {
foreach (const item_t::string_map::value_type& data, *xact.metadata) {
- if (! data.second.second) {
- out << " ; ";
- if (data.second.first)
- out << data.first << ": " << *data.second.first;
- else
- out << ':' << data.first << ":";
- out << '\n';
- }
+ if (! data.second.second) {
+ out << " ; ";
+ if (data.second.first)
+ out << data.first << ": " << *data.second.first;
+ else
+ out << ':' << data.first << ":";
+ out << '\n';
+ }
}
}
foreach (post_t * post, xact.posts) {
- if (post->has_flags(ITEM_TEMP | ITEM_GENERATED) &&
- ! post->has_flags(POST_ANONYMIZED) &&
- ! report.HANDLED(print_virtual))
- continue;
+ if (! report.HANDLED(generated) &&
+ (post->has_flags(ITEM_TEMP | ITEM_GENERATED) &&
+ ! post->has_flags(POST_ANONYMIZED)))
+ continue;
out << " ";
std::ostringstream buf;
if (xact.state() == item_t::UNCLEARED)
- buf << (post->state() == item_t::CLEARED ? "* " :
- (post->state() == item_t::PENDING ? "! " : ""));
+ buf << (post->state() == item_t::CLEARED ? "* " :
+ (post->state() == item_t::PENDING ? "! " : ""));
if (post->has_flags(POST_VIRTUAL)) {
- if (post->has_flags(POST_MUST_BALANCE))
- buf << '[';
- else
- buf << '(';
+ if (post->has_flags(POST_MUST_BALANCE))
+ buf << '[';
+ else
+ buf << '(';
}
buf << post->account->fullname();
if (post->has_flags(POST_VIRTUAL)) {
- if (post->has_flags(POST_MUST_BALANCE))
- buf << ']';
- else
- buf << ')';
+ if (post->has_flags(POST_MUST_BALANCE))
+ buf << ']';
+ else
+ buf << ')';
}
unistring name(buf.str());
std::size_t account_width =
- (report.HANDLER(account_width_).specified ?
- report.HANDLER(account_width_).value.to_long() : 36);
+ (report.HANDLER(account_width_).specified ?
+ report.HANDLER(account_width_).value.to_long() : 36);
if (account_width < name.length())
- account_width = name.length();
-
- if (! post->has_flags(POST_CALCULATED) || report.HANDLED(print_virtual)) {
- out << name.extract();
- int slip = (static_cast<int>(account_width) -
- static_cast<int>(name.length()));
- if (slip > 0) {
- out.width(slip);
- out << ' ';
- }
-
- std::ostringstream amtbuf;
-
- string amt;
- if (post->amount_expr) {
- amt = post->amount_expr->text();
- } else {
- int amount_width =
- (report.HANDLER(amount_width_).specified ?
- report.HANDLER(amount_width_).value.to_int() : 12);
-
- std::ostringstream amt_str;
- value_t(post->amount).print(amt_str, amount_width, -1,
- AMOUNT_PRINT_RIGHT_JUSTIFY |
- AMOUNT_PRINT_NO_COMPUTED_ANNOTATIONS);
- amt = amt_str.str();
- }
-
- string trimmed_amt(amt);
- trim_left(trimmed_amt);
- int amt_slip = (static_cast<int>(amt.length()) -
- static_cast<int>(trimmed_amt.length()));
- if (slip + amt_slip < 2)
- amtbuf << string(2 - (slip + amt_slip), ' ');
- amtbuf << amt;
-
- if (post->cost &&
- ! post->has_flags(POST_CALCULATED | POST_COST_CALCULATED)) {
- if (post->has_flags(POST_COST_IN_FULL))
- amtbuf << " @@ " << post->cost->abs();
- else
- amtbuf << " @ "
- << (*post->cost / post->amount).abs();
- }
-
- if (post->assigned_amount)
- amtbuf << " = " << post->assigned_amount;
-
- string trailer = amtbuf.str();
- out << trailer;
-
- account_width += unistring(trailer).length();
+ account_width = name.length();
+
+ if (! post->has_flags(POST_CALCULATED) || report.HANDLED(generated)) {
+ out << name.extract();
+ int slip = (static_cast<int>(account_width) -
+ static_cast<int>(name.length()));
+ if (slip > 0) {
+ out.width(slip);
+ out << ' ';
+ }
+
+ std::ostringstream amtbuf;
+
+ string amt;
+ if (post->amount_expr) {
+ amt = post->amount_expr->text();
+ } else {
+ int amount_width =
+ (report.HANDLER(amount_width_).specified ?
+ report.HANDLER(amount_width_).value.to_int() : 12);
+
+ std::ostringstream amt_str;
+ value_t(post->amount).print(amt_str, amount_width, -1,
+ AMOUNT_PRINT_RIGHT_JUSTIFY |
+ AMOUNT_PRINT_NO_COMPUTED_ANNOTATIONS);
+ amt = amt_str.str();
+ }
+
+ string trimmed_amt(amt);
+ trim_left(trimmed_amt);
+ int amt_slip = (static_cast<int>(amt.length()) -
+ static_cast<int>(trimmed_amt.length()));
+ if (slip + amt_slip < 2)
+ amtbuf << string(2 - (slip + amt_slip), ' ');
+ amtbuf << amt;
+
+ if (post->cost &&
+ ! post->has_flags(POST_CALCULATED | POST_COST_CALCULATED)) {
+ if (post->has_flags(POST_COST_IN_FULL))
+ amtbuf << " @@ " << post->cost->abs();
+ else
+ amtbuf << " @ "
+ << (*post->cost / post->amount).abs();
+ }
+
+ if (post->assigned_amount)
+ amtbuf << " = " << post->assigned_amount;
+
+ string trailer = amtbuf.str();
+ out << trailer;
+
+ account_width += unistring(trailer).length();
} else {
- out << buf.str();
+ out << buf.str();
}
if (post->note)
- print_note(out, *post->note, columns, 4 + account_width);
+ print_note(out, *post->note, columns, 4 + account_width);
out << '\n';
}
}