# HG changeset patch # User Gerd Moellmann # Date 969534886 0 # Node ID e57e942d4ca1ecde80c05c9c439258268fb931ea # Parent 1430a37286eb6a4f75223d59faaf17aaed932d3a (Vrecursive_load_depth_limit): New variable. (Fload): Check recursive loads whose recursion depth exceeds Vrecursive_load_depth_limit. (syms_of_lread): DERFAR_LISP recursive-load-depth-limit. diff -r 1430a37286eb -r e57e942d4ca1 src/lread.c --- a/src/lread.c Thu Sep 21 09:29:24 2000 +0000 +++ b/src/lread.c Thu Sep 21 11:14:46 2000 +0000 @@ -181,6 +181,24 @@ static Lisp_Object Vloads_in_progress; +/* Limit of the depth of recursive loads. */ + +Lisp_Object Vrecursive_load_depth_limit; + +/* Non-zero means load dangerous compiled Lisp files. */ + +int load_dangerous_libraries; + +/* A regular expression used to detect files compiled with Emacs. */ + +static Lisp_Object Vbytecomp_version_regexp; + +static void readevalloop P_ ((Lisp_Object, FILE*, Lisp_Object, + Lisp_Object (*) (), int, + Lisp_Object, Lisp_Object)); +static Lisp_Object load_unwind P_ ((Lisp_Object)); +static Lisp_Object load_descriptor_unwind P_ ((Lisp_Object)); + /* Handle unreading and rereading of characters. Write READCHAR to read a character, @@ -537,22 +555,9 @@ XSETINT (val, getc (instream)); return val; } + + -static void readevalloop P_ ((Lisp_Object, FILE*, Lisp_Object, - Lisp_Object (*) (), int, - Lisp_Object, Lisp_Object)); -static Lisp_Object load_unwind P_ ((Lisp_Object)); -static Lisp_Object load_descriptor_unwind P_ ((Lisp_Object)); - -/* Non-zero means load dangerous compiled Lisp files. */ - -int load_dangerous_libraries; - -/* A regular expression used to detect files compiled with Emacs. */ - -static Lisp_Object Vbytecomp_version_regexp; - - /* Value is non-zero if the file asswociated with file descriptor FD is a compiled Lisp file that's safe to load. Only files compiled with Emacs are safe to load. Files compiled with XEmacs can lead @@ -708,18 +713,26 @@ return call5 (handler, Qload, found, noerror, nomessage, Qt); } -#if 0 /* This is a good idea, but it doesn't quite work. - While compiling files, `provide's seem to not be evaluated. - Let's come back to this when there's more time. */ - - /* Check if we're loading this file again while another load - of the same file is already in progress. */ - if (!NILP (Fmember (found, Vloads_in_progress))) - Fsignal (Qerror, Fcons (build_string ("Recursive load"), - Fcons (found, Vloads_in_progress))); - record_unwind_protect (record_load_unwind, Vloads_in_progress); - Vloads_in_progress = Fcons (found, Vloads_in_progress); -#endif /* 0 */ + /* Check if we're stuck in a recursive load cycle. + + 2000-09-21: It's not possible to just check for the file loaded + being a member of Vloads_in_progress. This fails because of the + way the byte compiler currently works; `provide's are not + evaluted, see font-lock.el/jit-lock.el as an example. This + leads to a certain amount of ``normal'' recursion. + + Also, just loading a file recursively is not always an error in + the general case; the second load may do something different. */ + if (INTEGERP (Vrecursive_load_depth_limit) + && XINT (Vrecursive_load_depth_limit) > 0) + { + Lisp_Object len = Flength (Vloads_in_progress); + if (XFASTINT (len) > XFASTINT (Vrecursive_load_depth_limit)) + Fsignal (Qerror, Fcons (build_string ("Recursive load suspected"), + Fcons (found, Vloads_in_progress))); + record_unwind_protect (record_load_unwind, Vloads_in_progress); + Vloads_in_progress = Fcons (found, Vloads_in_progress); + } /* Load .elc files directly, but not when they are remote and have no handler! */ @@ -3588,6 +3601,12 @@ Vbytecomp_version_regexp = build_string ("^;;;.\\(in Emacs version\\|bytecomp version FSF\\)"); + DEFVAR_LISP ("recursive-load-depth-limit", &Vrecursive_load_depth_limit, + "Limit for depth of recursive loads.\n\ +Value should be either an integer > 0 specifying the limit, or nil for\n\ +no limit."); + Vrecursive_load_depth_limit = make_number (10); + /* Vsource_directory was initialized in init_lread. */ load_descriptor_list = Qnil;