diff options
author | John Wiegley <johnw@newartisans.com> | 2012-03-11 03:05:33 -0500 |
---|---|---|
committer | John Wiegley <johnw@newartisans.com> | 2012-03-11 03:05:33 -0500 |
commit | 2a41649584c731024c3d3331b8a4a5f4011b9693 (patch) | |
tree | d55f6559887ecc679b5add11540b1e35880b07fa | |
parent | 6ddd935e4a140d77b9f94beeed1c76286c9cc1ca (diff) | |
download | fork-ledger-2a41649584c731024c3d3331b8a4a5f4011b9693.tar.gz fork-ledger-2a41649584c731024c3d3331b8a4a5f4011b9693.tar.bz2 fork-ledger-2a41649584c731024c3d3331b8a4a5f4011b9693.zip |
Improve error reporting of nested function calls
-rw-r--r-- | src/op.cc | 13 |
1 files changed, 7 insertions, 6 deletions
@@ -537,13 +537,13 @@ value_t expr_t::op_t::calc_call(scope_t& scope, ptr_op_t * locus, ptr_op_t func = left(); string name = func->is_ident() ? func->as_ident() : "<value expr>"; - try { - func = find_definition(func, scope, locus, depth); + func = find_definition(func, scope, locus, depth); - call_scope_t call_args(scope, locus, depth + 1); - if (has_right()) - call_args.set_args(split_cons_expr(right())); + call_scope_t call_args(scope, locus, depth + 1); + if (has_right()) + call_args.set_args(split_cons_expr(right())); + try { if (func->is_function()) { return func->as_function()(call_args); } else { @@ -552,7 +552,8 @@ value_t expr_t::op_t::calc_call(scope_t& scope, ptr_op_t * locus, } } catch (const std::exception&) { - add_error_context(_("While calling function '%1':" << name)); + add_error_context(_("While calling function '%1 %2':" << name + << call_args.args)); throw; } } |