#include "lily-guile.hh"
#include "main.hh"
#include "warn.hh"
+#include "smobs.hh"
/*
INIT
*/
+// Why a pointer here? Because it has zero initialization at load
+// time which is guaranteed to come before the static initializations
+// of all constructors for static expressions of the classes created
+// by ADD_SCM_INIT_FUNC. The vector data type does not have load-time
+// initialization and might clear out already set callbacks at the
+// time it is initialized since there is no implied order among
+// non-trivial constructors for static data in separate compilation
+// units. So we need a trivial type like a pointer instead.
+
typedef void (*Void_fptr) ();
vector<Void_fptr> *scm_init_funcs_;
void
ly_init_ly_module (void *)
{
+ // Start up type system first.
+ Scm_init::init ();
for (vsize i = scm_init_funcs_->size (); i--;)
(scm_init_funcs_->at (i)) ();
debug_output ("]\n", false);
}
- scm_primitive_load_path (scm_from_locale_string ("lily.scm"));
+ scm_primitive_load_path (scm_from_ascii_string ("lily.scm"));
}
SCM global_lily_module;