diff options
author | John Wiegley <johnw@newartisans.com> | 2009-02-18 21:00:02 -0400 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2009-02-18 21:00:02 -0400 |
commit | ec08dee745ee7c1bda63defa2828ce98e438370b (patch) | |
tree | f10b51e0ea64c4eed5c17115c62d5d9c0aaa70c5 /src | |
parent | dac10c8cf624613b9bdebe33e2d10c68ff310c50 (diff) | |
download | fork-ledger-ec08dee745ee7c1bda63defa2828ce98e438370b.tar.gz fork-ledger-ec08dee745ee7c1bda63defa2828ce98e438370b.tar.bz2 fork-ledger-ec08dee745ee7c1bda63defa2828ce98e438370b.zip |
Always perform tilde expansion on input pathnames
Diffstat (limited to 'src')
-rw-r--r-- | src/session.cc | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/src/session.cc b/src/session.cc index 5bc7ed8d..1e2dfb64 100644 --- a/src/session.cc +++ b/src/session.cc @@ -110,13 +110,15 @@ std::size_t session_t::read_data(const string& master_account) if (! master_account.empty()) acct = journal->find_account(master_account); - 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"); + if (HANDLED(price_db_)) { + path price_db_path = resolve_path(HANDLER(price_db_).str()); + if (exists(price_db_path) && read_journal(price_db_path) > 0) + throw_(parse_error, "Entries not allowed in price history file"); } foreach (const path& pathname, HANDLER(file_).data_files) { - if (pathname == "-") { + path filename = resolve_path(pathname); + if (filename == "-") { // 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. @@ -134,11 +136,11 @@ std::size_t session_t::read_data(const string& master_account) entry_count += read_journal(buf_in, "/dev/stdin", acct); } - else if (exists(pathname)) { - entry_count += read_journal(pathname, acct); + else if (exists(filename)) { + entry_count += read_journal(filename, acct); } else { - throw_(parse_error, "Could not open journal file '" << pathname << "'"); + throw_(parse_error, "Could not read journal file '" << filename << "'"); } } |