mirror of
https://github.com/janet-lang/janet
synced 2025-01-25 22:56:52 +00:00
Proper re-entry into debug state nested fibers.
This commit is contained in:
parent
6ac59251e9
commit
0fd9224e4a
@ -218,7 +218,7 @@ failure to return or error.
|
|||||||
| `pusha` | `(pusha array)` | Push values in $array as args |
|
| `pusha` | `(pusha array)` | Push values in $array as args |
|
||||||
| `put` | `(put ds key val)` | $ds[$key] = $val |
|
| `put` | `(put ds key val)` | $ds[$key] = $val |
|
||||||
| `puti` | `(puti ds index val)` | $ds[index] = $val |
|
| `puti` | `(puti ds index val)` | $ds[index] = $val |
|
||||||
| `res` | `(res fiber val)` | Resume $fiber with value $val |
|
| `res` | `(res dest fiber val)` | $dest = resume $fiber with $val |
|
||||||
| `ret` | `(ret val)` | Return $val |
|
| `ret` | `(ret val)` | Return $val |
|
||||||
| `retn` | `(retn)` | Return nil |
|
| `retn` | `(retn)` | Return nil |
|
||||||
| `setu` | `(setu env index val)` | envs[env][index] = $val |
|
| `setu` | `(setu env index val)` | envs[env][index] = $val |
|
||||||
@ -231,5 +231,5 @@ failure to return or error.
|
|||||||
| `sub` | `(sub dest lhs rhs)` | $dest = $lhs - $rhs |
|
| `sub` | `(sub dest lhs rhs)` | $dest = $lhs - $rhs |
|
||||||
| `tcall` | `(tcall callee)` | Return call($callee) |
|
| `tcall` | `(tcall callee)` | Return call($callee) |
|
||||||
| `tchck` | `(tcheck slot types)` | Assert $slot does matches types |
|
| `tchck` | `(tcheck slot types)` | Assert $slot does matches types |
|
||||||
| `yield` | `(yield value)` | Yield $value to parent fiber |
|
| `yield` | `(yield dest value)` | $dest = yield $value to parent |
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ Dst dst_run(DstFiber *fiber) {
|
|||||||
/* Save old fiber to reset */
|
/* Save old fiber to reset */
|
||||||
DstFiber *old_vm_fiber = dst_vm_fiber;
|
DstFiber *old_vm_fiber = dst_vm_fiber;
|
||||||
|
|
||||||
/* VM state */
|
/* interpreter state */
|
||||||
register Dst *stack;
|
register Dst *stack;
|
||||||
register uint32_t *pc;
|
register uint32_t *pc;
|
||||||
register DstFunction *func;
|
register DstFunction *func;
|
||||||
@ -731,8 +731,6 @@ static void *op_lookup[255] = {
|
|||||||
switch (nextfiber->status) {
|
switch (nextfiber->status) {
|
||||||
default:
|
default:
|
||||||
vm_throw("expected pending, new, or debug fiber");
|
vm_throw("expected pending, new, or debug fiber");
|
||||||
case DST_FIBER_DEBUG:
|
|
||||||
break;
|
|
||||||
case DST_FIBER_NEW:
|
case DST_FIBER_NEW:
|
||||||
{
|
{
|
||||||
dst_fiber_push(nextfiber, val);
|
dst_fiber_push(nextfiber, val);
|
||||||
@ -740,11 +738,21 @@ static void *op_lookup[255] = {
|
|||||||
nextfiber->flags &= ~DST_FIBER_FLAG_NEW;
|
nextfiber->flags &= ~DST_FIBER_FLAG_NEW;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case DST_FIBER_DEBUG:
|
||||||
|
{
|
||||||
|
if (!nextfiber->child) {
|
||||||
|
DstStackFrame *nextframe = dst_fiber_frame(nextfiber);
|
||||||
|
nextframe->pc++;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
case DST_FIBER_PENDING:
|
case DST_FIBER_PENDING:
|
||||||
{
|
{
|
||||||
DstStackFrame *nextframe = dst_fiber_frame(nextfiber);
|
if (!nextfiber->child) {
|
||||||
nextfiber->data[nextfiber->frame + ((*nextframe->pc >> 8) & 0xFF)] = val;
|
DstStackFrame *nextframe = dst_fiber_frame(nextfiber);
|
||||||
nextframe->pc++;
|
nextfiber->data[nextfiber->frame + ((*nextframe->pc >> 8) & 0xFF)] = val;
|
||||||
|
nextframe->pc++;
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -71,6 +71,27 @@
|
|||||||
|
|
||||||
(assert (= "hello, world" `hello, world`) "simple long string")
|
(assert (= "hello, world" `hello, world`) "simple long string")
|
||||||
(assert (= "hello, \"world\"" `hello, "world"`) "long string with embedded quotes")
|
(assert (= "hello, \"world\"" `hello, "world"`) "long string with embedded quotes")
|
||||||
(assert (= "hello, \\\\\\ \"world\"" `hello, \\\ "world"`), "long string with embedded quotes and backslashes")
|
(assert (= "hello, \\\\\\ \"world\"" `hello, \\\ "world"`),
|
||||||
|
"long string with embedded quotes and backslashes")
|
||||||
|
|
||||||
|
# More fiber semantics
|
||||||
|
|
||||||
|
(var myvar 0)
|
||||||
|
(defn fiberstuff []
|
||||||
|
(++ myvar)
|
||||||
|
(def f (fiber.new (fn [] (++ myvar) (debug) (++ myvar))))
|
||||||
|
(fiber.resume f)
|
||||||
|
(++ myvar))
|
||||||
|
|
||||||
|
(def myfiber (fiber.new fiberstuff :dey))
|
||||||
|
|
||||||
|
(assert (= myvar 0) "fiber creation does not call fiber function")
|
||||||
|
(fiber.resume myfiber)
|
||||||
|
(assert (= myvar 2) "fiber debug statement breaks at proper point")
|
||||||
|
(assert (= (fiber.status myfiber) :debug) "fiber enters debug state")
|
||||||
|
(fiber.resume myfiber)
|
||||||
|
(assert (= myvar 4) "fiber resumes properly from debug state")
|
||||||
|
(assert (= (fiber.status myfiber) :dead) "fiber properly dies from debug state")
|
||||||
|
|
||||||
|
|
||||||
(end-suite)
|
(end-suite)
|
||||||
|
Loading…
Reference in New Issue
Block a user