2 ly-module.cc -- implement guile module stuff.
4 source file of the GNU LilyPond music typesetter
6 (c) 2002--2005 Han-Wen Nienhuys <hanwen@cs.uu.nl>
9 #include "lily-guile.hh"
13 #include "protected-scm.hh"
15 #ifdef MODULE_GC_KLUDGE
16 Protected_scm anonymous_modules = SCM_EOL;
21 clear_anonymous_modules ()
23 for (SCM s = anonymous_modules;
27 SCM module = scm_car (s);
28 SCM closure = SCM_MODULE_EVAL_CLOSURE(module);
29 SCM prop = scm_procedure_property (closure, ly_symbol2scm ("module"));
31 if (ly_is_module (prop))
33 scm_set_procedure_property_x (closure, ly_symbol2scm ("module"),
38 anonymous_modules = SCM_EOL;
42 ly_make_anonymous_module (bool safe)
47 SCM maker = ly_lily_module_constant ("make-module");
49 SCM scm_module = ly_lily_module_constant ("the-scm-module");
51 mod = scm_call_0 (maker);
52 scm_module_define (mod, ly_symbol2scm ("%module-public-interface"),
55 ly_use_module (mod, scm_module);
56 ly_use_module (mod, global_lily_module);
60 SCM proc = ly_lily_module_constant ("make-safe-lilypond-module");
61 mod = scm_call_0 (proc);
64 #ifdef MODULE_GC_KLUDGE
65 anonymous_modules = scm_cons (mod, anonymous_modules);
72 ly_use_module (SCM mod, SCM used)
75 = scm_list_3 (ly_symbol2scm ("module-use!"),
77 scm_list_2 (ly_symbol2scm ("module-public-interface"),
80 return scm_eval (expr, global_lily_module);
83 #define FUNC_NAME __FUNCTION__
88 accumulate_symbol (void *closure, SCM key, SCM val, SCM result)
92 return scm_cons (key, result);
96 ly_module_symbols (SCM mod)
98 SCM_VALIDATE_MODULE (1, mod);
100 SCM obarr = SCM_MODULE_OBARRAY (mod);
101 return scm_internal_hash_fold ((Hash_closure_function) & accumulate_symbol,
102 NULL, SCM_EOL, obarr);
106 entry_to_alist (void *closure, SCM key, SCM val, SCM result)
109 if (scm_variable_bound_p (val) == SCM_BOOL_T)
110 return scm_cons (scm_cons (key, scm_variable_ref (val)), result);
111 programming_error ("unbound variable in module");
115 LY_DEFINE (ly_module2alist, "ly:module->alist",
117 "Dump the contents of module @var{mod} as an alist.")
119 SCM_VALIDATE_MODULE (1, mod);
120 SCM obarr = SCM_MODULE_OBARRAY (mod);
122 return scm_internal_hash_fold ((Hash_closure_function) & entry_to_alist, NULL, SCM_EOL, obarr);
126 ly_export (SCM module, SCM namelist)
128 static SCM export_function;
129 if (!export_function)
130 export_function = scm_permanent_object (scm_c_lookup ("module-export!"));
132 scm_call_2 (SCM_VARIABLE_REF (export_function), module, namelist);
136 ly_reexport_module (SCM mod)
138 ly_export (mod, ly_module_symbols (mod));
143 #ifdef MODULE_GC_KLUDGE
145 redefine_keyval (void *closure, SCM key, SCM val, SCM result)
148 SCM new_tab = result;
149 scm_hashq_set_x (new_tab, key, val);
155 Kludge for older GUILE 1.6 versions.
158 make_stand_in_procs_weak ()
160 SCM old_tab = scm_stand_in_procs;
161 SCM new_tab = scm_make_weak_key_hash_table (scm_from_int (257));
163 new_tab = scm_internal_hash_fold ((Hash_closure_function) &redefine_keyval,
168 scm_stand_in_procs = new_tab;
171 ADD_SCM_INIT_FUNC(make_stand_in_procs_weak, make_stand_in_procs_weak);