Mercurial > hg > xemacs-beta
view lisp/diagnose.el @ 2671:5402bf7d11a5
[xemacs-hg @ 2005-03-17 09:26:07 by michaels]
2005-03-17 Mike Sperber <mike@xemacs.org>
* files.el: Merge the following changes from GNU Emacs:
2005-01-04 Andreas Schwab <schwab@suse.de>
* files.el (insert-directory): Only look for error lines in
inserted text. Don't move too far after processing --dired markers.
2004-12-27 Richard M. Stallman <rms@gnu.org>
* files.el (insert-directory-ls-version): New variable.
(insert-directory): When ls returns an error, test the version
number to decide what the return code means.
With --dired output format, detect and distinguish lines
that are really error messages.
(insert-directory-adj-pos): New function.
2004-09-25 Stefan Monnier <monnier@iro.umontreal.ca>
* files.el (insert-directory): Obey --dired even with symlinks.
2004-05-25 Luc Teirlinck <teirllm@auburn.edu>
(insert-directory): Check that lines were really inserted by
the --dired switch, before erasing them.
2004-04-17 Richard M. Stallman <rms@gnu.org>
* files.el (insert-directory): Delete any error msg output by the
`insert-directory-program'.
author | michaels |
---|---|
date | Thu, 17 Mar 2005 09:26:09 +0000 |
parents | 6db7dbf7f88b |
children | 6fa9919a9a0b |
line wrap: on
line source
;;; diagnose.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 9) "%9s\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) (buffer "*memory usage*") begin) (with-output-to-temp-buffer buffer (save-excursion (set-buffer buffer) (when-fboundp 'charset-list (setq begin (point)) (incf grandtotal (show-foo-stats 'charset (charset-list) #'charset-memory-usage)) (sort-numeric-fields -1 (save-excursion (goto-char begin) (forward-line 2) (point)) (save-excursion (forward-line -2) (point))) (princ "\n")) (setq begin (point)) (incf grandtotal (show-foo-stats 'buffer (buffer-list) #'buffer-memory-usage)) (sort-numeric-fields -1 (save-excursion (goto-char begin) (forward-line 3) (point)) (save-excursion (forward-line -2) (point))) (princ "\n") (setq begin (point)) (incf grandtotal (show-foo-stats 'window (mapcan #'(lambda (fr) (window-list fr t)) (frame-list)) #'window-memory-usage)) (sort-numeric-fields -1 (save-excursion (goto-char begin) (forward-line 3) (point)) (save-excursion (forward-line -2) (point))) (princ "\n") (let ((total 0) (fmt "%-30s%10s\n")) (setq begin (point)) (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)) (sort-numeric-fields -1 (save-excursion (goto-char begin) (forward-line 2) (point)) (save-excursion (forward-line -2) (point))) (princ (format "\n\ngrand total: %s\n" grandtotal))) grandtotal))))