summaryrefslogtreecommitdiff
path: root/src/session.cc
diff options
context:
space:
mode:
Diffstat (limited to 'src/session.cc')
-rw-r--r--src/session.cc118
1 files changed, 15 insertions, 103 deletions
diff --git a/src/session.cc b/src/session.cc
index f3d01eec..a1ff4892 100644
--- a/src/session.cc
+++ b/src/session.cc
@@ -33,7 +33,6 @@
#include "report.h"
#include "iterators.h"
#include "filters.h"
-#include "textual.h"
namespace ledger {
@@ -61,7 +60,8 @@ session_t::session_t()
current_year(CURRENT_DATE().year()),
commodity_pool(new commodity_pool_t),
- master(new account_t(NULL, ""))
+ master(new account_t(NULL, "")),
+ journal(new journal_t(master.get()))
{
TRACE_CTOR(session_t, "");
@@ -70,8 +70,6 @@ session_t::session_t()
else
HANDLER(price_db_).on(path("./.pricedb").string());
- register_parser(new textual_parser_t);
-
// Add time commodity conversions, so that timelog's may be parsed
// in terms of seconds, but reported as minutes or hours.
if (commodity_t * commodity = commodity_pool->create("s"))
@@ -80,58 +78,26 @@ session_t::session_t()
assert(false);
}
-journal_t * session_t::create_journal()
-{
- journal_t * journal = new journal_t(master.get());
- journals.push_back(journal);
- return journal;
-}
-
-void session_t::close_journal(journal_t * journal)
-{
- for (ptr_list<journal_t>::iterator i = journals.begin();
- i != journals.end();
- i++)
- if (&*i == journal) {
- journals.erase(i);
- return;
- }
- assert(false);
- checked_delete(journal);
-}
-
-std::size_t session_t::read_journal(journal_t& journal,
- std::istream& in,
+std::size_t session_t::read_journal(std::istream& in,
const path& pathname,
account_t * master)
{
if (! master)
- master = journal.master;
-
- foreach (journal_t::parser_t& parser, parsers)
-#if defined(TEST_FOR_PARSER)
- if (parser.test(in))
-#endif
- return parser.parse(in, *this, journal, master, &pathname);
-
- return 0;
+ master = journal->master;
+ return journal->parse(in, *this, master, &pathname);
}
-std::size_t session_t::read_journal(journal_t& journal,
- const path& pathname,
+std::size_t session_t::read_journal(const path& pathname,
account_t * master)
{
- journal.sources.push_back(pathname);
-
if (! exists(pathname))
throw_(std::logic_error, "Cannot read file" << pathname);
ifstream stream(pathname);
- return read_journal(journal, stream, pathname, master);
+ return read_journal(stream, pathname, master);
}
-std::size_t session_t::read_data(journal_t& journal,
- const string& master_account)
+std::size_t session_t::read_data(const string& master_account)
{
if (HANDLER(file_).data_files.empty())
throw_(parse_error, "No journal file was specified (please use -f)");
@@ -139,24 +105,18 @@ std::size_t session_t::read_data(journal_t& journal,
std::size_t entry_count = 0;
if (entry_count == 0) {
- account_t * acct = journal.master;
+ account_t * acct = journal->master;
if (! master_account.empty())
- acct = journal.find_account(master_account);
+ acct = journal->find_account(master_account);
- journal.price_db = HANDLER(price_db_).str();
- if (journal.price_db && exists(*journal.price_db)) {
- if (read_journal(journal, *journal.price_db)) {
+ if (HANDLED(price_db_) && exists(path(HANDLER(price_db_).str()))) {
+ if (read_journal(HANDLER(price_db_).str()))
throw_(parse_error, "Entries not allowed in price history file");
- } else {
- journal.sources.pop_back();
- }
}
foreach (const path& pathname, HANDLER(file_).data_files) {
if (pathname == "-") {
- journal.sources.push_back("/dev/stdin");
-
// To avoid problems with stdin and pipes, etc., we read the entire
// file in beforehand into a memory buffer, and then parcel it out
// from there.
@@ -172,12 +132,10 @@ std::size_t session_t::read_data(journal_t& journal,
std::istringstream buf_in(buffer.str());
- entry_count += read_journal(journal, buf_in, "/dev/stdin", acct);
+ entry_count += read_journal(buf_in, "/dev/stdin", acct);
}
else if (exists(pathname)) {
- entry_count += read_journal(journal, pathname, acct);
- if (journal.price_db)
- journal.sources.push_back(*journal.price_db);
+ entry_count += read_journal(pathname, acct);
}
else {
throw_(parse_error, "Could not open journal file '" << pathname << "'");
@@ -185,25 +143,11 @@ std::size_t session_t::read_data(journal_t& journal,
}
}
- VERIFY(journal.valid());
+ VERIFY(journal->valid());
return entry_count;
}
-void session_t::unregister_parser(journal_t::parser_t * parser)
-{
- for (ptr_list<journal_t::parser_t>::iterator i = parsers.begin();
- i != parsers.end();
- i++) {
- if (&*i == parser) {
- parsers.erase(i);
- return;
- }
- }
- assert(false);
- checked_delete(parser);
-}
-
void session_t::clean_xacts()
{
session_xacts_iterator walker(*this);
@@ -223,38 +167,6 @@ void session_t::clean_accounts()
master->clear_xdata();
}
-#if 0
-value_t session_t::resolve(const string& name, expr_t::scope_t& locals)
-{
- const char * p = name.c_str();
- switch (*p) {
- case 'd':
-#if 0
- if (name == "date_format") {
- // jww (2007-04-18): What to do here?
- return string_value(moment_t::output_format);
- }
-#endif
- break;
-
- case 'n':
- switch (*++p) {
- case 'o':
- if (name == "now")
- return value_t(now);
- break;
- }
- break;
-
- case 'r':
- if (name == "register_format")
- return string_value(register_format);
- break;
- }
- return expr_t::scope_t::resolve(name, locals);
-}
-#endif
-
option_t<session_t> * session_t::lookup_option(const char * p)
{
switch (*p) {