/*
This file is part of LilyPond, the GNU music typesetter.
- Copyright (C) 2002--2014 Han-Wen Nienhuys <hanwen@xs4all.nl>
+ Copyright (C) 2002--2015 Han-Wen Nienhuys <hanwen@xs4all.nl>
LilyPond is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
*/
#include "lily-guile.hh"
+#include "ly-module.hh"
#include "warn.hh"
#include "main.hh"
-#include "std-string.hh"
#include "protected-scm.hh"
+#include "lily-imports.hh"
SCM
ly_make_module (bool safe)
{
/* Look up (evaluate) Scheme make-module function and call it */
- SCM maker = ly_lily_module_constant ("make-module");
- mod = scm_call_0 (maker);
+ mod = Guile_user::make_module ();
/*
Look up and call Guile module-export-all! or, when using
Guile V1.8, the compatible shim defined in lily.scm.
*/
- SCM module_export_all_x = ly_lily_module_constant ("module-export-all!");
- scm_call_1 (module_export_all_x, mod);
+#if GUILEV2
+ Guile_user::module_export_all_x (mod);
+#else
+ Lily::module_export_all_x (mod);
+#endif
/*
Evaluate Guile module "the-root-module",
N.B. this used to be "the-scm-module" and is deprecated in
Guile V1.9/2.0
*/
- SCM scm_module = ly_lily_module_constant ("the-root-module");
- ly_use_module (mod, scm_module);
- ly_use_module (mod, global_lily_module);
+
+ ly_use_module (mod, Guile_user::the_root_module);
+ ly_use_module (mod, Lily::module);
}
else
{
/* Evaluate and call make-safe-lilypond-module */
- SCM proc = ly_lily_module_constant ("make-safe-lilypond-module");
- mod = scm_call_0 (proc);
+ mod = Lily::make_safe_lilypond_module ();
}
return mod;
TODO - Replace inline evaluations (interpreted)
with guile API calls if these become available.
*/
- SCM scm_module_use = ly_symbol2scm ("module-use!");
- SCM scm_module_public_interface = ly_symbol2scm ("module-public-interface");
- SCM iface = scm_list_2 (scm_module_public_interface, used);
/*
Set up to interpret
'(module_use! <mod> (module-public-interface <used>))'
*/
- SCM expr = scm_list_3 (scm_module_use, mod, iface);
- /*
- Now return SCM value, this is the result of interpreting
- '(eval (module-use! <mod> (module-public-interface <used>)) "lily")'
- */
- return scm_eval (expr, global_lily_module);
+ return Guile_user::module_use_x (mod,
+ Guile_user::module_public_interface (used));
}
#define FUNC_NAME __FUNCTION__
SCM val,
SCM result)
{
- if (scm_variable_bound_p (val) == SCM_BOOL_T)
+ if (to_boolean (scm_variable_bound_p (val)))
return scm_cons (scm_cons (key, scm_variable_ref (val)), result);
programming_error ("unbound variable in module");
return result;
void
ly_export (SCM module, SCM namelist)
{
- static SCM export_function;
- if (!export_function)
- export_function = scm_permanent_object (scm_c_lookup ("module-export!"));
-
- scm_call_2 (SCM_VARIABLE_REF (export_function), module, namelist);
+ Guile_user::module_export_x (module, namelist);
}
void