mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-30 11:50:28 +02:00
implement autocompilation
* am/guilec (.scm.go): Set GUILE_AUTO_COMPILE=0 when compiling individual files, and remove the mkdir -p as compile-file takes care of that now. * libguile/load.c (do_try_autocompile, autocompile_catch_handler) (scm_try_autocompile, scm_init_load): Implement autocompilation. * libguile/script.c (scm_shell_usage, scm_compile_shell_switches): Add --autocompile / --no-autocompile command-line options, and support for the GUILE_AUTO_COMPILE environment variable, defaulting to autocompilation enabled.
This commit is contained in:
parent
0fb81f95b0
commit
ee00175026
3 changed files with 92 additions and 3 deletions
|
@ -11,5 +11,4 @@ CLEANFILES = $(GOBJECTS)
|
||||||
|
|
||||||
SUFFIXES = .scm .go
|
SUFFIXES = .scm .go
|
||||||
.scm.go:
|
.scm.go:
|
||||||
$(MKDIR_P) `dirname $@`
|
GUILE_AUTO_COMPILE=0 $(top_builddir)/meta/uninstalled-env guile-tools compile -o "$@" "$<"
|
||||||
$(top_builddir)/meta/uninstalled-env guile-tools compile -o "$@" "$<"
|
|
||||||
|
|
|
@ -182,6 +182,8 @@ static SCM *scm_loc_load_extensions;
|
||||||
static SCM *scm_loc_load_compiled_path;
|
static SCM *scm_loc_load_compiled_path;
|
||||||
static SCM *scm_loc_load_compiled_extensions;
|
static SCM *scm_loc_load_compiled_extensions;
|
||||||
|
|
||||||
|
/* Whether we should try to auto-compile. */
|
||||||
|
static SCM *scm_loc_load_should_autocompile;
|
||||||
|
|
||||||
SCM_DEFINE (scm_parse_path, "parse-path", 1, 1, 0,
|
SCM_DEFINE (scm_parse_path, "parse-path", 1, 1, 0,
|
||||||
(SCM path, SCM tail),
|
(SCM path, SCM tail),
|
||||||
|
@ -580,10 +582,65 @@ compiled_is_newer (SCM full_filename, SCM compiled_filename)
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static SCM
|
||||||
|
do_try_autocompile (void *data)
|
||||||
|
{
|
||||||
|
SCM source = PTR2SCM (data);
|
||||||
|
SCM comp_mod, compile_file, res;
|
||||||
|
|
||||||
|
scm_puts (";;; compiling ", scm_current_error_port ());
|
||||||
|
scm_display (source, scm_current_error_port ());
|
||||||
|
scm_newline (scm_current_error_port ());
|
||||||
|
|
||||||
|
comp_mod = scm_c_resolve_module ("system base compile");
|
||||||
|
compile_file = scm_c_module_lookup (comp_mod, "compile-file");
|
||||||
|
res = scm_call_1 (scm_variable_ref (compile_file), source);
|
||||||
|
|
||||||
|
scm_puts (";;; compiled ", scm_current_error_port ());
|
||||||
|
scm_display (res, scm_current_error_port ());
|
||||||
|
scm_newline (scm_current_error_port ());
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
static SCM
|
||||||
|
autocompile_catch_handler (void *data, SCM tag, SCM throw_args)
|
||||||
|
{
|
||||||
|
SCM source = PTR2SCM (data);
|
||||||
|
scm_puts (";;; WARNING: compilation of ", scm_current_error_port ());
|
||||||
|
scm_display (source, scm_current_error_port ());
|
||||||
|
scm_puts (" failed\n", scm_current_error_port ());
|
||||||
|
scm_puts (";;; key ", scm_current_error_port ());
|
||||||
|
scm_write (tag, scm_current_error_port ());
|
||||||
|
scm_puts (", throw args ", scm_current_error_port ());
|
||||||
|
scm_write (throw_args, scm_current_error_port ());
|
||||||
|
scm_newline (scm_current_error_port ());
|
||||||
|
return SCM_BOOL_F;
|
||||||
|
}
|
||||||
|
|
||||||
static SCM
|
static SCM
|
||||||
scm_try_autocompile (SCM source)
|
scm_try_autocompile (SCM source)
|
||||||
{
|
{
|
||||||
|
static int message_shown = 0;
|
||||||
|
|
||||||
|
if (scm_is_false (*scm_loc_load_should_autocompile))
|
||||||
return SCM_BOOL_F;
|
return SCM_BOOL_F;
|
||||||
|
|
||||||
|
if (!message_shown)
|
||||||
|
{
|
||||||
|
scm_puts (";;; note: autocompilation is enabled, set GUILE_AUTO_COMPILE=0\n"
|
||||||
|
";;; or pass the --no-autocompile argument to disable\n",
|
||||||
|
scm_current_error_port ());
|
||||||
|
message_shown = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* fixme: wrap in a `catch' */
|
||||||
|
return scm_c_catch (SCM_BOOL_T,
|
||||||
|
do_try_autocompile,
|
||||||
|
SCM2PTR (source),
|
||||||
|
autocompile_catch_handler,
|
||||||
|
SCM2PTR (source),
|
||||||
|
NULL, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
SCM_DEFINE (scm_primitive_load_path, "primitive-load-path", 1, 1, 0,
|
SCM_DEFINE (scm_primitive_load_path, "primitive-load-path", 1, 1, 0,
|
||||||
|
@ -673,6 +730,9 @@ scm_init_load ()
|
||||||
scm_list_1 (scm_from_locale_string (".go"))));
|
scm_list_1 (scm_from_locale_string (".go"))));
|
||||||
scm_loc_load_hook = SCM_VARIABLE_LOC (scm_c_define ("%load-hook", SCM_BOOL_F));
|
scm_loc_load_hook = SCM_VARIABLE_LOC (scm_c_define ("%load-hook", SCM_BOOL_F));
|
||||||
|
|
||||||
|
scm_loc_load_should_autocompile
|
||||||
|
= SCM_VARIABLE_LOC (scm_c_define ("%load-should-autocompile", SCM_BOOL_F));
|
||||||
|
|
||||||
the_reader = scm_make_fluid ();
|
the_reader = scm_make_fluid ();
|
||||||
the_reader_fluid_num = SCM_FLUID_NUM (the_reader);
|
the_reader_fluid_num = SCM_FLUID_NUM (the_reader);
|
||||||
SCM_FAST_FLUID_SET_X (the_reader_fluid_num, SCM_BOOL_F);
|
SCM_FAST_FLUID_SET_X (the_reader_fluid_num, SCM_BOOL_F);
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include "libguile/eval.h"
|
#include "libguile/eval.h"
|
||||||
#include "libguile/feature.h"
|
#include "libguile/feature.h"
|
||||||
#include "libguile/load.h"
|
#include "libguile/load.h"
|
||||||
|
#include "libguile/private-gc.h" /* scm_getenv_int */
|
||||||
#include "libguile/read.h"
|
#include "libguile/read.h"
|
||||||
#include "libguile/script.h"
|
#include "libguile/script.h"
|
||||||
#include "libguile/strings.h"
|
#include "libguile/strings.h"
|
||||||
|
@ -376,6 +377,10 @@ scm_shell_usage (int fatal, char *message)
|
||||||
" --no-debug start with normal evaluator\n"
|
" --no-debug start with normal evaluator\n"
|
||||||
" Default is to enable debugging for interactive\n"
|
" Default is to enable debugging for interactive\n"
|
||||||
" use, but not for `-s' and `-c'.\n"
|
" use, but not for `-s' and `-c'.\n"
|
||||||
|
" --autocompile compile source files automatically\n"
|
||||||
|
" --no-autocompile disable automatic source file compilation\n"
|
||||||
|
" Default is to enable autocompilation of source\n"
|
||||||
|
" files.\n"
|
||||||
" -q inhibit loading of user init file\n"
|
" -q inhibit loading of user init file\n"
|
||||||
" --emacs enable Emacs protocol (experimental)\n"
|
" --emacs enable Emacs protocol (experimental)\n"
|
||||||
" --use-srfi=LS load SRFI modules for the SRFIs in LS,\n"
|
" --use-srfi=LS load SRFI modules for the SRFIs in LS,\n"
|
||||||
|
@ -404,6 +409,7 @@ SCM_SYMBOL (sym_quit, "quit");
|
||||||
SCM_SYMBOL (sym_use_srfis, "use-srfis");
|
SCM_SYMBOL (sym_use_srfis, "use-srfis");
|
||||||
SCM_SYMBOL (sym_load_path, "%load-path");
|
SCM_SYMBOL (sym_load_path, "%load-path");
|
||||||
SCM_SYMBOL (sym_set_x, "set!");
|
SCM_SYMBOL (sym_set_x, "set!");
|
||||||
|
SCM_SYMBOL (sym_sys_load_should_autocompile, "%load-should-autocompile");
|
||||||
SCM_SYMBOL (sym_cons, "cons");
|
SCM_SYMBOL (sym_cons, "cons");
|
||||||
SCM_SYMBOL (sym_at, "@");
|
SCM_SYMBOL (sym_at, "@");
|
||||||
SCM_SYMBOL (sym_atat, "@@");
|
SCM_SYMBOL (sym_atat, "@@");
|
||||||
|
@ -448,6 +454,8 @@ scm_compile_shell_switches (int argc, char **argv)
|
||||||
int use_emacs_interface = 0;
|
int use_emacs_interface = 0;
|
||||||
int turn_on_debugging = 0;
|
int turn_on_debugging = 0;
|
||||||
int dont_turn_on_debugging = 0;
|
int dont_turn_on_debugging = 0;
|
||||||
|
int turn_on_autocompile = 0;
|
||||||
|
int dont_turn_on_autocompile = 0;
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
char *argv0 = guile;
|
char *argv0 = guile;
|
||||||
|
@ -584,6 +592,18 @@ scm_compile_shell_switches (int argc, char **argv)
|
||||||
turn_on_debugging = 0;
|
turn_on_debugging = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
else if (! strcmp (argv[i], "--autocompile"))
|
||||||
|
{
|
||||||
|
turn_on_autocompile = 1;
|
||||||
|
dont_turn_on_autocompile = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (! strcmp (argv[i], "--no-autocompile"))
|
||||||
|
{
|
||||||
|
dont_turn_on_autocompile = 1;
|
||||||
|
turn_on_autocompile = 0;
|
||||||
|
}
|
||||||
|
|
||||||
else if (! strcmp (argv[i], "--emacs")) /* use emacs protocol */
|
else if (! strcmp (argv[i], "--emacs")) /* use emacs protocol */
|
||||||
use_emacs_interface = 1;
|
use_emacs_interface = 1;
|
||||||
|
|
||||||
|
@ -701,6 +721,16 @@ scm_compile_shell_switches (int argc, char **argv)
|
||||||
tail = scm_cons (scm_cons (sym_load_user_init, SCM_EOL), tail);
|
tail = scm_cons (scm_cons (sym_load_user_init, SCM_EOL), tail);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* If GUILE_AUTO_COMPILE is not set and no args are given, default to
|
||||||
|
autocompilation. */
|
||||||
|
if (turn_on_autocompile || (scm_getenv_int ("GUILE_AUTO_COMPILE", 1)
|
||||||
|
&& !dont_turn_on_autocompile))
|
||||||
|
{
|
||||||
|
tail = scm_cons (scm_list_3 (sym_set_x, sym_sys_load_should_autocompile,
|
||||||
|
SCM_BOOL_T),
|
||||||
|
tail);
|
||||||
|
}
|
||||||
|
|
||||||
/* If debugging was requested, or we are interactive and debugging
|
/* If debugging was requested, or we are interactive and debugging
|
||||||
was not explicitly turned off, turn on debugging. */
|
was not explicitly turned off, turn on debugging. */
|
||||||
if (turn_on_debugging || (interactive && !dont_turn_on_debugging))
|
if (turn_on_debugging || (interactive && !dont_turn_on_debugging))
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue