From: Karl Heuer Date: Sun, 6 Sep 1998 13:57:32 +0000 (+0000) Subject: (Fload): Handle case where openp finds a magic file X-Git-Tag: emacs-20.4~1756 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=5e24a1f76c0aba5b5a650e1837f650fc75dc9ea3;p=emacs.git (Fload): Handle case where openp finds a magic file but it has no `load' handler or that handler calls `load'. If FOUND != FILE, find FOUND's handler even if inhibited for FILE. --- diff --git a/src/lread.c b/src/lread.c index 04f34e88690..72ebd3589ba 100644 --- a/src/lread.c +++ b/src/lread.c @@ -649,15 +649,25 @@ Return t if file exists.") return Qnil; } - /* If FD is 0, that means openp found a remote file. */ + /* If FD is 0, that means openp found a magic file. */ if (fd == 0) { - handler = Ffind_file_name_handler (found, Qload); - return call5 (handler, Qload, found, noerror, nomessage, Qt); + if (NILP (Fequal (found, file))) + /* If FOUND is a different file name from FILE, + find its handler even if we have already inhibited + the `load' operation on FILE. */ + handler = Ffind_file_name_handler (found, Qt); + else + handler = Ffind_file_name_handler (found, Qload); + if (! NILP (handler)) + return call5 (handler, Qload, found, noerror, nomessage, Qt); } + /* Load .elc files directly, but not when they are + remote and have no handler! */ if (!bcmp (&(XSTRING (found)->data[XSTRING (found)->size - 4]), - ".elc", 4)) + ".elc", 4) + && fd != 0) { struct stat s1, s2; int result; @@ -687,7 +697,8 @@ Return t if file exists.") /* We are loading a source file (*.el). */ if (!NILP (Vload_source_file_function)) { - close (fd); + if (fd != 0) + close (fd); return call4 (Vload_source_file_function, found, file, NILP (noerror) ? Qnil : Qt, NILP (nomessage) ? Qnil : Qt); @@ -2108,7 +2119,7 @@ read1 (readcharfun, pch, first_in_list) { /* Compute NaN and infinities using 0.0 in a variable, to cope with compilers that think they are smarter - than us. */ + than we are. */ double zero = 0.0; double value;