1
0
mirror of https://github.com/janet-lang/janet synced 2025-10-26 05:07:41 +00:00

Change inheritance rule.

This commit is contained in:
Calvin Rose
2021-03-19 15:18:19 -05:00
parent 3c63a48df4
commit b3e80308d4
2 changed files with 16 additions and 5 deletions

View File

@@ -3127,6 +3127,7 @@
(put nextenv :debug-level level) (put nextenv :debug-level level)
(put nextenv :signal x) (put nextenv :signal x)
(merge-into nextenv debugger-env) (merge-into nextenv debugger-env)
(eprint (fiber/status f) ": " x)
(debug/stacktrace f x) (debug/stacktrace f x)
(eflush) (eflush)
(defn debugger-chunks [buf p] (defn debugger-chunks [buf p]
@@ -3142,14 +3143,15 @@
(nextenv :resume-value)) (nextenv :resume-value))
(fn [f x] (fn [f x]
(if (= :dead (fiber/status f)) (def fs (fiber/status f))
(if (= :dead fs)
(do (do
(put e '_ @{:value x}) (put e '_ @{:value x})
(printf (get e :pretty-format "%q") x) (printf (get e :pretty-format "%q") x)
(flush)) (flush))
(if (e :debug) (if (e :debug)
(enter-debugger f x) (enter-debugger f x)
(do (debug/stacktrace f x) (eflush)))))) (do (eprint fs ": " x) (debug/stacktrace f x) (eflush))))))
(run-context {:env env (run-context {:env env
:chunks chunks :chunks chunks

View File

@@ -275,11 +275,21 @@ static Janet call_nonfn(JanetFiber *fiber, Janet callee) {
return janet_method_invoke(callee, argc, fiber->data + fiber->stacktop); return janet_method_invoke(callee, argc, fiber->data + fiber->stacktop);
} }
static Janet method_to_fun(Janet method, Janet obj) {
if (janet_checktype(obj, JANET_TABLE)) {
JanetTable *proto = janet_unwrap_table(obj)->proto;
if (NULL == proto) return janet_wrap_nil();
return janet_table_get(proto, method);
} else {
return janet_get(obj, method);
}
}
/* Get a callable from a keyword method name and ensure that it is valid. */ /* Get a callable from a keyword method name and ensure that it is valid. */
static Janet resolve_method(Janet name, JanetFiber *fiber) { static Janet resolve_method(Janet name, JanetFiber *fiber) {
int32_t argc = fiber->stacktop - fiber->stackstart; int32_t argc = fiber->stacktop - fiber->stackstart;
if (argc < 1) janet_panicf("method call (%v) takes at least 1 argument, got 0", name); if (argc < 1) janet_panicf("method call (%v) takes at least 1 argument, got 0", name);
Janet callee = janet_get(fiber->data[fiber->stackstart], name); Janet callee = method_to_fun(name, fiber->data[fiber->stackstart]);
if (janet_checktype(callee, JANET_NIL)) if (janet_checktype(callee, JANET_NIL))
janet_panicf("unknown method %v invoked on %v", name, fiber->data[fiber->stackstart]); janet_panicf("unknown method %v invoked on %v", name, fiber->data[fiber->stackstart]);
return callee; return callee;
@@ -287,8 +297,7 @@ static Janet resolve_method(Janet name, JanetFiber *fiber) {
/* Lookup method on value x */ /* Lookup method on value x */
static Janet janet_method_lookup(Janet x, const char *name) { static Janet janet_method_lookup(Janet x, const char *name) {
Janet kname = janet_ckeywordv(name); return method_to_fun(janet_ckeywordv(name), x);
return janet_get(x, kname);
} }
/* Call a method first on the righthand side, and then on the left hand side with a prefix */ /* Call a method first on the righthand side, and then on the left hand side with a prefix */