mirror of
git://git.sv.gnu.org/emacs.git
synced 2025-12-06 06:20:55 -08:00
Autoload more carefully from Lisp. Follow aliases for function properties.
* lisp/subr.el (autoloadp): New function. (symbol-file): Use it. (function-get): New function. * lisp/emacs-lisp/macroexp.el (macroexp--expand-all): Use function-get and autoload-do-load. * lisp/emacs-lisp/lisp-mode.el (lisp-font-lock-syntactic-face-function) (lisp-indent-function): * lisp/emacs-lisp/gv.el (gv-get): * lisp/emacs-lisp/edebug.el (get-edebug-spec, edebug-basic-spec): * lisp/emacs-lisp/byte-opt.el (byte-optimize-form): * lisp/emacs-lisp/bytecomp.el (byte-compile-arglist-warn): * lisp/emacs-lisp/autoload.el (make-autoload, autoload-print-form): Use function-get. * lisp/emacs-lisp/cl.el: Don't propagate function properties any more. * src/eval.c (Fautoload_do_load): Rename from do_autoload, export to Lisp, add argument, tune behavior, and adjust all callers. * lisp/speedbar.el (speedbar-add-localized-speedbar-support): * lisp/emacs-lisp/disass.el (disassemble-internal): * lisp/desktop.el (desktop-load-file): * lisp/help-fns.el (help-function-arglist, find-lisp-object-file-name) (describe-function-1): * lisp/emacs-lisp/find-func.el (find-function-noselect): * lisp/emacs-lisp/elp.el (elp-instrument-function): * lisp/emacs-lisp/advice.el (ad-has-proper-definition): * lisp/apropos.el (apropos-safe-documentation, apropos-macrop): * lisp/emacs-lisp/debug.el (debug-on-entry): * lisp/emacs-lisp/cl-macs.el (cl-compiler-macroexpand): * lisp/emacs-lisp/byte-opt.el (byte-compile-inline-expand): * lisp/calc/calc.el (name): Use autoloadp & autoload-do-load.
This commit is contained in:
parent
b1364986cb
commit
7abaf5ccc9
29 changed files with 190 additions and 136 deletions
|
|
@ -249,8 +249,8 @@
|
|||
(let* ((name (car form))
|
||||
(localfn (cdr (assq name byte-compile-function-environment)))
|
||||
(fn (or localfn (and (fboundp name) (symbol-function name)))))
|
||||
(when (and (consp fn) (eq (car fn) 'autoload))
|
||||
(load (nth 1 fn))
|
||||
(when (autoloadp fn)
|
||||
(autoload-do-load fn)
|
||||
(setq fn (or (and (fboundp name) (symbol-function name))
|
||||
(cdr (assq name byte-compile-function-environment)))))
|
||||
(pcase fn
|
||||
|
|
@ -586,10 +586,11 @@
|
|||
(let (opt new)
|
||||
(if (and (consp form)
|
||||
(symbolp (car form))
|
||||
(or (and for-effect
|
||||
;; we don't have any of these yet, but we might.
|
||||
(setq opt (get (car form) 'byte-for-effect-optimizer)))
|
||||
(setq opt (get (car form) 'byte-optimizer)))
|
||||
(or ;; (and for-effect
|
||||
;; ;; We don't have any of these yet, but we might.
|
||||
;; (setq opt (get (car form)
|
||||
;; 'byte-for-effect-optimizer)))
|
||||
(setq opt (function-get (car form) 'byte-optimizer)))
|
||||
(not (eq form (setq new (funcall opt form)))))
|
||||
(progn
|
||||
;; (if (equal form new) (error "bogus optimizer -- %s" opt))
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue