Mercurial > emacs
view lisp/cus-dep.el @ 17419:c9f73399244c
(elp-functionp): New function.
(elp-instrument-package): Don't attempt to instrument autoload functions.
(elp-elapsed-time): New function to calculate the different between
two `current-time' lists. This no longer throws away the top 16 bits
of information.
(elp-wrapper): Use elp-elapsed-time instead of elp-get-time. Also,
call `current-time' as close to the function entrance and exit as
possible so more of the overhead is eliminated from the times.
(elp-get-time): Obsolete, deleted.
(elp-restore-function):
When restoring, do not check assq elp-wrapper
if the symbol-function is a compiled lisp function (i.e. byte coded).
If it is byte-coded, it could not have been instrumented.
Don't do the symbol-function restoration if
the symbol has no function definition.
(elp-instrument-function): Always `restore' the funsym before instrumenting.
Fail if function is an autoload symbol.
(elp-instrument-list): Remove unnecessary condition-case.
(elp-results):
Noninteractive as a function is non-portable, use the
variable instead. buffer-substring with 3 arguments is non-portable.
(elp-instrument-function, elp-instrument-list):
Handle function symbols that have already been instrumented. Do
not instrument them twice.
(elp-recycle-buffers-p): New variable.
(elp-report-limit, elp-sort-by-function): New default values.
(elp-use-standard-output): New variable.
(elp-results): Optionally dump results to standard-output.
author | Richard M. Stallman <rms@gnu.org> |
---|---|
date | Sat, 12 Apr 1997 19:14:18 +0000 |
parents | ad9d92edda0d |
children | 83503d0dc576 |
line wrap: on
line source
;;; cus-dep.el --- Find customization dependencies. ;; ;; Copyright (C) 1997 Free Software Foundation, Inc. ;; ;; Author: Per Abrahamsen <abraham@dina.kvl.dk> ;; Keywords: internal ;;; Code: (require 'cl) (load-file "widget.el") (load-file "custom.el") (load-file "cus-face.el") (defun custom-make-dependencies () "Batch function to extract custom dependencies from .el files. Usage: emacs -batch -l ./cus-dep.el -f custom-make-dependencies" (let ((enable-local-eval nil) (files (directory-files "" nil "\\`[^=].*\\.el\\'" t)) file) (while files (setq file (car files) files (cdr files)) (message "Checking %s..." file) (set-buffer (find-file-noselect file)) (goto-char (point-min)) (string-match "\\`\\(.*\\)\\.el\\'" file) (condition-case nil (let ((name (file-name-nondirectory (match-string 1 file)))) (while t (let ((expr (read (current-buffer)))) (when (and (listp expr) (memq (car expr) '(defcustom defface defgroup))) (eval expr) (put (nth 1 expr) 'custom-where name))))) (error nil)) (kill-buffer (current-buffer)))) (message "Generating cus-load.el...") (find-file "cus-load.el") (erase-buffer) (insert "\ ;;; cus-load.el --- automatically extracted custom dependencies ;; ;;; Code: ") (mapatoms (lambda (symbol) (let ((members (get symbol 'custom-group)) item where found) (when members (while members (setq item (car (car members)) members (cdr members) where (get item 'custom-where)) (unless (or (null where) (member where found)) (if found (insert " ") (insert "(put '" (symbol-name symbol) " 'custom-loads '(")) (insert (prin1-to-string where)) (push where found))) (insert "))\n"))))) (insert "\n;;; cus-load.el ends here\n") (save-buffer) (message "Generating cus-load.el...")) ;;; cus-dep.el ends here