diff options
author | John Wiegley <johnw@newartisans.com> | 2005-02-09 05:02:01 +0000 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2008-04-13 02:40:54 -0400 |
commit | 4fda55175204c31d833975c0ccb968e0b8f6039a (patch) | |
tree | f959c5e4b0f46472d8fd8d98e734bb4012feaa5f | |
parent | 64461f0d95b418fe2320bd8d92363fb7c9f899ae (diff) | |
download | fork-ledger-4fda55175204c31d833975c0ccb968e0b8f6039a.tar.gz fork-ledger-4fda55175204c31d833975c0ccb968e0b8f6039a.tar.bz2 fork-ledger-4fda55175204c31d833975c0ccb968e0b8f6039a.zip |
(parse_elements): Added %S, %B and %E elements, for printing the
source path, beginning and ending positions of an entry.
-rw-r--r-- | format.cc | 29 | ||||
-rw-r--r-- | format.h | 3 |
2 files changed, 31 insertions, 1 deletions
@@ -180,6 +180,9 @@ element_t * format_t::parse_elements(const std::string& fmt) current->chars = format_t::date_format; break; + case 'S': current->type = element_t::SOURCE; break; + case 'B': current->type = element_t::BEG_POS; break; + case 'E': current->type = element_t::END_POS; break; case 'X': current->type = element_t::CLEARED; break; case 'C': current->type = element_t::CODE; break; case 'P': current->type = element_t::PAYEE; break; @@ -296,7 +299,8 @@ void format_t::format(std::ostream& out_str, const details_t& details) const if (! has_flag) unit_cost.commodity().flags &= ~COMMODITY_STYLE_VARIABLE; - } else { + } + else if (details.entry) { unsigned int xacts_count = 0; transaction_t * first = NULL; transaction_t * last = NULL; @@ -324,6 +328,29 @@ void format_t::format(std::ostream& out_str, const details_t& details) const } break; + case element_t::SOURCE: + if (details.entry) { + int idx = details.entry->src_idx; + for (strings_list::iterator i = details.entry->journal->sources.begin(); + i != details.entry->journal->sources.end(); + i++) + if (! idx--) { + out << *i; + break; + } + } + break; + + case element_t::BEG_POS: + if (details.entry) + out << (unsigned long)details.entry->beg_pos; + break; + + case element_t::END_POS: + if (details.entry) + out << (unsigned long)details.entry->end_pos; + break; + case element_t::DATE_STRING: if (details.entry && details.entry->date) { char buf[256]; @@ -17,6 +17,9 @@ struct element_t enum kind_t { STRING, VALUE_EXPR, + SOURCE, + BEG_POS, + END_POS, DATE_STRING, CLEARED, CODE, |