diff options
author | Paul Smith <psmith@gnu.org> | 2013-09-22 12:11:13 -0400 |
---|---|---|
committer | Paul Smith <psmith@gnu.org> | 2013-09-22 17:10:35 -0400 |
commit | f69922b335df7c5879142f5732f481d4f52548c6 (patch) | |
tree | 35c20f1fd7eb55ef687f88dff812be560b9110c9 | |
parent | 65931ce7a9a84ddb9adb118b7558bfd1b8c3ee46 (diff) | |
download | gunmake-f69922b335df7c5879142f5732f481d4f52548c6.tar.gz |
Defer Guile initialization until the first $(guile...) call.
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | guile.c | 12 |
2 files changed, 15 insertions, 3 deletions
@@ -1,5 +1,11 @@ 2013-09-22 Paul Smith <psmith@gnu.org> + * guile.c (guile_gmake_setup): Don't initialize Guile so early. + (func_guile): Lazily initialize Guile the first time the $(guile ..) + function is invoked. Guile can steal file descriptors which + confuses our jobserver FD checking, so we don't want to initialize + it before we have to. + VMS port updates by Hartmut Becker <becker.ismaning@freenet.de> * makefile.com: Add output to the filelist. @@ -107,6 +107,15 @@ internal_guile_eval (void *arg) static char * func_guile (const char *funcname UNUSED, int argc UNUSED, char **argv) { + static int init = 0; + + if (! init) + { + /* Initialize the Guile interpreter. */ + scm_with_guile (guile_init, NULL); + init = 1; + } + if (argv[0] && argv[0][0] != '\0') return scm_with_guile (internal_guile_eval, argv[0]); @@ -120,9 +129,6 @@ func_guile (const char *funcname UNUSED, int argc UNUSED, char **argv) int guile_gmake_setup (const gmk_floc *flocp UNUSED) { - /* Initialize the Guile interpreter. */ - scm_with_guile (guile_init, NULL); - /* Create a make function "guile". */ gmk_add_function ("guile", func_guile, 0, 1, 1); |