mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-24 12:20:20 +02:00
with-dynamic-state compiler and VM support
* libguile/dynstack.h (SCM_DYNSTACK_TYPE_DYNAMIC_STATE): * libguile/dynstack.c (DYNAMIC_STATE_WORDS, DYNAMIC_STATE_STATE_BOX): (scm_dynstack_push_dynamic_state): (scm_dynstack_unwind_dynamic_state): New definitions. (scm_dynstack_unwind_1, scm_dynstack_wind_1): Add with-dynamic-state cases. * libguile/memoize.c (push_dynamic_state, pop_dynamic_state) (do_push_dynamic_state, do_pop_dynamic_state): New definitions. (memoize, scm_init_memoize): Handle push-dynamic-state and pop-dynamic-state. * libguile/vm-engine.c (push-dynamic-state, pop-dynamic-state): New opcodes. * module/ice-9/boot-9.scm (with-dynamic-state): New definition in Scheme so that the push-dynamic-state and pop-dynamic-state always run in the VM. * module/language/cps/compile-bytecode.scm (compile-function): * module/language/cps/effects-analysis.scm: * module/language/cps/types.scm: * module/language/tree-il/effects.scm (make-effects-analyzer): * module/language/tree-il/peval.scm (peval): * module/language/tree-il/primitives.scm (*interesting-primitive-names*): * module/system/vm/assembler.scm: Add support for with-dynamic-state to the compiler. * test-suite/tests/fluids.test ("dynamic states"): Add basic tests. * doc/ref/vm.texi (Dynamic Environment Instructions): Update.
This commit is contained in:
parent
aa84489d18
commit
7184c176b4
14 changed files with 260 additions and 5 deletions
|
@ -81,6 +81,7 @@ typedef enum {
|
|||
SCM_DYNSTACK_TYPE_WITH_FLUID,
|
||||
SCM_DYNSTACK_TYPE_PROMPT,
|
||||
SCM_DYNSTACK_TYPE_DYNWIND,
|
||||
SCM_DYNSTACK_TYPE_DYNAMIC_STATE,
|
||||
} scm_t_dynstack_item_type;
|
||||
|
||||
#define SCM_DYNSTACK_TAG_TYPE_MASK 0xf
|
||||
|
@ -150,6 +151,8 @@ SCM_INTERNAL void scm_dynstack_push_unwinder (scm_t_dynstack *,
|
|||
SCM_INTERNAL void scm_dynstack_push_fluid (
|
||||
scm_t_dynstack *, SCM fluid, SCM value,
|
||||
scm_t_dynamic_state *dynamic_state);
|
||||
SCM_INTERNAL void scm_dynstack_push_dynamic_state (scm_t_dynstack *, SCM,
|
||||
scm_t_dynamic_state *);
|
||||
SCM_INTERNAL void scm_dynstack_push_prompt (scm_t_dynstack *,
|
||||
scm_t_dynstack_prompt_flags,
|
||||
SCM key,
|
||||
|
@ -188,6 +191,8 @@ SCM_INTERNAL scm_t_bits* scm_dynstack_unwind_fork (scm_t_dynstack *,
|
|||
SCM_INTERNAL void scm_dynstack_unwind_frame (scm_t_dynstack *);
|
||||
SCM_INTERNAL void scm_dynstack_unwind_fluid
|
||||
(scm_t_dynstack *dynstack, scm_t_dynamic_state *dynamic_state);
|
||||
SCM_INTERNAL void scm_dynstack_unwind_dynamic_state
|
||||
(scm_t_dynstack *dynstack, scm_t_dynamic_state *dynamic_state);
|
||||
|
||||
SCM_INTERNAL scm_t_bits* scm_dynstack_find_prompt (scm_t_dynstack *, SCM,
|
||||
scm_t_dynstack_prompt_flags *,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue