]> git.eshelyaron.com Git - emacs.git/commitdiff
(proced-command-alist): Remove sort column.
authorRoland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Mon, 14 Apr 2008 01:35:56 +0000 (01:35 +0000)
committerRoland Winkler <Roland.Winkler@physik.uni-erlangen.de>
Mon, 14 Apr 2008 01:35:56 +0000 (01:35 +0000)
(proced-command, proced-procname-column): Use
make-variable-buffer-local.
(proced-signal-function): Renamed from proced-kill-program.  Allow
for elisp symbols and string values representing system calls.
(proced-marker-regexp, proced-success-message): New functions.
(proced): Use defalias.  Add autoload cookie.
(proced-unmark-backward, proced-toggle-marks)
(proced-hide-processes): New commands.
(proced-do-mark): Simplify code.
(proced-insert-mark): Use optional arg BACKWARD instead of line number.
(proced-update): Remove sorting.
(proced-send-signal): Display number of processes to operate on.
Allow for system calls or elisp functions to send signals.  Check
if signal was send successfully.

lisp/ChangeLog
lisp/proced.el

index b6bf23ccbdca92d66d14979258407a82fb6be9f6..f76b7cd5553a028752938eb805c98feed65d36db 100644 (file)
@@ -1,3 +1,22 @@
+2008-04-13  Roland Winkler  <Roland.Winkler@physik.uni-erlangen.de>
+
+       * proced.el (proced-command-alist): Remove sort column.
+       (proced-command, proced-procname-column): Use
+       make-variable-buffer-local.
+       (proced-signal-function): Renamed from proced-kill-program.  Allow
+       for elisp symbols and string values representing system calls.
+       (proced-marker-regexp, proced-success-message): New functions.
+       (proced): Use defalias.  Add autoload cookie.
+       (proced-unmark-backward, proced-toggle-marks)
+       (proced-hide-processes): New commands.
+       (proced-do-mark): Simplify code.
+       (proced-insert-mark): Use optional arg BACKWARD instead of line
+       number.
+       (proced-update): Remove sorting.
+       (proced-send-signal): Display number of processes to operate on.
+       Allow for system calls or elisp functions to send signals.  Check
+       if signal was send successfully.
+
 2008-04-13  Stefan Monnier  <monnier@iro.umontreal.ca>
 
        * minibuffer.el (completion-all-completion-with-base-size): New var.
        Move non-autoloaded define-obsolete-variable-alias calls for defcustoms
        not in dumped files before the associated defcustom.
 
-2008-04-11  Johan Bockgård  <bojohan@gnu.org>
+2008-04-11  Johan Bockgård  <bojohan@gnu.org>
 
        * minibuffer.el (lazy-completion-table): Fix debug spec.
 
 
        * loadup.el: Load ldefs-boot.el if loaddefs.el doesn't exist.
 
-2008-04-11  Jan Djärv  <jan.h.d@swipnet.se>
+2008-04-11  Jan Djärv  <jan.h.d@swipnet.se>
 
        * tooltip.el (tooltip-show-help-non-mode): Set message-truncate-lines
        to t and don't truncate msg.
        * nxml/nxml-mode.el (nxml-cleanup): New function.
        (nxml-mode): Add it to change-major-mode-hook.
 
-2008-04-09  Jan Djärv  <jan.h.d@swipnet.se>
+2008-04-09  Jan Djärv  <jan.h.d@swipnet.se>
 
        * term/x-win.el (x-gtk-stock-map): Map info to gtk-info.
 
 
        * calc/.cvsignore: New file.
 
-2008-04-09  Jan Djärv  <jan.h.d@swipnet.se>
+2008-04-09  Jan Djärv  <jan.h.d@swipnet.se>
 
        * vc.el (vc-status-tool-bar-map): Add vc-print-log to tool bar.
 
        * faces.el (font-slant-table): Change numeric values for `r',
        `roman', and `normal'.
 
-2008-04-07  Vincent Belaïche  <vincent.b.1@hotmail.fr>
+2008-04-07  Vincent Belaïche  <vincent.b.1@hotmail.fr>
 
        * calc/calc-vec.el (calcFunc-kron, calc-kron): New functions.
 
        Likewise for braille and mathematical.
        Use unicode scripts that cover the phonetic script for IPA.
 
-2008-04-01  Johan Bockgård  <bojohan@gnu.org>
+2008-04-01  Johan Bockgård  <bojohan@gnu.org>
 
        * emacs-lisp/cl-macs.el (frame-parameter) <defsetf>: Make it
        return the assigned value.
        (verilog-auto-unused, verilog-auto): Update documentation to use
        more obvious instance module names versus cell names.
 
-2008-03-28  Jan Djärv  <jan.h.d@swipnet.se>
+2008-03-28  Jan Djärv  <jan.h.d@swipnet.se>
 
        * progmodes/compile.el (compilation-mode-tool-bar-map): Only enable
        kill if a process is running.
        * image-mode.el (image-mode-reapply-winprops): Simplify now that
        window-configuration-change-hook works buffer-locally.
 
-2008-03-26  Johan Bockgård  <bojohan@gnu.org>
+2008-03-26  Johan Bockgård  <bojohan@gnu.org>
 
        * emacs-lisp/lisp-mnt.el (lm-with-file): Use mode and syntax table
        for Emacs Lisp, not Lisp.
        * emacs-lisp/bytecomp.el (byte-compile-obsolete): If no
        replacement is provided, don't print "use nil instead".
 
-2008-03-26  Johan Bockgård  <bojohan@gnu.org>
+2008-03-26  Johan Bockgård  <bojohan@gnu.org>
 
        * complete.el (PC-do-completion): Use regexp-quote.
 
        (verilog-signals-matching-regexp): New internal function for
        signal matching.
 
-2008-03-25  Johan Bockgård  <bojohan@gnu.org>
+2008-03-25  Johan Bockgård  <bojohan@gnu.org>
 
        * info.el (Info-isearch-search): Always return point.
 
        * international/mule.el (load-with-code-conversion): Avoid setting
        default-enable-multibyte-characters.
 
-2008-03-19  Gustav Hållberg  <gustav@virtutech.com>  (tiny change)
+2008-03-19  Gustav Hållberg  <gustav@virtutech.com>  (tiny change)
 
        * vc.el (vc-annotate-background): Fix custom type.
 
        * progmodes/sh-script.el (sh-font-lock-quoted-subshell): Fix handling
        of \ and '.
 
-2008-03-13  Johan Bockgård  <bojohan@gnu.org>
+2008-03-13  Johan Bockgård  <bojohan@gnu.org>
 
        * net/browse-url.el (browse-url-text-xterm):
        Unquote browse-url-text-browser.
        (bookmark-insert-buffer-name): Remove.
        (bookmark-buffer-file-name): Signal an error rather than returning nil.
 
-2008-03-09  Thomas Hühn  <xf27@arcor.de>  (tiny change)
+2008-03-09  Thomas Hühn  <xf27@arcor.de>  (tiny change)
 
        * tutorial.el (tutorial--default-keys): Update `C-l' binding.
 
        (bookmark-prop-get): Declare.
        (Info-bookmark-jump): Use it.
 
-2008-03-08  Johan Bockgård  <bojohan@gnu.org>
+2008-03-08  Johan Bockgård  <bojohan@gnu.org>
 
        * subr.el (while-no-input): Don't splice BODY directly into the
        `or' form.
        * image-mode.el (image-bookmark-make-record):
        * info.el (Info-bookmark-make-record): Delete obsolete second arg.
 
-2008-03-07  Jan Djärv  <jan.h.d@swipnet.se>
+2008-03-07  Jan Djärv  <jan.h.d@swipnet.se>
 
        * vc.el (vc-status-menu-map-filter): Return orig-binding if
        boundp 'vc-ignore-menu-filter.
        (org-promote, org-demote, org-archive-subtree)
        (org-remember-handler, org-refile, org-put-clock-overlay): Use it.
 
-2008-03-06  Jan Djärv  <jan.h.d@swipnet.se>
+2008-03-06  Jan Djärv  <jan.h.d@swipnet.se>
 
        * term/x-win.el (x-gtk-stock-map): Add bookmark_add.
 
        when using transient-mark-mode.
        (default-indicate-unused-lines): Remove unused var.
 
-2008-02-26  Jan Djärv  <jan.h.d@swipnet.se>
+2008-02-26  Jan Djärv  <jan.h.d@swipnet.se>
 
        * progmodes/grep.el (grep-mode-tool-bar-map): Change place on next
        and previous.
        * help-mode.el (help-info-variable):
        New button able to read Info files for help-fns.el.
 
-2008-02-25  Jan Djärv  <jan.h.d@swipnet.se>
+2008-02-25  Jan Djärv  <jan.h.d@swipnet.se>
 
        * progmodes/grep.el (grep-mode-tool-bar-map): New variable.
        (grep-mode): Use grep-mode-tool-bar-map.
        * font-lock.el (font-lock-set-defaults): Unset previously set variables
        when needed.
 
-2008-02-24  Ævar Arnfjörð Bjarmason  <avar@cpan.org>  (tiny change)
+2008-02-24  Ævar Arnfjörð Bjarmason  <avar@cpan.org>  (tiny change)
 
        * net/rcirc.el (rcirc-url-regexp): Replace definition by copying
        from gnus-button-url-regexp.
        * startup.el (command-line): Use custom-reevaluate-setting for
        transient-mark-mode.
 
-2008-02-17  Michaël Cadilhac  <michael@cadilhac.name>
+2008-02-17  Michaël Cadilhac  <michael@cadilhac.name>
 
        * wdired.el (wdired-allow-to-change-permissions): Fix typo.
 
 2008-02-01  Dave Love  <fx@gnu.org>
 
        * international/mule-diag.el (describe-character-set):
-       Fix printing dimensions.  Use `×', not `x'.
+       Fix printing dimensions.  Use `×', not `x'.
 
 2008-02-01  Kenichi Handa  <handa@m17n.org>
 
 
 2008-02-01  Dave Love  <fx@gnu.org>
 
-       * international/characters.el: Make Ÿ and ÿ a case pair.
+       * international/characters.el: Make Ÿ and ÿ a case pair.
 
 2008-02-01  Kenichi Handa  <handa@etl.go.jp>
 
 
        * progmodes/python.el (top-level): Don't require cl when compiling.
 
-2007-12-02  Agustín Martín  <agustin.martin@hispalinux.es>
+2007-12-02  Agustín Martín  <agustin.martin@hispalinux.es>
 
        * textmodes/flyspell.el (flyspell-large-region): Explicitly set
        encoding for aspell process and for communication with it.
        (x-send-client-message):
        * emulation/cua-base.el (x-clipboard-yank): Declare as functions.
 
-2007-11-22  Jan Djärv  <jan.h.d@swipnet.se>
+2007-11-22  Jan Djärv  <jan.h.d@swipnet.se>
 
        * term/x-win.el (x-gtk-map-stock): Check if FILE is a string.
 
 
        * emulation/tpu-mapper.el (tpu-map-key): Remove un-needed cond branch.
 
-2007-11-07  Johan Bockgård  <bojohan@gnu.org>
+2007-11-07  Johan Bockgård  <bojohan@gnu.org>
 
        * eshell/esh-mode.el (eshell-output-filter):
        * eshell/esh-proc.el (eshell-insertion-filter, eshell-sentinel):
        * help-fns.el (describe-function-1): Don't use the advice origname
        if it has no function definition.
 
-2007-10-18  Johan Bockgård  <bojohan@gnu.org>
+2007-10-18  Johan Bockgård  <bojohan@gnu.org>
 
        * net/tramp.el (tramp-rfn-eshadow-update-overlay): Save excursion.
        Use `save-restriction' rather than `widen'.
        (bs--get-mode-name, bs-mode): Fix typos in docstrings.
        (bs--format-aux): Doc fix.
 
-2007-10-08  Michaël Cadilhac  <michael@cadilhac.name>
+2007-10-08  Michaël Cadilhac  <michael@cadilhac.name>
 
        * progmodes/gud.el (gud-gud-gdb-command-name): Fix typo in docstring.
 
        * progmodes/gud.el (gud-display-line): Find source buffer even when
        GUD buffer has its own frame.
 
-2007-10-08  Jan Djärv  <jan.h.d@swipnet.se>
+2007-10-08  Jan Djärv  <jan.h.d@swipnet.se>
 
        * term/x-win.el (icon-map-list): Set to nil for 22.1 compatibility.
 
-2007-10-08  Jan Djärv  <jan.h.d@swipnet.se>
+2007-10-08  Jan Djärv  <jan.h.d@swipnet.se>
 
        * term/x-win.el (x-gtk-stock-map): Version is 22.2.
 
        * emacs-lisp/copyright.el (copyright-update): Don't update if the file
        already uses a more recent copyright version than the "current" one.
 
-2007-10-03  Michaël Cadilhac  <michael@cadilhac.name>
+2007-10-03  Michaël Cadilhac  <michael@cadilhac.name>
 
        * doc-view.el (doc-view-dvi->pdf-sentinel, doc-view-reset-slice)
        (doc-view-insert-image): Minor aesthetical docstring changes.
        * indent.el (indent-for-tab-command): First check if the region is
        active.
 
-2007-09-24  Michaël Cadilhac  <michael@cadilhac.name>
+2007-09-24  Michaël Cadilhac  <michael@cadilhac.name>
 
        * whitespace.el (whitespace-tickle-timer): Don't install the timer if
        whitespace-rescan-timer-time is 0.
        * indent.el (indent-for-tab-command): Indent the region if
        transient-mark-mode and the region is active.
 
-2007-09-21  Francesco Potortì  <pot@gnu.org>
+2007-09-21  Francesco Potortì  <pot@gnu.org>
 
        * progmodes/octave-inf.el (inferior-octave-mode): Use add-hook to
        add inferior-octave-directory-tracker to the buffer-local value
        (browse-url-elinks-sentinel): Use browse-url-elinks-new-window.
        Improve error message.
 
-2007-09-19  Michaël Cadilhac  <michael@cadilhac.name>
+2007-09-19  Michaël Cadilhac  <michael@cadilhac.name>
 
        * net/browse-url.el (browse-url-url-encode-chars): Use the right
        parameter name in the function body.
        * newcomment.el (comment-add): New arg EXTRA.
        (comment-region-default): Pass EXTRA if not indenting lines.
 
-2007-09-17  Michaël Cadilhac  <michael@cadilhac.name>
+2007-09-17  Michaël Cadilhac  <michael@cadilhac.name>
 
        * net/browse-url.el (browse-url-url-encode-chars): New function.
        URL-encode some chars in a string.
        (move-beginning-of-line): Remove unused var `start'.
        (blink-matching-open): Restructure in a more functional style.
 
-2007-09-16  Michaël Cadilhac  <michael@cadilhac.name>
+2007-09-16  Michaël Cadilhac  <michael@cadilhac.name>
 
        * calendar/holidays.el (list-holidays): Remove the cyclic alias.
 
 
        * term/rxvt.el (rxvt-function-map): Initialize in the declaration.
 
-2007-09-12  Michaël Cadilhac  <michael@cadilhac.name>
+2007-09-12  Michaël Cadilhac  <michael@cadilhac.name>
 
        * net/browse-url.el (browse-url-encode-url): Fix an infinite loop.
        New argument `filename-p' to use one set of confusing chars or another.
 2007-09-10  Thien-Thi Nguyen  <ttn@gnuvola.org>
 
        * net/browse-url.el (browse-url-encode-url): Use copy-sequence.
-       Reported by Jan Djärv <jan.h.d@swipnet.se>.
+       Reported by Jan Djärv <jan.h.d@swipnet.se>.
 
 2007-09-10  Dave Love  <fx@gnu.org>
 
        Move font-lock-builtin-face down from 4 to 7 to better keep the
        progression of color brightness, and to better match Org-mode's faces.
 
-2007-09-10  Michaël Cadilhac  <michael@cadilhac.name>
+2007-09-10  Michaël Cadilhac  <michael@cadilhac.name>
 
        * progmodes/meta-mode.el (meta-font-lock-keywords)
        (font-lock-match-meta-declaration-item-and-skip-to-next)
 
        * vc-arch.el (vc-arch-checkin): Fix typo.
 
-2007-09-07  Johan Bockgård  <bojohan@gnu.org>
+2007-09-07  Johan Bockgård  <bojohan@gnu.org>
 
        * cus-face.el (custom-theme-set-faces): Set face attributes
        locally for each frame.
        * complete.el (PC-do-completion): Don't try to treat
        empty string as an abbreviation.
 
-2007-09-06  Johan Bockgård  <bojohan@dd.chalmers.se>
+2007-09-06  Johan Bockgård  <bojohan@dd.chalmers.se>
 
        * help-fns.el (describe-variable): Keep doc's text properties.
 
        (normal-no-mouse-startup-screen): New fn, broken out.
        (normal-about-screen): New function, contents all new.
 
-2007-09-05  Michaël Cadilhac  <michael@cadilhac.name>
+2007-09-05  Michaël Cadilhac  <michael@cadilhac.name>
 
        * emacs-lisp/rx.el (rx): Fix typo in docstring.
 
        * cus-edit.el (custom-buffer-create-internal): Check tool-bar-mode
        is bound.
 
-2007-09-05  Johan Bockgård  <bojohan@dd.chalmers.se>
+2007-09-05  Johan Bockgård  <bojohan@dd.chalmers.se>
 
        * emacs-lisp/advice.el (ad-make-advised-docstring): Highlight note
        in doc string.
        (terminal-init-xterm): Use it.  Deal with delete-frame hook.
        Add the selected frame to xterm-modify-other-keys-terminal-list.
 
-2007-09-02  Jan Djärv  <jan.h.d@swipnet.se>
+2007-09-02  Jan Djärv  <jan.h.d@swipnet.se>
 
        * term/x-win.el (x-gtk-stock-map): Map diropen to system-file-manager.
        (icon-map-list): New variable.
 
        * vc-svn.el (vc-svn-diff-tree): Pass a list to vc-svn-diff.
 
-2007-08-31  Michaël Cadilhac  <michael@cadilhac.name>
+2007-08-31  Michaël Cadilhac  <michael@cadilhac.name>
 
        * textmodes/flyspell.el (flyspell-mark-duplications-exceptions):
        New variable.  List of exceptions for the duplicated word rule.
        * files.el (create-file-buffer): If the filename sans directory starts
        with spaces, remove them.
 
-2007-08-31  Jan Djärv  <jan.h.d@swipnet.se>
+2007-08-31  Jan Djärv  <jan.h.d@swipnet.se>
 
        * term/x-win.el (x-gtk-stock-map): Add etc/images to keys.
        (x-gtk-map-stock): Use two directory elements when matching
 
        * version.el (emacs-version): Increase to 23.0.50.
 
-2007-08-29  Jan Djärv  <jan.h.d@swipnet.se>
+2007-08-29  Jan Djärv  <jan.h.d@swipnet.se>
 
        * term/x-win.el (x-gtk-stock-map): :version changed to 23.1.
 
 
        * env.el (getenv): Pass frame to getenv-internal.
 
-2007-08-29  Károly LÅ\91rentey  <lorentey@elte.hu>
+2007-08-29  Károly LÅÂ\91rentey  <lorentey@elte.hu>
 
        * version.el (emacs-version): Show if multi-tty is present.
 
        (display-time-world-timer-second, display-time-world-mode-map):
        New variables.
 
-2007-08-28  Jan Djärv  <jan.h.d@swipnet.se>
+2007-08-28  Jan Djärv  <jan.h.d@swipnet.se>
 
        * term/x-win.el (x-gtk-stock-map): New variable.
        (x-gtk-map-stock): New function.
        * info.el (info-tool-bar-map): Add :rtl keyword to right/left-arrow and
        prev/next-node.
 
-2007-08-28  Johan Bockgård  <bojohan@dd.chalmers.se>  (tiny change)
+2007-08-28  Johan Bockgård  <bojohan@dd.chalmers.se>  (tiny change)
 
        * play/gamegrid.el (gamegrid-init): Set line-spacing to 0.
 
 
        * vc.el (vc-annotate-warp-version): Don't use previous-line.
 
-2007-08-27  Johan Bockgård  <bojohan@dd.chalmers.se>
+2007-08-27  Johan Bockgård  <bojohan@dd.chalmers.se>
 
        * net/browse-url.el (browse-url-emacs): New function.
 
 
        * emacs-lisp/avl-tree.el: New file.
 
-2007-08-26  Michaël Cadilhac  <michael@cadilhac.name>
+2007-08-26  Michaël Cadilhac  <michael@cadilhac.name>
 
        * hi-lock.el (hi-lock-unface-buffer): Show a x-menu only if the mouse
        was used.
        undo-list when setting syntax-table properties.
        (ada-after-change-function): Use ada-set-syntax-table-properties.
 
