summaryrefslogtreecommitdiff
path: root/src/global.h
diff options
context:
space:
mode:
authorCraig Earls <enderw88@gmail.com>2012-10-25 10:39:48 -0700
committerCraig Earls <enderw88@gmail.com>2012-10-25 10:39:48 -0700
commit4b261f99bc56853b3468a8a1bb5b4af39ed67af5 (patch)
tree87b067d8aa94f651eda9b584e6762dc3ae2c3fe0 /src/global.h
parent41cc9a7f3cb9cd4b1857b0209c59ef66929edf03 (diff)
downloadfork-ledger-4b261f99bc56853b3468a8a1bb5b4af39ed67af5.tar.gz
fork-ledger-4b261f99bc56853b3468a8a1bb5b4af39ed67af5.tar.bz2
fork-ledger-4b261f99bc56853b3468a8a1bb5b4af39ed67af5.zip
Fixes Bug 695, ledger ignores --init-file
Handle --init-file as a special command option like the debug options. That wway we can have the argument captured before teh global scope is created.
Diffstat (limited to 'src/global.h')
-rw-r--r--src/global.h14
1 files changed, 10 insertions, 4 deletions
diff --git a/src/global.h b/src/global.h
index f797ba01..d37043fc 100644
--- a/src/global.h
+++ b/src/global.h
@@ -46,6 +46,8 @@ namespace ledger {
class session_t;
class report_t;
+extern std::string _init_file;
+
class global_scope_t : public noncopyable, public scope_t
{
shared_ptr<session_t> session_ptr;
@@ -151,10 +153,14 @@ See LICENSE file included with the distribution for details and disclaimer.");
OPTION__
(global_scope_t, init_file_, // -i
CTOR(global_scope_t, init_file_) {
- if (const char * home_var = std::getenv("HOME"))
- on(none, (path(home_var) / ".ledgerrc").string());
- else
- on(none, path("./.ledgerrc").string());
+ if(!_init_file.empty())
+ // _init_file is filled during handle_debug_options
+ on(none, _init_file);
+ else
+ if (const char * home_var = std::getenv("HOME"))
+ on(none, (path(home_var) / ".ledgerrc").string());
+ else
+ on(none, path("./.ledgerrc").string());
});
OPTION(global_scope_t, options);