Mercurial > hg > xemacs-beta
view lisp/diagnose.el @ 1303:f99d3d25df86
[xemacs-hg @ 2003-02-15 10:15:54 by ben]
autoload fixes, make-doc speed improvements
Makefile.in.in: Run update-elc-2 with -no-autoloads
to avoid multiple autoload-loading problem.
configure.usage: Document quick-build better.
make-docfile.el: Use `message' (defined in this file) in place of `princ'/`print',
and put in a terpri, so that we get correct newline behavior.
Rewrite if-progn -> when and a few similar stylistic niceties.
And the big change: Allow MS Windows to specify the object files
directly and frob them into C files here (formerly this was done
in xemacs.mak, and very slooooooooooooooooooowly). Due to
line-length limitations in CMD, we need to use a "response file"
to hold the arguments, so when we see a response file argument
(preceded by an @), read in the args (a bit of trickiness to do
this), and process recursively. Also frob .obj -> .c as mentioned
earlier and handle other junk dependencies that need to be removed
(NEEDTODUMP, make-docfile.exe).
update-elc-2.el: Use :test `equal' in call to set-difference.
update-elc.el: Put back commented out kill-emacs, update header comment.
xemacs.mak: Delete old unused code that checks SATISFIED.
Move update-elc-2 up to be near update-elc.
Run update-elc-2 with -no-autoloads to avoid multiple
autoload-loading problem.
Don't compute make-docfile args ourselves. Pass the raw objects
to make-docfile.el, which does the computation (much faster than
we could). Don't delete the DOC file, split the invocation into
two calls to make-docfile.exe (one direct, one through
make-docfile.el), etc. In general, all we do is call make-docfile.
Add proper dependencies for DOC-file rebuilding so it doesn't get
done when not necessary. Implement quick-building here: not
building the DOC file unless it doesn't exist, as the quick-build
docs say.
Makefile.in.in: Don't delete the DOC file. Implement quick-building here: not
building the DOC file unless it doesn't exist, as the quick-build
docs say.
config.h.in, emacs.c: Nothing but niggly spacing changes -- one space before a paren
starting a function-call arglist, please.
author | ben |
---|---|
date | Sat, 15 Feb 2003 10:16:14 +0000 |
parents | 242b62e9fc59 |
children | 6db7dbf7f88b |
line wrap: on
line source
;;; debug.el --- routines for debugging problems in XEmacs ;; Copyright (C) 2002 Ben Wing. ;; Maintainer: XEmacs Development Team ;; Keywords: dumped ;; This file is part of XEmacs. ;; XEmacs is free software; you can redistribute it and/or modify it ;; under the terms of the GNU General Public License as published by ;; the Free Software Foundation; either version 2, or (at your option) ;; any later version. ;; XEmacs is distributed in the hope that it will be useful, but ;; WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ;; General Public License for more details. ;; You should have received a copy of the GNU General Public License ;; along with XEmacs; see the file COPYING. If not, write to the Free ;; Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA ;; 02111-1307, USA. ;;; Synched up with: Not in FSF. ;;; Commentary: ;; This file is dumped with XEmacs. ;;; Code: (defun show-memory-usage () "Show statistics about memory usage of various sorts in XEmacs." (interactive) (garbage-collect) (flet ((show-foo-stats (objtypename objlist memfun) (let* ((hash (make-hash-table)) (first t) types fmt (objnamelen 25) (linelen objnamelen) (totaltotal 0)) (dolist (obj objlist) (let ((total 0) (stats (funcall memfun obj))) (loop for (type . num) in stats while type do (puthash type (+ num (or (gethash type hash) 0)) hash) (incf total num) (if first (push type types))) (incf totaltotal total) (when first (setq types (nreverse types)) (setq fmt (concat (format "%%-%ds" objnamelen) (mapconcat #'(lambda (type) (let ((fieldlen (max 8 (+ 2 (length (symbol-name type)))))) (incf linelen fieldlen) (format "%%%ds" fieldlen))) types "") (progn (incf linelen 8) "%8s\n"))) (princ "\n") (princ (apply 'format fmt objtypename (append types (list 'total)))) (princ (make-string linelen ?-)) (princ "\n")) (let ((objname (format "%s" obj))) (princ (apply 'format fmt (substring objname 0 (min (length objname) (1- objnamelen))) (nconc (mapcar #'(lambda (type) (cdr (assq type stats))) types) (list total))))) (setq first nil))) (princ "\n") (princ (apply 'format fmt "total" (nconc (mapcar #'(lambda (type) (gethash type hash)) types) (list totaltotal)))) totaltotal))) (let ((grandtotal 0)) (with-output-to-temp-buffer "*memory usage*" (when-fboundp 'charset-list (incf grandtotal (show-foo-stats 'charset (charset-list) #'charset-memory-usage)) (princ "\n")) (incf grandtotal (show-foo-stats 'buffer (buffer-list) #'buffer-memory-usage)) (princ "\n") (incf grandtotal (show-foo-stats 'window (mapcan #'(lambda (fr) (window-list fr t)) (frame-list)) #'window-memory-usage)) (princ "\n") (let ((total 0) (fmt "%-30s%10s\n")) (princ (format fmt "object" "storage")) (princ (make-string 40 ?-)) (princ "\n") (map-plist #'(lambda (stat num) (when (string-match "\\(.*\\)-storage$" (symbol-name stat)) (incf total num) (princ (format fmt (match-string 1 (symbol-name stat)) num))) (when (eq stat 'long-strings-total-length) (incf total num) (princ (format fmt stat num)))) (sixth (garbage-collect))) (princ "\n") (princ (format fmt "total" total)) (incf grandtotal total)) (princ (format "\n\ngrand total: %s\n" grandtotal)) grandtotal))))