summaryrefslogtreecommitdiff
path: root/src/lread.c
diff options
context:
space:
mode:
authorPaul Eggert <eggert@cs.ucla.edu>2019-09-18 23:53:46 -0700
committerPaul Eggert <eggert@cs.ucla.edu>2019-09-18 23:54:15 -0700
commitdff4f9c759f5cf19047719716ea5ee8ffdc3006e (patch)
tree6f139a6efa38b31b75ef987c2322c446488b5cd0 /src/lread.c
parent6eb122c8db9d6a445b2002f025e01215ab560843 (diff)
downloademacs-dff4f9c759f5cf19047719716ea5ee8ffdc3006e.tar.gz
emacs-dff4f9c759f5cf19047719716ea5ee8ffdc3006e.tar.bz2
emacs-dff4f9c759f5cf19047719716ea5ee8ffdc3006e.zip
Omit some overenthusiastic file-truename calls
Problem reported by Tino Calancha (Bug#37445). * src/emacs.c (init_cmdargs): Call file-truename only if needed, i.e., if invocation-directory ends in "/i386/" on WINDOWSNT. * src/lread.c (readevalloop): If the sourcename is not absolute, make it absolute. There is no need to convert non-absolute files into truenames, since absolute files are not converted into truenames. (init_lread): Do not convert source-directory into a truename at startup. There is no need to do so in a dumped Emacs since an absolute file name suffices. The source directory might not even exist any more, or might have been replaced by an interloper who takes advantage of the truename calculation. (syms_of_lread): Remove Qfile_truename; no longer needed.
Diffstat (limited to 'src/lread.c')
-rw-r--r--src/lread.c11
1 files changed, 3 insertions, 8 deletions
diff --git a/src/lread.c b/src/lread.c
index 99e0ce30ba6..4f3446b09db 100644
--- a/src/lread.c
+++ b/src/lread.c
@@ -1999,11 +1999,10 @@ readevalloop (Lisp_Object readcharfun,
(NILP (lex_bound) || EQ (lex_bound, Qunbound)
? Qnil : list1 (Qt)));
- /* Try to ensure sourcename is a truename, except whilst preloading. */
+ /* Ensure sourcename is absolute, except whilst preloading. */
if (!will_dump_p ()
- && !NILP (sourcename) && !NILP (Ffile_name_absolute_p (sourcename))
- && !NILP (Ffboundp (Qfile_truename)))
- sourcename = call1 (Qfile_truename, sourcename) ;
+ && !NILP (sourcename) && !NILP (Ffile_name_absolute_p (sourcename)))
+ sourcename = Fexpand_file_name (sourcename, Qnil);
LOADHIST_ATTACH (sourcename);
@@ -4678,9 +4677,6 @@ load_path_default (void)
void
init_lread (void)
{
- if (NILP (Vpurify_flag) && !NILP (Ffboundp (Qfile_truename)))
- Vsource_directory = call1 (Qfile_truename, Vsource_directory);
-
/* First, set Vload_path. */
/* Ignore EMACSLOADPATH when dumping. */
@@ -5100,7 +5096,6 @@ this variable will become obsolete. */);
DEFSYM (Qload, "load");
DEFSYM (Qload_file_name, "load-file-name");
DEFSYM (Qeval_buffer_list, "eval-buffer-list");
- DEFSYM (Qfile_truename, "file-truename");
DEFSYM (Qdir_ok, "dir-ok");
DEFSYM (Qdo_after_load_evaluation, "do-after-load-evaluation");