diff options
author | John Wiegley <johnw@newartisans.com> | 2004-09-23 02:37:42 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2004-09-23 02:37:42 -0400 |
commit | 4e6157b74a8fb55eb4e6ab786858dfb055839f55 (patch) | |
tree | b4040bd771302c4df1bd139bea78a6ef9ed149d0 | |
parent | 12c0c08f1ea8cda276f390c6929a7b59b86448ed (diff) | |
download | fork-ledger-4e6157b74a8fb55eb4e6ab786858dfb055839f55.tar.gz fork-ledger-4e6157b74a8fb55eb4e6ab786858dfb055839f55.tar.bz2 fork-ledger-4e6157b74a8fb55eb4e6ab786858dfb055839f55.zip |
added some error checking
-rw-r--r-- | config.cc | 13 | ||||
-rw-r--r-- | main.cc | 21 |
2 files changed, 26 insertions, 8 deletions
@@ -3,6 +3,7 @@ #include "quotes.h" #include <fstream> +#include <stdlib.h> namespace ledger { @@ -206,14 +207,16 @@ void parse_ledger_data(journal_t * journal, { int entry_count = 0; - if (! config.init_file.empty()) { + if (! config.init_file.empty() && + access(config.init_file.c_str(), R_OK) != -1) { if (parse_journal_file(config.init_file, journal)) throw error("Entries not allowed in initialization file"); journal->sources.pop_front(); // remove init file } if (cache_parser && config.use_cache && - ! config.cache_file.empty() && ! config.data_file.empty()) { + ! config.cache_file.empty() && + ! config.data_file.empty()) { config.cache_dirty = true; if (access(config.cache_file.c_str(), R_OK) != -1) { std::ifstream stream(config.cache_file.c_str()); @@ -355,7 +358,11 @@ OPT_BEGIN(init, "i:") { } OPT_END(init); OPT_BEGIN(file, "f:") { - config.data_file = optarg; + if (access(optarg, R_OK) != -1) + config.data_file = optarg; + else + throw error(std::string("The ledger file '") + optarg + + "' does not exist or is not readable"); } OPT_END(file); OPT_BEGIN(cache, ":") { @@ -247,8 +247,13 @@ int parse_and_report(int argc, char * argv[], char * envp[]) TIMER_START(report_gen); std::ostream * out = &std::cout; - if (! config.output_file.empty()) - out = new std::ofstream(config.output_file.c_str()); + if (! config.output_file.empty()) { + if (access(config.output_file.c_str(), W_OK) == -1) + throw error(std::string("Cannot write output to file '" + + config.output_file + "'")); + else + out = new std::ofstream(config.output_file.c_str()); + } // Compile the format strings @@ -328,9 +333,15 @@ int parse_and_report(int argc, char * argv[], char * envp[]) TIMER_START(write_cache); - if (config.use_cache && config.cache_dirty && ! config.cache_file.empty()) { - std::ofstream stream(config.cache_file.c_str()); - write_binary_journal(stream, journal.get(), &journal->sources); + if (config.use_cache && config.cache_dirty && + ! config.cache_file.empty()) { + if (access(config.cache_file.c_str(), W_OK) == -1) { + std::cerr << "Warning: Cannot update cache file '" + << config.cache_file << "'" << std::endl; + } else { + std::ofstream stream(config.cache_file.c_str()); + write_binary_journal(stream, journal.get(), &journal->sources); + } } TIMER_STOP(write_cache); |