From 0a8b36de3f32f360ffdfc7c6d2e07b11345c7a1d Mon Sep 17 00:00:00 2001 From: John Wiegley Date: Thu, 16 Feb 2006 01:01:38 +0000 Subject: Made several changes to the parsing infrastructure to allow passing the "config_t" object around. This is needed for parsing option settings in the initialization file. --- binary.cc | 1 + binary.h | 1 + config.cc | 1 + gnucash.cc | 1 + gnucash.h | 1 + main.cc | 4 ++- ofx.cc | 1 + ofx.h | 1 + parser.cc | 106 +++++++++++++++++++++++++++++++------------------------------ parser.h | 23 ++++++-------- qif.cc | 1 + qif.h | 1 + textual.cc | 8 +++-- textual.h | 1 + xml.cc | 9 +++--- xml.h | 1 + 16 files changed, 88 insertions(+), 73 deletions(-) diff --git a/binary.cc b/binary.cc index 4953cf7e..687f3540 100644 --- a/binary.cc +++ b/binary.cc @@ -495,6 +495,7 @@ bool binary_parser_t::test(std::istream& in) const } unsigned int binary_parser_t::parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master, const std::string * original_file) diff --git a/binary.h b/binary.h index 4b362faa..ca3254c9 100644 --- a/binary.h +++ b/binary.h @@ -12,6 +12,7 @@ class binary_parser_t : public parser_t virtual bool test(std::istream& in) const; virtual unsigned int parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master = NULL, const std::string * original_file = NULL); diff --git a/config.cc b/config.cc index 40294ad0..ac197fd3 100644 --- a/config.cc +++ b/config.cc @@ -988,6 +988,7 @@ OPT_BEGIN(total_data, "J") { OPT_BEGIN(price_db, ":") { config->price_db = optarg; + std::cerr << "Setting --price_db=" << optarg << std::endl; } OPT_END(price_db); OPT_BEGIN(price_exp, "Z:") { diff --git a/gnucash.cc b/gnucash.cc index 02e5b477..b90c797e 100644 --- a/gnucash.cc +++ b/gnucash.cc @@ -352,6 +352,7 @@ bool gnucash_parser_t::test(std::istream& in) const } unsigned int gnucash_parser_t::parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master, const std::string * original_file) diff --git a/gnucash.h b/gnucash.h index 6b71fffa..6945e55f 100644 --- a/gnucash.h +++ b/gnucash.h @@ -11,6 +11,7 @@ class gnucash_parser_t : public parser_t virtual bool test(std::istream& in) const; virtual unsigned int parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master = NULL, const std::string * original_file = NULL); diff --git a/main.cc b/main.cc index cf53be68..89f032b1 100644 --- a/main.cc +++ b/main.cc @@ -68,8 +68,10 @@ int parse_and_report(int argc, char * argv[], char * envp[]) config.process_option("file", p); if (const char * p = std::getenv("LEDGER_INIT")) config.process_option("init-file", p); +#if 0 if (const char * p = std::getenv("PRICE_HIST")) config.process_option("price-db", p); +#endif if (const char * p = std::getenv("PRICE_EXP")) config.process_option("price-exp", p); #endif @@ -128,7 +130,7 @@ int parse_and_report(int argc, char * argv[], char * envp[]) TIMER_START(parse); - if (parse_ledger_data(journal.get(), config) == 0) + if (parse_ledger_data(config, journal.get()) == 0) throw error("Please specify ledger file using -f" " or LEDGER_FILE environment variable."); diff --git a/ofx.cc b/ofx.cc index 7aa95256..97cb7302 100644 --- a/ofx.cc +++ b/ofx.cc @@ -196,6 +196,7 @@ bool ofx_parser_t::test(std::istream& in) const } unsigned int ofx_parser_t::parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master, const std::string * original_file) diff --git a/ofx.h b/ofx.h index 9b017bfa..232daecb 100644 --- a/ofx.h +++ b/ofx.h @@ -11,6 +11,7 @@ class ofx_parser_t : public parser_t virtual bool test(std::istream& in) const; virtual unsigned int parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master = NULL, const std::string * original_file = NULL); diff --git a/parser.cc b/parser.cc index cdb3a810..cc257a2e 100644 --- a/parser.cc +++ b/parser.cc @@ -57,6 +57,7 @@ bool unregister_parser(parser_t * parser) } unsigned int parse_journal(std::istream& in, + config_t& config, journal_t * journal, account_t * master, const std::string * original_file) @@ -68,12 +69,13 @@ unsigned int parse_journal(std::istream& in, i != parsers->end(); i++) if ((*i)->test(in)) - return (*i)->parse(in, journal, master, original_file); + return (*i)->parse(in, config, journal, master, original_file); return 0; } unsigned int parse_journal_file(const std::string& path, + config_t& config, journal_t * journal, account_t * master, const std::string * original_file) @@ -87,48 +89,58 @@ unsigned int parse_journal_file(const std::string& path, original_file = &path; std::ifstream stream(path.c_str()); - return parse_journal(stream, journal, master, original_file); + return parse_journal(stream, config, journal, master, original_file); } -unsigned int parse_ledger_data(journal_t * journal, - const std::string& data_file, - const std::string& init_file, - const std::string& price_db, - bool use_cache, - const std::string& cache_file, - bool * cache_dirty, - parser_t * cache_parser, - parser_t * xml_parser, - parser_t * stdin_parser, - const std::string& default_account) +extern parser_t * binary_parser_ptr; +extern parser_t * xml_parser_ptr; +extern parser_t * textual_parser_ptr; + +unsigned int parse_ledger_data(config_t& config, + journal_t * journal, + parser_t * cache_parser, + parser_t * xml_parser, + parser_t * stdin_parser) { unsigned int entry_count = 0; - DEBUG_PRINT("ledger.config.cache", "3. use_cache = " << use_cache); + if (! cache_parser) + cache_parser = binary_parser_ptr; + if (! xml_parser) + xml_parser = xml_parser_ptr; + if (! stdin_parser) + stdin_parser = textual_parser_ptr; - if (! init_file.empty() && access(init_file.c_str(), R_OK) != -1) { - if (parse_journal_file(init_file, journal) || + DEBUG_PRINT("ledger.config.cache", + "3. use_cache = " << config.use_cache); + + if (! config.init_file.empty() && + access(config.init_file.c_str(), R_OK) != -1) { + if (parse_journal_file(config.init_file, config, journal) || journal->auto_entries.size() > 0 || journal->period_entries.size() > 0) throw error(std::string("Entries found in initialization file '") + - init_file + "'"); + config.init_file + "'"); journal->sources.pop_front(); // remove init file } - if (use_cache && ! cache_file.empty() && ! data_file.empty()) { - DEBUG_PRINT("ledger.config.cache", "using_cache " << cache_file); - if (cache_dirty) - *cache_dirty = true; - if (access(cache_file.c_str(), R_OK) != -1) { - std::ifstream stream(cache_file.c_str()); + if (config.use_cache && ! config.cache_file.empty() && + ! config.data_file.empty()) { + DEBUG_PRINT("ledger.config.cache", + "using_cache " << config.cache_file); + if (config.cache_dirty) + config.cache_dirty = true; + if (access(config.cache_file.c_str(), R_OK) != -1) { + std::ifstream stream(config.cache_file.c_str()); if (cache_parser && cache_parser->test(stream)) { std::string price_db_orig = journal->price_db; - journal->price_db = price_db; - entry_count += cache_parser->parse(stream, journal, NULL, &data_file); + journal->price_db = config.price_db; + entry_count += cache_parser->parse(stream, config, journal, + NULL, &config.data_file); if (entry_count > 0) { - if (cache_dirty) - *cache_dirty = false; + if (config.cache_dirty) + config.cache_dirty = false; } else { journal->price_db = price_db_orig; } @@ -136,15 +148,15 @@ unsigned int parse_ledger_data(journal_t * journal, } } - if (entry_count == 0 && ! data_file.empty()) { + if (entry_count == 0 && ! config.data_file.empty()) { account_t * acct = NULL; - if (! default_account.empty()) - acct = journal->find_account(default_account); + if (! config.account.empty()) + acct = journal->find_account(config.account); - journal->price_db = price_db; + journal->price_db = config.price_db; if (! journal->price_db.empty() && access(journal->price_db.c_str(), R_OK) != -1) { - if (parse_journal_file(journal->price_db, journal)) { + if (parse_journal_file(journal->price_db, config, journal)) { throw error("Entries not allowed in price history file"); } else { DEBUG_PRINT("ledger.config.cache", @@ -154,19 +166,22 @@ unsigned int parse_ledger_data(journal_t * journal, } DEBUG_PRINT("ledger.config.cache", - "rejected cache, parsing " << data_file); - if (data_file == "-") { - use_cache = false; + "rejected cache, parsing " << config.data_file); + if (config.data_file == "-") { + config.use_cache = false; journal->sources.push_back(""); #if 0 if (xml_parser && std::cin.peek() == '<') - entry_count += xml_parser->parse(std::cin, journal, acct); + entry_count += xml_parser->parse(std::cin, config, journal, + acct); else if (stdin_parser) #endif - entry_count += stdin_parser->parse(std::cin, journal, acct); + entry_count += stdin_parser->parse(std::cin, config, + journal, acct); } - else if (access(data_file.c_str(), R_OK) != -1) { - entry_count += parse_journal_file(data_file, journal, acct); + else if (access(config.data_file.c_str(), R_OK) != -1) { + entry_count += parse_journal_file(config.data_file, config, + journal, acct); if (! journal->price_db.empty()) journal->sources.push_back(journal->price_db); } @@ -177,17 +192,4 @@ unsigned int parse_ledger_data(journal_t * journal, return entry_count; } -extern parser_t * binary_parser_ptr; -extern parser_t * xml_parser_ptr; -extern parser_t * textual_parser_ptr; - -unsigned int parse_ledger_data(journal_t * journal, config_t& config) -{ - return parse_ledger_data(journal, config.data_file, config.init_file, - config.price_db, config.use_cache, - config.cache_file, &config.cache_dirty, - binary_parser_ptr, xml_parser_ptr, - textual_parser_ptr, config.account); -} - } // namespace ledger diff --git a/parser.h b/parser.h index d163e5e9..396f0fe6 100644 --- a/parser.h +++ b/parser.h @@ -8,6 +8,7 @@ namespace ledger { class account_t; class journal_t; +class config_t; class parser_t { @@ -17,6 +18,7 @@ class parser_t virtual bool test(std::istream& in) const = 0; virtual unsigned int parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master = NULL, const std::string * original_file = NULL) = 0; @@ -26,29 +28,22 @@ bool register_parser(parser_t * parser); bool unregister_parser(parser_t * parser); unsigned int parse_journal(std::istream& in, + config_t& config, journal_t * journal, account_t * master = NULL, const std::string * original_file = NULL); unsigned int parse_journal_file(const std::string& path, + config_t& config, journal_t * journal, account_t * master = NULL, const std::string * original_file = NULL); -unsigned int parse_ledger_data(journal_t * journal, - const std::string& data_file, - const std::string& init_file = "", - const std::string& price_db = "", - bool use_cache = false, - const std::string& cache_file = "", - bool * cache_dirty = NULL, - parser_t * cache_parser = NULL, - parser_t * xml_parser = NULL, - parser_t * stdin_parser = NULL, - const std::string& default_account = ""); - -class config_t; -unsigned int parse_ledger_data(journal_t * journal, config_t& config); +unsigned int parse_ledger_data(config_t& config, + journal_t * journal, + parser_t * cache_parser = NULL, + parser_t * xml_parser = NULL, + parser_t * stdin_parser = NULL); void initialize_parser_support(); void shutdown_parser_support(); diff --git a/qif.cc b/qif.cc index 429bdcc9..629ce289 100644 --- a/qif.cc +++ b/qif.cc @@ -39,6 +39,7 @@ bool qif_parser_t::test(std::istream& in) const } unsigned int qif_parser_t::parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master, const std::string * original_file) diff --git a/qif.h b/qif.h index 89663724..d8c52576 100644 --- a/qif.h +++ b/qif.h @@ -11,6 +11,7 @@ class qif_parser_t : public parser_t virtual bool test(std::istream& in) const; virtual unsigned int parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master = NULL, const std::string * original_file = NULL); diff --git a/textual.cc b/textual.cc index 7bfce642..0a317070 100644 --- a/textual.cc +++ b/textual.cc @@ -487,6 +487,7 @@ static void clock_out_from_timelog(const std::time_t when, } unsigned int textual_parser_t::parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master, const std::string * original_file) @@ -607,6 +608,8 @@ unsigned int textual_parser_t::parse(std::istream& in, date_buffer[std::strlen(date_field)] = ' '; std::strcpy(&date_buffer[std::strlen(date_field) + 1], time_field); + std::cerr << "date_buffer = " << date_buffer << std::endl; + struct std::tm when; if (strptime(date_buffer, "%Y/%m/%d %H:%M:%S", &when)) { date = std::mktime(&when); @@ -653,7 +656,7 @@ unsigned int textual_parser_t::parse(std::istream& in, if (p) *p++ = '\0'; } - process_option(config_options, line + 2, p); + config.process_option(line + 2, p); break; } @@ -721,7 +724,8 @@ unsigned int textual_parser_t::parse(std::istream& in, DEBUG_PRINT("ledger.textual.include", "Including path '" << path << "'"); - count += parse_journal_file(path, journal, account_stack.front()); + count += parse_journal_file(path, config, journal, + account_stack.front()); } else if (word == "account") { account_t * acct; diff --git a/textual.h b/textual.h index 64107e0a..473f0294 100644 --- a/textual.h +++ b/textual.h @@ -13,6 +13,7 @@ class textual_parser_t : public parser_t virtual bool test(std::istream& in) const; virtual unsigned int parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master = NULL, const std::string * original_file = NULL); diff --git a/xml.cc b/xml.cc index 380416ed..6e3007b8 100644 --- a/xml.cc +++ b/xml.cc @@ -175,10 +175,11 @@ bool xml_parser_t::test(std::istream& in) const return true; } -unsigned int xml_parser_t::parse(std::istream& in, - journal_t * journal, - account_t * master, - const std::string * original_file) +unsigned int xml_parser_t::parse(std::istream& in, + config_t& config, + journal_t * journal, + account_t * master, + const std::string * original_file) { char buf[BUFSIZ]; diff --git a/xml.h b/xml.h index fc56aa0a..17b01bb7 100644 --- a/xml.h +++ b/xml.h @@ -12,6 +12,7 @@ class xml_parser_t : public parser_t virtual bool test(std::istream& in) const; virtual unsigned int parse(std::istream& in, + config_t& config, journal_t * journal, account_t * master = NULL, const std::string * original_file = NULL); -- cgit v1.2.3