mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-15 16:20:17 +02:00
move module and meta inside programs' object tables
* libguile/programs.h (struct scm_program): Remove the module and meta fields. * libguile/programs.c (scm_c_make_program): Add a new argument, `objs'. If it's a vector, we'll look for the module and the metadata in there, instead of having them in the scm_program structure. (scm_c_make_closure, program_mark, scm_program_meta) (scm_c_program_source, scm_program_module): Adapt to the new program representation. * libguile/objcodes.c (scm_objcode_to_program): Pass #f as the object table when making the program. * libguile/vm-engine.h (CACHE_PROGRAM): * libguile/vm-engine.c (vm_run): Rework to use the simple vector API for getting the current object table. Call the helper, vm_make_boot_program, to make the boot program. * libguile/vm-i-loader.c (load-program): Set the current module and the meta in the object vector, which we pass to scm_c_make_program. * libguile/vm-i-system.c (toplevel-ref, toplevel-set): Adapt to the new program representation. * module/language/glil/compile-objcode.scm (codegen): Clarify.
This commit is contained in:
parent
a72317988f
commit
2fda024221
9 changed files with 64 additions and 61 deletions
|
@ -297,10 +297,11 @@ VM_DEFINE_INSTRUCTION (toplevel_ref, "toplevel-ref", 1, 0, 1)
|
|||
SYNC_REGISTER ();
|
||||
if (SCM_LIKELY (SCM_SYMBOLP (what)))
|
||||
{
|
||||
SCM mod;
|
||||
if (SCM_LIKELY (scm_module_system_booted_p
|
||||
&& scm_is_true (bp->module)))
|
||||
&& scm_is_true ((mod = scm_program_module (program)))))
|
||||
/* might longjmp */
|
||||
what = scm_module_lookup (bp->module, what);
|
||||
what = scm_module_lookup (mod, what);
|
||||
else
|
||||
what = scm_sym2var (what, SCM_BOOL_F, SCM_BOOL_F);
|
||||
}
|
||||
|
@ -379,10 +380,11 @@ VM_DEFINE_INSTRUCTION (toplevel_set, "toplevel-set", 1, 1, 0)
|
|||
SYNC_BEFORE_GC ();
|
||||
if (SCM_LIKELY (SCM_SYMBOLP (what)))
|
||||
{
|
||||
SCM mod;
|
||||
if (SCM_LIKELY (scm_module_system_booted_p
|
||||
&& scm_is_true (bp->module)))
|
||||
&& scm_is_true ((mod = scm_program_module (program)))))
|
||||
/* might longjmp */
|
||||
what = scm_module_lookup (bp->module, what);
|
||||
what = scm_module_lookup (mod, what);
|
||||
else
|
||||
what = scm_sym2var (what, SCM_BOOL_F, SCM_BOOL_F);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue