diff options
author | Craig Earls <enderw88@gmail.com> | 2012-10-25 10:39:48 -0700 |
---|---|---|
committer | Craig Earls <enderw88@gmail.com> | 2012-10-25 10:39:48 -0700 |
commit | 4b261f99bc56853b3468a8a1bb5b4af39ed67af5 (patch) | |
tree | 87b067d8aa94f651eda9b584e6762dc3ae2c3fe0 /src/global.h | |
parent | 41cc9a7f3cb9cd4b1857b0209c59ef66929edf03 (diff) | |
download | fork-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.h | 14 |
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); |