summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2005-06-23 00:09:13 +0000
committerJohn Wiegley <johnw@newartisans.com>2008-04-13 02:41:13 -0400
commit92e591c23729681b49b85001694a30e84715253f (patch)
treef997df17ed6e58cd6086bf01ae83714e1439ac2c
parentafa807a678a04b042a2f30b1cd55170424340f6f (diff)
downloadfork-ledger-92e591c23729681b49b85001694a30e84715253f.tar.gz
fork-ledger-92e591c23729681b49b85001694a30e84715253f.tar.bz2
fork-ledger-92e591c23729681b49b85001694a30e84715253f.zip
(parse): Set the beginning and ending line number for each entry as it
is parsed.
-rw-r--r--textual.cc27
1 files changed, 17 insertions, 10 deletions
diff --git a/textual.cc b/textual.cc
index 10c09cef..ab74dd81 100644
--- a/textual.cc
+++ b/textual.cc
@@ -466,7 +466,8 @@ unsigned int textual_parser_t::parse(std::istream& in,
while (in.good() && ! in.eof()) {
try {
- istream_pos_type beg_pos = in.tellg();
+ istream_pos_type beg_pos = in.tellg();
+ unsigned long beg_line = linenum;
in.getline(line, MAX_LINE);
if (in.eof())
@@ -629,9 +630,11 @@ unsigned int textual_parser_t::parse(std::istream& in,
if (parse_transactions(in, account_stack.front(), *ae, "automated")) {
if (ae->finalize()) {
journal->auto_entries.push_back(ae);
- ae->src_idx = src_idx;
- ae->beg_pos = beg_pos;
- ae->end_pos = in.tellg();
+ ae->src_idx = src_idx;
+ ae->beg_pos = beg_pos;
+ ae->beg_line = beg_line;
+ ae->end_pos = in.tellg();
+ ae->end_line = linenum;
} else {
throw parse_error(path, linenum,
"Automated entry failed to balance");
@@ -650,9 +653,11 @@ unsigned int textual_parser_t::parse(std::istream& in,
if (pe->finalize()) {
extend_entry_base(journal, *pe);
journal->period_entries.push_back(pe);
- pe->src_idx = src_idx;
- pe->beg_pos = beg_pos;
- pe->end_pos = in.tellg();
+ pe->src_idx = src_idx;
+ pe->beg_pos = beg_pos;
+ pe->beg_line = beg_line;
+ pe->end_pos = in.tellg();
+ pe->end_line = linenum;
} else {
throw parse_error(path, linenum, "Period entry failed to balance");
}
@@ -723,9 +728,11 @@ unsigned int textual_parser_t::parse(std::istream& in,
if (entry_t * entry = parse_entry(in, line, account_stack.front(),
*this)) {
if (journal->add_entry(entry)) {
- entry->src_idx = src_idx;
- entry->beg_pos = beg_pos;
- entry->end_pos = in.tellg();
+ entry->src_idx = src_idx;
+ entry->beg_pos = beg_pos;
+ entry->beg_line = beg_line;
+ entry->end_pos = in.tellg();
+ entry->end_line = linenum;
count++;
} else {
print_entry(std::cerr, *entry);