-2007-08-18  Michaël Cadilhac  <michael@cadilhac.name>
+2007-08-18  Michaël Cadilhac  <michael@cadilhac.name>
 
        * progmodes/meta-mode.el (meta-indent-calculate-last): Remove.
        (meta-indent-current-nesting): Use a computation of the nesting
        (cperl-find-pods-heres): Fix an error when typing expressions like
        `s{a}{b}'.
 
-2007-08-17  Michaël Cadilhac  <michael@cadilhac.name>
+2007-08-17  Michaël Cadilhac  <michael@cadilhac.name>
 
        * mail/emacsbug.el (report-emacs-bug): Remove the last number of
        `emacs-version', use the topic prefix ``version; ''.  Make MS-DOS
        sloppier, for the sake of GNU Mailman.
        (rmail-digest-rfc1153): Initialize `result' correctly.
 
-2007-08-15  Michaël Cadilhac  <michael@cadilhac.name>
+2007-08-15  Michaël Cadilhac  <michael@cadilhac.name>
 
        * mail/emacsbug.el (report-emacs-bug): Put `Bug: emacs-version; '
        in the mail title.  Suggested by Reiner Steib.
 
        * net/trampver.el: Update release number.
 
-2007-07-22  Jan Djärv  <jan.h.d@swipnet.se>
+2007-07-22  Jan Djärv  <jan.h.d@swipnet.se>
 
        * startup.el (command-line-x-option-alist): Use x-handle-no-bitmap-icon.
 
        * isearch.el (isearch-edit-string): Call to isearch-push-state
        after the search.
 
-2007-07-09  Jan Djärv  <jan.h.d@swipnet.se>
+2007-07-09  Jan Djärv  <jan.h.d@swipnet.se>
 
        * window.el (fit-window-to-buffer): Remove setting of window-min-height
        to 1 as enlarge-window uses the value to resize/shrink windows other
        * font-lock.el (lisp-font-lock-keywords-2): Recognize the new \(?1:..\)
        syntax as well.  Reported by Juri Linkov <juri@jurta.org>.
 
-2007-06-28  Jan Djärv  <jan.h.d@swipnet.se>
+2007-06-28  Jan Djärv  <jan.h.d@swipnet.se>
 
        * dnd.el (dnd-get-local-file-name): Set fixcase to t in call to
        replace-regexp-in-string.
 
        * diff-mode.el (diff-font-lock-keywords): Fix M. Kifer's last change.
 
-2007-06-13  Johan Bockgård  <bojohan@dd.chalmers.se>  (tiny change)
+2007-06-13  Johan Bockgård  <bojohan@dd.chalmers.se>  (tiny change)
 
        * term/xterm.el (terminal-init-xterm): Escape parens in character
        constants.
        * emacs-lisp/bytecomp.el (byte-compile-find-cl-functions):
        Match against file-name-nondirectory.
        Fix text on user customization variables.
-       Reported by Johan Bockgård <bojohan@dd.chalmers.se>.
+       Reported by Johan Bockgård <bojohan@dd.chalmers.se>.
 
 2007-06-09  Alfred M. Szmidt  <ams@gnu.org>  (tiny change)
 
 
        * files.el (set-auto-mode): Doc fix.
 
-2007-05-22  Jan Djärv  <jan.h.d@swipnet.se>
+2007-05-22  Jan Djärv  <jan.h.d@swipnet.se>
 
        * help-fns.el (find-source-lisp-file): New function.
        (describe-function-1): Use find-source-lisp-file to find source
        * dabbrev.el (dabbrev-eliminate-newlines):
        Renamed from dabbrev--eliminate-newlines.  All uses changed.
 
-2007-05-10  Michaël Cadilhac  <michael@cadilhac.name>
+2007-05-10  Michaël Cadilhac  <michael@cadilhac.name>
 
        * man.el (Man-next-section): Don't consider the last line of the page
        as being part of any section.
        * image-dired.el (image-dired-display-image): Derive image-type from
        filename rather than assuming jpeg, in case no resizing was needed.
 
-2007-04-25  Johan Bockgård  <bojohan@dd.chalmers.se>
+2007-04-25  Johan Bockgård  <bojohan@dd.chalmers.se>
 
        * custom.el (defface): Doc fix.
 
index 6f2543ac9ace908df5a1a13fd9e1e05a353c8611..9840d6f808fd7e34b23e395d50be018ad6f51ef8 100644 (file)
@@ -1,4 +1,4 @@
-;;; proced.el --- operate on processes like dired
+;;; proced.el --- operate on system processes like dired
 
 ;; Copyright (C) 2008 Free Software Foundation, Inc.
 
 
 ;;; Commentary:
 
-;; Proced makes an Emacs buffer containing a listing of the current processes
-;; (using ps(1)).  You can use the normal Emacs commands to move around in
-;; this buffer, and special Proced commands to operate on the processes listed.
+;; Proced makes an Emacs buffer containing a listing of the current system
+;; processes (using ps(1)).  You can use the normal Emacs commands
+;; to move around in this buffer, and special Proced commands to operate
+;; on the processes listed.
 ;;
-;; To autoload, use
-;;     (autoload 'proced "proced" nil t)
-;; in your .emacs file.
-;;
-;; Is there a need for additional features like:
-;; - automatic update of process list
+;; To do:
 ;; - sort by CPU time or other criteria
 ;; - filter by user name or other criteria
+;; - automatic update of process list
 
 ;;; Code:
 
          `(("user" ("ps" "-fu" ,(number-to-string (user-uid))) 2)
            ("all" ("ps" "-ef") 2))))
   "Alist of commands to get list of processes.
-Each element has the form (NAME COMMAND PID-COLUMN SORT-COLUMN).
+Each element has the form (NAME COMMAND PID-COLUMN).
 NAME is a shorthand name to select the type of listing.
 COMMAND is a list (COMMAND-NAME ARG1 ARG2 ...),
 where COMMAND-NAME is the command to generate the listing (usually \"ps\").
 ARG1, ARG2, ... are arguments passed to COMMAND-NAME to generate
 a particular listing.  These arguments differ under various operating systems.
-PID-COLUMN is the column number (starting from 1) of the process ID.
-SORT-COLUMN is the column number used for sorting the process listing
-\(must be a numeric field).  If nil, the process listing is not sorted."
+PID-COLUMN is the column number (starting from 1) of the process ID."
   :group 'proced
   :type '(repeat (group (string :tag "name")
                         (cons (string :tag "command")
@@ -90,11 +85,15 @@ SORT-COLUMN is the column number used for sorting the process listing
 Must be the car of an element of `proced-command-alist'."
   :group 'proced
   :type '(string :tag "name"))
+(make-variable-buffer-local 'proced-command)
 
-(defcustom proced-kill-program "kill"
-  "Name of kill command (usually `kill')."
+(defcustom proced-signal-function 'signal-process
+  "Name of signal function.
+It can be an elisp function (usually `signal-process') or a string specifying
+the external command (usually \"kill\")."
   :group 'proced
-  :type '(string :tag "command"))
+  :type '(choice (function :tag "function")
+                 (string :tag "command")))
 
 (defcustom proced-signal-list
   '(("HUP   (1.  Hangup)")
@@ -148,6 +147,7 @@ Important: the match ends just after the marker.")
 (defvar proced-procname-column nil
   "Proced command column.
 Initialized based on `proced-procname-column-regexp'.")
+(make-variable-buffer-local 'proced-procname-column)
 
 (defvar proced-font-lock-keywords
   (list
@@ -173,13 +173,16 @@ Initialized based on `proced-procname-column-regexp'.")
     (define-key km "d" 'proced-mark) ; Dired compatibility
     (define-key km "m" 'proced-mark)
     (define-key km "M" 'proced-mark-all)
-    (define-key km "g" 'revert-buffer) ; Dired compatibility
-    (define-key km "q" 'quit-window)
     (define-key km "u" 'proced-unmark)
+    (define-key km "\177" 'proced-unmark-backward)
     (define-key km "U" 'proced-unmark-all)
+    (define-key km "t" 'proced-toggle-marks)
+    (define-key km "h" 'proced-hide-processes)
     (define-key km "x" 'proced-send-signal) ; Dired compatibility
     (define-key km "k" 'proced-send-signal) ; kill processes
     (define-key km "l" 'proced-listing-type)
+    (define-key km "g" 'revert-buffer) ; Dired compatibility
+    (define-key km "q" 'quit-window)
     (define-key km [remap undo] 'proced-undo)
     (define-key km [remap advertised-undo] 'proced-undo)
     km)
@@ -192,6 +195,9 @@ Initialized based on `proced-procname-column-regexp'.")
     ["Unmark" proced-unmark t]
     ["Mark All" proced-mark-all t]
     ["Unmark All" proced-unmark-all t]
+    ["Toggle Marks" proced-unmark-all t]
+    "--"
+    ["Hide Marked Processes" proced-hide-processes t]
     "--"
     ["Revert" revert-buffer t]
     ["Send signal" proced-send-signal t]
@@ -201,8 +207,28 @@ Initialized based on `proced-procname-column-regexp'.")
   "(n)ext, (p)revious, (m)ark, (u)nmark, (k)ill, (q)uit  (type ? for more help)"
   "Help string for proced.")
 
+(defun proced-marker-regexp ()
+  (concat "^" (regexp-quote (char-to-string proced-marker-char))))
+
+(defun proced-success-message (action count)
+  (message "%s %s process%s" action count (if (= 1 count) "" "es")))
+
+(defun proced-move-to-procname ()
+  "Move to the beginning of the process name on the current line.
+Return the position of the beginning of the process name, or nil if none found."
+  (beginning-of-line)
+  (if proced-procname-column
+      (forward-char proced-procname-column)
+    (forward-char 2)))
+
+(defsubst proced-skip-regexp ()
+  "Regexp to skip in process listing."
+  (apply 'concat (make-list (1- (nth 2 (assoc proced-command
+                                              proced-command-alist)))
+                            "\\s-+\\S-+")))
+
 (defun proced-mode (&optional arg)
-  "Mode for displaying UNIX processes and sending signals to them.
+  "Mode for displaying UNIX system processes and sending signals to them.
 Type \\[proced-mark-process] to mark a process for later commands.
 Type \\[proced-send-signal] to send signals to marked processes.
 
@@ -240,15 +266,8 @@ information will be displayed but not selected.
 ;; Proced mode is suitable only for specially formatted data.
 (put 'proced-mode 'mode-class 'special)
 
-(fset 'proced 'proced-mode)
-
-(defun proced-move-to-procname ()
-  "Move to the beginning of the process name on the current line.
-Return the position of the beginning of the process name, or nil if none found."
-  (beginning-of-line)
-  (if proced-procname-column
-      (forward-char proced-procname-column)
-    (forward-char 2)))
+;;;###autoload
+(defalias 'proced 'proced-mode)
 
 (defun proced-mark (&optional count)
   "Mark the current (or next COUNT) processes."
@@ -260,20 +279,24 @@ Return the position of the beginning of the process name, or nil if none found."
   (interactive "p")
   (proced-do-mark nil count))
 
+(defun proced-unmark-backward (&optional count)
+  "Unmark the previous (or COUNT previous) processes."
+  (interactive "p")
+  (proced-do-mark nil (- (or count 1))))
+
 (defun proced-do-mark (mark &optional count)
   "Mark the current (or next ARG) processes using MARK."
   (or count (setq count 1))
-  (let ((n (if (<= 0 count) 1 -1))
+  (let ((backward (< count 0))
         (line (line-number-at-pos))
        buffer-read-only)
     ;; do nothing in the first line
     (unless (= line 1)
-      (setq count (1+ (cond ((<= 0 count) count)
-                            ((< (abs count) line) (abs count))
-                            (t (1- line)))))
+      (setq count (1+ (if (<= 0 count) count
+                        (min (- line 2) (abs count)))))
       (beginning-of-line)
       (while (not (or (zerop (setq count (1- count))) (eobp)))
-        (proced-insert-mark mark n))
+        (proced-insert-mark mark backward))
       (proced-move-to-procname))))
 
 (defun proced-mark-all ()
@@ -288,18 +311,74 @@ Return the position of the beginning of the process name, or nil if none found."
 
 (defun proced-do-mark-all (mark)
   "Mark all processes using MARK."
-  (save-excursion
-    (let (buffer-read-only)
+  (let (buffer-read-only)
+    (save-excursion
       (goto-line 2)
       (while (not (eobp))
-        (proced-insert-mark mark 1)))))
+        (proced-insert-mark mark)))))
 
-(defun proced-insert-mark (mark n)
-  "If MARK is non-nil, insert `proced-marker-char', move N lines."
-  ;; Do we need other marks besides `proced-marker-char'?
+(defun proced-toggle-marks ()
+  "Toggle marks: marked processes become unmarked, and vice versa."
+  (interactive)
+  (let ((mark-re (proced-marker-regexp))
+        buffer-read-only)
+    (save-excursion
+      (goto-line 2)
+      (while (not (eobp))
+        (cond ((looking-at mark-re)
+               (proced-insert-mark nil))
+              ((looking-at " ")
+               (proced-insert-mark t))
+              (t
+               (forward-line 1)))))))
+
+(defun proced-insert-mark (mark &optional backward)
+  "If MARK is non-nil, insert `proced-marker-char'.
+If BACKWARD is non-nil, move one line backwards before inserting the mark.
+Otherwise move one line forward after inserting the mark."
+  (if backward (forward-line -1))
   (insert (if mark proced-marker-char ?\s))
   (delete-char 1)
-  (forward-line n))
+  (unless backward (forward-line)))
+
+;; Mostly analog of `dired-do-kill-lines'.
+;; However, for negative args the target lines of `dired-do-kill-lines'
+;; include the current line, whereas `dired-mark' for negative args operates
+;; on the preceding lines. Here we are consistent with `dired-mark'.
+(defun proced-hide-processes (&optional arg quiet)
+  "Hide marked processes.
+With prefix ARG, hide that many lines starting with the current line.
+\(A negative argument hides backward.)
+If QUIET is non-nil suppress status message.
+Returns count of hidden lines."
+  (interactive "P")
+  (let ((mark-re (proced-marker-regexp))
+        (count 0)
+        buffer-read-only)
+    (save-excursion
+      (if arg
+          ;; Hide ARG lines starting with the current line.
+          (let ((line (line-number-at-pos)))
+            ;; do nothing in the first line
+            (unless (= line 1)
+              (delete-region (line-beginning-position)
+                             (save-excursion
+                               (if (<= 0 arg)
+                                   (setq count (- arg (forward-line arg)))
+                                 (setq count (min (- line 2) (abs arg)))
+                                 (forward-line (- count)))
+                               (point)))))
+        ;; Hide marked lines
+        (goto-line 2)
+        (while (and (not (eobp))
+                    (re-search-forward mark-re nil t))
+          (delete-region (match-beginning 0)
+                         (save-excursion (forward-line) (point)))
+          (setq count (1+ count)))))
+    (unless (zerop count) (proced-move-to-procname))
+    (unless quiet
+      (proced-success-message "Hid" count))
+    count))
 
 (defun proced-listing-type (command)
   "Select `proced' listing type COMMAND from `proced-command-alist'."
@@ -308,14 +387,9 @@ Return the position of the beginning of the process name, or nil if none found."
   (setq proced-command command)
   (proced-update))
 
-(defsubst proced-skip-regexp ()
-  "Regexp to skip in process listing."
-  (apply 'concat (make-list (1- (nth 2 (assoc proced-command
-                                              proced-command-alist)))
-                            "\\s-+\\S-+")))
-
 (defun proced-update (&optional quiet)
   "Update the `proced' process information.  Preserves point and marks."
+  ;; This is the main function that generates and updates the process listing.
   (interactive)
   (or quiet (message "Updating process information..."))
   (let* ((command (cdr (assoc proced-command proced-command-alist)))
@@ -342,16 +416,12 @@ Return the position of the beginning of the process name, or nil if none found."
     (goto-char (point-min))
     (while (re-search-forward "[ \t\r]+$" nil t)
       (delete-region (match-beginning 0) (match-end 0)))
+    (set-buffer-modified-p nil)
     ;; set `proced-procname-column'
     (goto-char (point-min))
     (and proced-procname-column-regexp
          (re-search-forward proced-procname-column-regexp nil t)
          (setq proced-procname-column (1- (match-beginning 0))))
-    ;; sort fields
-    (goto-line 2)
-    (if (nth 2 command)
-        (sort-numeric-fields (nth 2 command) (point) (point-max)))
-    (set-buffer-modified-p nil)
     ;; restore process marks
     (if plist
         (save-excursion
@@ -380,7 +450,8 @@ Return the position of the beginning of the process name, or nil if none found."
   "Analog of `revert-buffer'."
   (proced-update))
 
-;; I do not want to reinvent the wheel
+;; I do not want to reinvent the wheel.  Should we rename `dired-pop-to-buffer'
+;; and move it to simple.el so that proced and ibuffer can easily use it, too?
 (autoload 'dired-pop-to-buffer "dired")
 
 (defun proced-send-signal (&optional signal)
@@ -388,21 +459,23 @@ Return the position of the beginning of the process name, or nil if none found."
 SIGNAL may be a string (HUP, INT, TERM, etc.) or a number.
 If SIGNAL is nil display marked processes and query interactively for SIGNAL."
   (interactive)
-  (let ((regexp (concat "^\\*" (proced-skip-regexp) "\\s-+\\([0-9]+\\>\\).*$"))
+  (let ((regexp (concat (proced-marker-regexp)
+                        (proced-skip-regexp) "\\s-+\\([0-9]+\\>\\).*$"))
         plist)
     ;; collect marked processes
     (save-excursion
       (goto-char (point-min))
       (while (re-search-forward regexp nil t)
         (push (cons (match-string-no-properties 1)
+                    ;; How much info should we collect here?  Would it be
+                    ;; better to collect only the PID (to avoid ambiguities)
+                    ;; and the command name?
                     (substring (match-string-no-properties 0) 2))
               plist)))
     (if (not plist)
         (message "No processes marked")
       (unless signal
         ;; Display marked processes (code taken from `dired-mark-pop-up').
-        ;; We include all process information to distinguish multiple
-        ;; instances of the same program.
         (let ((bufname  " *Marked Processes*")
               (header (save-excursion
                         (goto-char (+ 2 (point-min)))
@@ -417,19 +490,48 @@ If SIGNAL is nil display marked processes and query interactively for SIGNAL."
             (save-window-excursion
               (dired-pop-to-buffer bufname) ; all we need
               (let* ((completion-ignore-case t)
+                     (pnum (if (= 1 (length plist))
+                               "1 process"
+                             (format "%d processes" (length plist))))
                      ;; The following is an ugly hack. Is there a better way
                      ;; to help people like me to remember the signals and
                      ;; their meanings?
-                     (tmp (completing-read "Signal (default TERM): "
+                     (tmp (completing-read (concat "Send signal [" pnum
+                                                   "] (default TERM): ")
                                            proced-signal-list
                                            nil nil nil nil "TERM")))
                 (setq signal (if (string-match "^\\(\\S-+\\)\\s-" tmp)
                                  (match-string 1 tmp) tmp))))))
         ;; send signal
-        (apply 'call-process proced-kill-program nil 0 nil
-               (concat "-" (if (numberp signal)
-                               (number-to-string signal) signal))
-               (mapcar 'car plist))
+        (let ((count 0)
+              err-list)
+          (if (functionp proced-signal-function)
+              ;; use built-in `signal-process'
+              (let ((signal (if (stringp signal)
+                                (if (string-match "\\`[0-9]+\\'" signal)
+                                    (string-to-number signal)
+                                  (make-symbol signal))
+                              signal))) ; number
+                (dolist (process plist)
+                  (if (zerop (funcall
+                              proced-signal-function
+                              (string-to-number (car process)) signal))
+                      (push (cdr process) err-list)
+                    (setq count (1+ count)))))
+            ;; use external system call
+            (let ((signal (concat "-" (if (numberp signal)
+                                          (number-to-string signal) signal))))
+              (dolist (process plist)
+                (if (zerop (call-process
+                            proced-signal-function nil 0 nil
+                            signal (car process)))
+                    (push (cdr process) err-list)
+                  (setq count (1+ count))))))
+          (if err-list
+              ;; FIXME: that's not enough to display the errors.
+              (message "%s: %s" signal err-list)
+            (proced-success-message "Sent signal to" count)))
+        ;; final clean-up
         (run-hooks 'proced-after-send-signal-hook)))))
 
 (defun proced-help ()