diff options
Diffstat (limited to 'src/global.cc')
-rw-r--r-- | src/global.cc | 78 |
1 files changed, 41 insertions, 37 deletions
diff --git a/src/global.cc b/src/global.cc index 35651ddb..c0698376 100644 --- a/src/global.cc +++ b/src/global.cc @@ -49,6 +49,8 @@ global_scope_t::global_scope_t(char ** envp) { TRACE_CTOR(global_scope_t, ""); + epoch = CURRENT_TIME(); + #if defined(HAVE_BOOST_PYTHON) if (! python_session.get()) { python_session.reset(new ledger::python_interpreter_t); @@ -113,10 +115,10 @@ void global_scope_t::read_init() ifstream init(init_file); if (session().journal->read(init_file, NULL, &report()) > 0 || - session().journal->auto_xacts.size() > 0 || - session().journal->period_xacts.size() > 0) { - throw_(parse_error, _("Transactions found in initialization file '%1'") - << init_file); + session().journal->auto_xacts.size() > 0 || + session().journal->period_xacts.size() > 0) { + throw_(parse_error, _("Transactions found in initialization file '%1'") + << init_file); } TRACE_FINISH(init, 1); @@ -137,7 +139,7 @@ char * global_scope_t::prompt_string() void global_scope_t::report_error(const std::exception& err) { - std::cout.flush(); // first display anything that was pending + std::cout.flush(); // first display anything that was pending if (caught_signal == NONE_CAUGHT) { // Display any pending error context information @@ -163,7 +165,7 @@ void global_scope_t::execute_command(strings_list args, bool at_repl) } strings_list::iterator arg = args.begin(); - string verb = *arg++; + string verb = *arg++; // Look for a precommand first, which is defined as any defined function // whose name starts with "ledger_precmd_". The difference between a @@ -180,8 +182,8 @@ void global_scope_t::execute_command(strings_list args, bool at_repl) // then invoke the command. expr_t::func_t command; - bool is_precommand = false; - bind_scope_t bound_scope(*this, report()); + bool is_precommand = false; + bind_scope_t bound_scope(*this, report()); if (bool(command = look_for_precommand(bound_scope, verb))) is_precommand = true; @@ -206,11 +208,11 @@ void global_scope_t::execute_command(strings_list args, bool at_repl) report().output_stream .initialize(report().HANDLED(output_) ? - optional<path>(path(report().HANDLER(output_).str())) : - optional<path>(), - report().HANDLED(pager_) ? - optional<path>(path(report().HANDLER(pager_).str())) : - optional<path>()); + optional<path>(path(report().HANDLER(output_).str())) : + optional<path>(), + report().HANDLED(pager_) ? + optional<path>(path(report().HANDLER(pager_).str())) : + optional<path>()); // Now that the output stream is initialized, report the options that will // participate in this report, if the user specified --options @@ -316,7 +318,7 @@ option_t<global_scope_t> * global_scope_t::lookup_option(const char * p) } expr_t::ptr_op_t global_scope_t::lookup(const symbol_t::kind_t kind, - const string& name) + const string& name) { switch (kind) { case symbol_t::FUNCTION: @@ -334,9 +336,9 @@ expr_t::ptr_op_t global_scope_t::lookup(const symbol_t::kind_t kind, switch (*p) { case 'p': if (is_eq(p, "push")) - return MAKE_FUNCTOR(global_scope_t::push_command); + return MAKE_FUNCTOR(global_scope_t::push_command); else if (is_eq(p, "pop")) - return MAKE_FUNCTOR(global_scope_t::pop_command); + return MAKE_FUNCTOR(global_scope_t::pop_command); break; } } @@ -400,8 +402,8 @@ void global_scope_t::normalize_session_options() #endif // defined(LOGGING_ON) } -expr_t::func_t global_scope_t::look_for_precommand(scope_t& scope, - const string& verb) +expr_t::func_t global_scope_t::look_for_precommand(scope_t& scope, + const string& verb) { if (expr_t::ptr_op_t def = scope.lookup(symbol_t::PRECOMMAND, verb)) return def->as_function(); @@ -410,7 +412,7 @@ expr_t::func_t global_scope_t::look_for_precommand(scope_t& scope, } expr_t::func_t global_scope_t::look_for_command(scope_t& scope, - const string& verb) + const string& verb) { if (expr_t::ptr_op_t def = scope.lookup(symbol_t::COMMAND, verb)) return def->as_function(); @@ -420,11 +422,12 @@ expr_t::func_t global_scope_t::look_for_command(scope_t& scope, void global_scope_t::visit_man_page() const { +#ifndef WIN32 int pid = fork(); if (pid < 0) { throw std::logic_error(_("Failed to fork child process")); } - else if (pid == 0) { // child + else if (pid == 0) { // child execlp("man", "man", "1", "ledger", NULL); // We should never, ever reach here @@ -434,7 +437,8 @@ void global_scope_t::visit_man_page() const int status = -1; wait(&status); - exit(0); // parent +#endif + exit(0); // parent } void handle_debug_options(int argc, char * argv[]) @@ -442,37 +446,37 @@ void handle_debug_options(int argc, char * argv[]) for (int i = 1; i < argc; i++) { if (argv[i][0] == '-') { if (std::strcmp(argv[i], "--args-only") == 0) { - args_only = true; + args_only = true; } else if (std::strcmp(argv[i], "--verify") == 0) { #if defined(VERIFY_ON) - verify_enabled = true; // global in utils.h + verify_enabled = true; // global in utils.h #endif } else if (std::strcmp(argv[i], "--verbose") == 0 || - std::strcmp(argv[i], "-v") == 0) { + std::strcmp(argv[i], "-v") == 0) { #if defined(LOGGING_ON) - _log_level = LOG_INFO; // global in utils.h + _log_level = LOG_INFO; // global in utils.h #endif } else if (i + 1 < argc && std::strcmp(argv[i], "--debug") == 0) { #if defined(DEBUG_ON) - _log_level = LOG_DEBUG; // global in utils.h - _log_category = argv[i + 1]; // global in utils.h - i++; + _log_level = LOG_DEBUG; // global in utils.h + _log_category = argv[i + 1]; // global in utils.h + i++; #endif } else if (i + 1 < argc && std::strcmp(argv[i], "--trace") == 0) { #if defined(TRACING_ON) - _log_level = LOG_TRACE; // global in utils.h - try { - // global in utils.h - _trace_level = boost::lexical_cast<uint8_t>(argv[i + 1]); - } - catch (const boost::bad_lexical_cast& e) { - throw std::logic_error(_("Argument to --trace must be an integer")); - } - i++; + _log_level = LOG_TRACE; // global in utils.h + try { + // global in utils.h + _trace_level = boost::lexical_cast<uint8_t>(argv[i + 1]); + } + catch (const boost::bad_lexical_cast&) { + throw std::logic_error(_("Argument to --trace must be an integer")); + } + i++; #endif } } |