summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJohn Wiegley <johnw@newartisans.com>2010-02-04 18:23:52 -0500
committerJohn Wiegley <johnw@newartisans.com>2010-02-04 18:23:52 -0500
commitb78e22d52b75cafd63678ee786b1653afffa49e6 (patch)
treebdb9fbeb401fde311189451b8b792dd69702baba /src
parentc92a54b0ab510762e10cd4cab1082a9e59716025 (diff)
downloadfork-ledger-b78e22d52b75cafd63678ee786b1653afffa49e6.tar.gz
fork-ledger-b78e22d52b75cafd63678ee786b1653afffa49e6.tar.bz2
fork-ledger-b78e22d52b75cafd63678ee786b1653afffa49e6.zip
Added a "seq" sequence property for all items
This indicates the absolute parsing order of every transaction and posting. It is 0 for generated items.
Diffstat (limited to 'src')
-rw-r--r--src/item.cc6
-rw-r--r--src/item.h6
-rw-r--r--src/textual.cc47
3 files changed, 39 insertions, 20 deletions
diff --git a/src/item.cc b/src/item.cc
index 0e596f33..135fa18f 100644
--- a/src/item.cc
+++ b/src/item.cc
@@ -296,6 +296,10 @@ namespace {
return item.pos ? long(item.pos->end_line) : 0L;
}
+ value_t get_seq(item_t& item) {
+ return item.pos ? long(item.pos->sequence) : 0L;
+ }
+
value_t get_depth(item_t&) {
return 0L;
}
@@ -416,6 +420,8 @@ expr_t::ptr_op_t item_t::lookup(const symbol_t::kind_t kind,
case 's':
if (name == "status")
return WRAP_FUNCTOR(get_wrapper<&get_status>);
+ else if (name == "seq")
+ return WRAP_FUNCTOR(get_wrapper<&get_seq>);
break;
case 't':
diff --git a/src/item.h b/src/item.h
index 84385eb7..8250ab6e 100644
--- a/src/item.h
+++ b/src/item.h
@@ -53,8 +53,10 @@ struct position_t
std::size_t beg_line;
istream_pos_type end_pos;
std::size_t end_line;
+ std::size_t sequence;
- position_t() : beg_pos(0), beg_line(0), end_pos(0), end_line(0) {
+ position_t()
+ : beg_pos(0), beg_line(0), end_pos(0), end_line(0), sequence(0) {
TRACE_CTOR(position_t, "");
}
position_t(const position_t& pos) {
@@ -72,6 +74,7 @@ struct position_t
beg_line = pos.beg_line;
end_pos = pos.end_pos;
end_line = pos.end_line;
+ sequence = pos.sequence;
}
return *this;
}
@@ -89,6 +92,7 @@ private:
ar & beg_line;
ar & end_pos;
ar & end_line;
+ ar & sequence;
}
#endif // HAVE_BOOST_SERIALIZATION
};
diff --git a/src/textual.cc b/src/textual.cc
index cbeb6358..697a22f8 100644
--- a/src/textual.cc
+++ b/src/textual.cc
@@ -77,6 +77,7 @@ namespace {
istream_pos_type curr_pos;
std::size_t count;
std::size_t errors;
+ std::size_t * global_sequence;
optional<date_t::year_type> current_year;
@@ -87,10 +88,11 @@ namespace {
std::istream& _in,
scope_t& _scope,
journal_t& _journal,
- account_t * _master = NULL,
- const path * _original_file = NULL,
- bool _strict = false,
- instance_t * _parent = NULL);
+ std::size_t * _global_sequence = NULL,
+ account_t * _master = NULL,
+ const path * _original_file = NULL,
+ bool _strict = false,
+ instance_t * _parent = NULL);
~instance_t();
@@ -213,6 +215,7 @@ instance_t::instance_t(std::list<state_t>& _state_stack,
std::istream& _in,
scope_t& _scope,
journal_t& _journal,
+ std::size_t * _global_sequence,
account_t * _master,
const path * _original_file,
bool _strict,
@@ -223,7 +226,8 @@ instance_t::instance_t(std::list<state_t>& _state_stack,
#endif
parent(_parent), in(_in), scope(_scope),
journal(_journal), master(_master),
- original_file(_original_file), strict(_strict)
+ original_file(_original_file), strict(_strict),
+ global_sequence(_global_sequence)
{
TRACE_CTOR(instance_t, "...");
@@ -452,6 +456,7 @@ void instance_t::clock_in_directive(char * line,
position.beg_line = linenum;
position.end_pos = curr_pos;
position.end_line = linenum;
+ position.sequence = (*global_sequence)++;
time_xact_t event(position, parse_datetime(datetime, current_year),
p ? top_account()->find_account(p) : NULL,
@@ -481,6 +486,7 @@ void instance_t::clock_out_directive(char * line,
position.beg_line = linenum;
position.end_pos = curr_pos;
position.end_line = linenum;
+ position.sequence = (*global_sequence)++;
time_xact_t event(position, parse_datetime(datetime, current_year),
p ? top_account()->find_account(p) : NULL,
@@ -554,8 +560,7 @@ void instance_t::option_directive(char * line)
void instance_t::automated_xact_directive(char * line)
{
- istream_pos_type pos = line_beg_pos;
- std::size_t lnum = linenum;
+ istream_pos_type pos= line_beg_pos;
bool reveal_context = true;
@@ -564,6 +569,11 @@ void instance_t::automated_xact_directive(char * line)
std::auto_ptr<auto_xact_t> ae
(new auto_xact_t(query_t(string(skip_ws(line + 1)),
keep_details_t(true, true, true))));
+ ae->pos = position_t();
+ ae->pos->pathname = pathname;
+ ae->pos->beg_pos = line_beg_pos;
+ ae->pos->beg_line = linenum;
+ ae->pos->sequence = (*global_sequence)++;
reveal_context = false;
@@ -573,10 +583,6 @@ void instance_t::automated_xact_directive(char * line)
journal.auto_xacts.push_back(ae.get());
ae->journal = &journal;
- ae->pos = position_t();
- ae->pos->pathname = pathname;
- ae->pos->beg_pos = pos;
- ae->pos->beg_line = lnum;
ae->pos->end_pos = curr_pos;
ae->pos->end_line = linenum;
@@ -595,14 +601,18 @@ void instance_t::automated_xact_directive(char * line)
void instance_t::period_xact_directive(char * line)
{
- istream_pos_type pos = line_beg_pos;
- std::size_t lnum = linenum;
+ istream_pos_type pos = line_beg_pos;
bool reveal_context = true;
try {
std::auto_ptr<period_xact_t> pe(new period_xact_t(skip_ws(line + 1)));
+ pe->pos = position_t();
+ pe->pos->pathname = pathname;
+ pe->pos->beg_pos = line_beg_pos;
+ pe->pos->beg_line = linenum;
+ pe->pos->sequence = (*global_sequence)++;
reveal_context = false;
@@ -614,10 +624,6 @@ void instance_t::period_xact_directive(char * line)
journal.extend_xact(pe.get());
journal.period_xacts.push_back(pe.get());
- pe->pos = position_t();
- pe->pos->pathname = pathname;
- pe->pos->beg_pos = pos;
- pe->pos->beg_line = lnum;
pe->pos->end_pos = curr_pos;
pe->pos->end_line = linenum;
@@ -694,7 +700,7 @@ void instance_t::include_directive(char * line)
#if defined(TIMELOG_SUPPORT)
timelog,
#endif
- stream, scope, journal, master,
+ stream, scope, journal, global_sequence, master,
&filename, strict, this);
instance.parse();
@@ -880,6 +886,7 @@ post_t * instance_t::parse_post(char * line,
post->pos->pathname = pathname;
post->pos->beg_pos = line_beg_pos;
post->pos->beg_line = linenum;
+ post->pos->sequence = (*global_sequence)++;
char buf[MAX_LINE + 1];
std::strcpy(buf, line);
@@ -1229,6 +1236,7 @@ xact_t * instance_t::parse_xact(char * line,
xact->pos->pathname = pathname;
xact->pos->beg_pos = line_beg_pos;
xact->pos->beg_line = linenum;
+ xact->pos->sequence = (*global_sequence)++;
bool reveal_context = true;
@@ -1378,11 +1386,12 @@ std::size_t journal_t::parse(std::istream& in,
time_log_t timelog(*this);
#endif
+ std::size_t parsing_sequence = 1;
instance_t parsing_instance(state_stack,
#if defined(TIMELOG_SUPPORT)
timelog,
#endif
- in, scope, *this, master,
+ in, scope, *this, &parsing_sequence, master,
original_file, strict);
parsing_instance.parse();