From 5ed76f197a12683791df815a741eb3908cc114c8 Mon Sep 17 00:00:00 2001 From: Calvin Rose Date: Fri, 10 Apr 2020 18:29:10 -0500 Subject: [PATCH] Differentiate error from resume and error from resumed fiber. --- src/boot/boot.janet | 14 ++++++++++---- src/core/vm.c | 32 ++++++++++++++++++++++++++------ 2 files changed, 36 insertions(+), 10 deletions(-) diff --git a/src/boot/boot.janet b/src/boot/boot.janet index 47a00b8a..d9c2e132 100644 --- a/src/boot/boot.janet +++ b/src/boot/boot.janet @@ -2280,11 +2280,16 @@ [] (dyn :fiber)) +(defn .signal + "Get the current signal being debugged." + [] + (dyn :signal)) + (defn .stack "Print the current fiber stack" [] (print) - (with-dyns [:err-color false] (debug/stacktrace (.fiber) "")) + (with-dyns [:err-color false] (debug/stacktrace (.fiber) (.signal))) (print)) (defn .frame @@ -2330,7 +2335,8 @@ (def pc (frame :pc)) (def sourcemap (dasm 'sourcemap)) (var last-loc [-2 -2]) - (print "\n function: " (dasm 'name) " [" (in dasm 'source "") "]") + (print "\n signal: " (.signal)) + (print " function: " (dasm 'name) " [" (in dasm 'source "") "]") (when-let [constants (dasm 'constants)] (printf " constants: %.4q" constants)) (printf " slots: %.4q\n" (frame :slots)) @@ -2458,8 +2464,8 @@ (defn debugger-chunks [buf p] (def status (parser/state p :delimiters)) (def c ((parser/where p) 0)) - (def prompt (string "debug[" level "]:" c ":" status "> ")) - (getline prompt buf nextenv)) + (def prpt (string "debug[" level "]:" c ":" status "> ")) + (getline prpt buf nextenv)) (print "entering debug[" level "] - (quit) to exit") (flush) (repl debugger-chunks (make-onsignal nextenv (+ 1 level)) nextenv) diff --git a/src/core/vm.c b/src/core/vm.c index 6ef676b1..868a7b96 100644 --- a/src/core/vm.c +++ b/src/core/vm.c @@ -89,8 +89,8 @@ JANET_THREAD_LOCAL jmp_buf *janet_vm_jmp_buf = NULL; func = janet_stack_frame(stack)->func; \ } while (0) #define vm_return(sig, val) do { \ - vm_commit(); \ janet_vm_return_reg[0] = (val); \ + vm_commit(); \ return (sig); \ } while (0) @@ -290,6 +290,10 @@ static Janet janet_binop_call(const char *lmethod, const char *rmethod, Janet lh } } +/* Forward declaration */ +static JanetSignal janet_check_can_resume(JanetFiber *fiber, Janet *out); +static JanetSignal janet_continue_no_check(JanetFiber *fiber, Janet in, Janet *out); + /* Interpreter main loop */ static JanetSignal run_vm(JanetFiber *fiber, Janet in) { @@ -999,8 +1003,12 @@ static JanetSignal run_vm(JanetFiber *fiber, Janet in) { Janet retreg; vm_assert_type(stack[B], JANET_FIBER); JanetFiber *child = janet_unwrap_fiber(stack[B]); + if (janet_check_can_resume(child, &retreg)) { + vm_commit(); + janet_panicv(retreg); + } fiber->child = child; - JanetSignal sig = janet_continue(child, stack[C], &retreg); + JanetSignal sig = janet_continue_no_check(child, stack[C], &retreg); if (sig != JANET_SIGNAL_OK && !(child->flags & (1 << sig))) { vm_return(sig, retreg); } @@ -1241,10 +1249,7 @@ Janet janet_call(JanetFunction *fun, int32_t argc, const Janet *argv) { return *janet_vm_return_reg; } -/* Enter the main vm loop */ -JanetSignal janet_continue(JanetFiber *fiber, Janet in, Janet *out) { - jmp_buf buf; - +static JanetSignal janet_check_can_resume(JanetFiber *fiber, Janet *out) { /* Check conditions */ JanetFiberStatus old_status = janet_fiber_status(fiber); if (janet_vm_stackn >= JANET_RECURSION_GUARD) { @@ -1261,6 +1266,13 @@ JanetSignal janet_continue(JanetFiber *fiber, Janet in, Janet *out) { *out = janet_wrap_string(str); return JANET_SIGNAL_ERROR; } + return JANET_SIGNAL_OK; +} + +static JanetSignal janet_continue_no_check(JanetFiber *fiber, Janet in, Janet *out) { + jmp_buf buf; + + JanetFiberStatus old_status = janet_fiber_status(fiber); /* Continue child fiber if it exists */ if (fiber->child) { @@ -1330,6 +1342,14 @@ JanetSignal janet_continue(JanetFiber *fiber, Janet in, Janet *out) { return signal; } +/* Enter the main vm loop */ +JanetSignal janet_continue(JanetFiber *fiber, Janet in, Janet *out) { + /* Check conditions */ + JanetSignal tmp_signal = janet_check_can_resume(fiber, out); + if (tmp_signal) return tmp_signal; + return janet_continue_no_check(fiber, in, out); +} + JanetSignal janet_pcall( JanetFunction *fun, int32_t argc,