# HG changeset patch # User Eli Zaretskii # Date 1264155805 -7200 # Node ID 89c890863220f93c2b049febb48066aee649baae # Parent ddd257e3f8165ebc1d8e06fde5b6ee0aed4b7f86 Fix bug #5447, whereby loading C:/foo.el.gz on MS-Windows would fail. jka-compr.el (jka-compr-load): If load-file is not in load-history, try its file-truename version. diff -r ddd257e3f816 -r 89c890863220 lisp/ChangeLog --- a/lisp/ChangeLog Fri Jan 22 18:10:04 2010 +0900 +++ b/lisp/ChangeLog Fri Jan 22 12:23:25 2010 +0200 @@ -1,3 +1,8 @@ +2010-01-22 Eli Zaretskii + + * jka-compr.el (jka-compr-load): If load-file is not in + load-history, try its file-truename version. (bug#5447) + 2010-01-21 Alan Mackenzie Fix a situation where deletion of a cpp construct throws an error. diff -r ddd257e3f816 -r 89c890863220 lisp/jka-compr.el --- a/lisp/jka-compr.el Fri Jan 22 18:10:04 2010 +0900 +++ b/lisp/jka-compr.el Fri Jan 22 12:23:25 2010 +0200 @@ -590,7 +590,14 @@ (or nomessage (message "Loading %s...done." file)) ;; Fix up the load history to point at the right library. - (let ((l (assoc load-file load-history))) + (let ((l (or (assoc load-file load-history) + ;; On MS-Windows, if load-file is in + ;; temporary-file-directory, it will look like + ;; "c:/DOCUME~1/USER/LOCALS~1/foo", whereas + ;; readevalloop will record its truename in + ;; load-history. Therefore try truename if the + ;; original name is not in load-history. + (assoc (file-truename load-file) load-history)))) ;; Remove .gz and .elc?. (while (file-name-extension file) (setq file (file-name-sans-extension file)))