: continuation->rstack-list
drop pair-type cdr ;
-: restore-param-stack ( continuation -- obj_stack continuation )
-
+: restore-param-stack ( continuation -- obj_stack )
continuation->pstack-list
2dup >R >R
-2 +loop
2drop
+;
+
+: restore-return-stack ( continuation -- )
+ R> \ store top of return stack on PS
+ continuation->rstack-list
+ 2dup >R >R
+ ( Allocate stack space first using rsp!,
+ then copy objects from list. )
+
+ car drop
+ rsp0 + rsp!
+
+ R> R> 2dup cdr
+ 2swap
+ car drop 0 swap do
+ 2dup car drop
+ rsp0 i + 1 + !
+ cdr
+ 1- +loop
+
+ 2drop
+ trace
+ >R \ restore original top of return stack
;
-: restore-continuation
+: restore-continuation ( continuation -- )
\ TODO: replace current parameter and return stacks with
\ contents of continuation object.
+
+ 2dup >R >R
+ restore-param-stack
+ R> R>
+ restore-return-stack
;
\ }}}