1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-06-10 14:00:21 +02:00

Add %auto-compilation-options', used by compile-file' when auto-compiling.

* module/ice-9/boot-9.scm (%auto-compilation-options): New variable.
  (load-in-vicinity): Honor it.

* libguile/load.c (kw_opts, sym_compile_file,
  sym_auto_compilation_options): New variables.
  (do_try_auto_compile): Honor %AUTO-COMPILATION-OPTIONS.

* module/system/repl/common.scm (repl-default-options): Have
  `compile-options' default to %AUTO-COMPILATION-OPTIONS.
This commit is contained in:
Ludovic Courtès 2011-02-13 19:18:02 +01:00
parent a4060f6710
commit 5a79300f85
3 changed files with 32 additions and 6 deletions

View file

@ -668,6 +668,10 @@ compiled_is_fresh (SCM full_filename, SCM compiled_filename)
}
SCM_KEYWORD (kw_env, "env");
SCM_KEYWORD (kw_opts, "opts");
SCM_SYMBOL (sym_compile_file, "compile-file");
SCM_SYMBOL (sym_auto_compilation_options, "%auto-compilation-options");
static SCM
do_try_auto_compile (void *data)
@ -680,14 +684,30 @@ do_try_auto_compile (void *data)
scm_newline (scm_current_error_port ());
comp_mod = scm_c_resolve_module ("system base compile");
compile_file = scm_module_variable
(comp_mod, scm_from_latin1_symbol ("compile-file"));
compile_file = scm_module_variable (comp_mod, sym_compile_file);
if (scm_is_true (compile_file))
{
/* Auto-compile in the context of the current module. */
SCM res = scm_call_3 (scm_variable_ref (compile_file), source,
kw_env, scm_current_module ());
SCM res, opts;
SCM args[5];
opts = scm_module_variable (scm_the_root_module (),
sym_auto_compilation_options);
if (SCM_VARIABLEP (opts))
opts = SCM_VARIABLE_REF (opts);
else
opts = SCM_EOL;
args[0] = source;
args[1] = kw_opts;
args[2] = opts;
args[3] = kw_env;
args[4] = scm_current_module ();
/* Assume `*current-warning-prefix*' has an appropriate value. */
res = scm_call_n (scm_variable_ref (compile_file), args, 5);
scm_puts (";;; compiled ", scm_current_error_port ());
scm_display (res, scm_current_error_port ());
scm_newline (scm_current_error_port ());

View file

@ -3259,6 +3259,10 @@ module '(ice-9 q) '(make-q q-length))}."
;;; source location.
;;;
(define %auto-compilation-options
;; Default `compile-file' option when auto-compiling.
'(#:warnings (unbound-variable arity-mismatch)))
(define* (load-in-vicinity dir path #:optional reader)
;; Returns the .go file corresponding to `name'. Does not search load
;; paths, only the fallback path. If the .go file is missing or out of
@ -3303,10 +3307,12 @@ module '(ice-9 q) '(make-q q-length))}."
(%load-should-auto-compile
(%warn-auto-compilation-enabled)
(format (current-error-port) ";;; compiling ~a\n" name)
(let ((cfn ((module-ref
(let ((cfn
((module-ref
(resolve-interface '(system base compile))
'compile-file)
name
#:opts %auto-compilation-options
#:env (current-module))))
(format (current-error-port) ";;; compiled ~a\n" cfn)
cfn))

View file

@ -107,7 +107,7 @@ See <http://www.gnu.org/licenses/lgpl.html>, for more details.")
(define repl-default-options
(copy-tree
`((compile-options (#:warnings (unbound-variable arity-mismatch)) #f)
`((compile-options ,%auto-compilation-options #f)
(trace #f #f)
(interp #f #f)
(prompt #f ,(lambda (prompt)