annotate lisp/proced.el @ 94108:7ab68bf3a905

(proced-mode): Redefine as just the major-mode. (proced): Separate it from proced-mode.
author Stefan Monnier <monnier@iro.umontreal.ca>
date Wed, 16 Apr 2008 03:07:49 +0000
parents f446992a6a91
children 6457a4cc8690
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
1 ;;; proced.el --- operate on system processes like dired
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
2
93213
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
3 ;; Copyright (C) 2008 Free Software Foundation, Inc.
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
4
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
5 ;; Author: Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
6 ;; Keywords: Processes, Unix
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
7
93213
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
8 ;; This file is part of GNU Emacs.
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
9
93213
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
10 ;; GNU Emacs is free software; you can redistribute it and/or modify
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
11 ;; it under the terms of the GNU General Public License as published by
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
12 ;; the Free Software Foundation; either version 3, or (at your option)
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
13 ;; any later version.
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
14
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
15 ;; GNU Emacs is distributed in the hope that it will be useful,
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
16 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
18 ;; GNU General Public License for more details.
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
19
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
20 ;; You should have received a copy of the GNU General Public License
93213
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
21 ;; along with GNU Emacs; see the file COPYING. If not, write to the
f51aae2fc6a4 Update copyright.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93212
diff changeset
22 ;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
23 ;; Boston, MA 02110-1301, USA.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
24
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
25 ;;; Commentary:
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
26
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
27 ;; Proced makes an Emacs buffer containing a listing of the current system
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
28 ;; processes (using ps(1)). You can use the normal Emacs commands
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
29 ;; to move around in this buffer, and special Proced commands to operate
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
30 ;; on the processes listed.
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
31 ;;
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
32 ;; To do:
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
33 ;; - sort by CPU time or other criteria
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
34 ;; - filter by user name or other criteria
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
35 ;; - automatic update of process list
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
36
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
37 ;;; Code:
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
38
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
39 (defgroup proced nil
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
40 "Proced mode."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
41 :group 'processes
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
42 :group 'unix
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
43 :prefix "proced-")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
44
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
45 (defcustom proced-procname-column-regexp "\\b\\(CMD\\|COMMAND\\)\\b"
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
46 "If non-nil, regexp that defines the `proced-procname-column'."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
47 :group 'proced
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
48 :type '(choice (const :tag "none" nil)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
49 (regexp :tag "regexp")))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
50
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
51 (defcustom proced-command-alist
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
52 (cond ((memq system-type '(berkeley-unix netbsd))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
53 '(("user" ("ps" "-uxgww") 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
54 ("user-running" ("ps" "-uxrgww") 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
55 ("all" ("ps" "-auxgww") 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
56 ("all-running" ("ps" "-auxrgww") 2)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
57 ((memq system-type '(linux lignux gnu/linux))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
58 `(("user" ("ps" "uxwww") 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
59 ("user-running" ("ps" "uxrwww") 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
60 ("all" ("ps" "auxwww") 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
61 ("all-running" ("ps" "auxrwww") 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
62 ("emacs" ("ps" "--pid" ,(number-to-string (emacs-pid))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
63 "--ppid" ,(number-to-string (emacs-pid))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
64 "uwww") 2)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
65 (t ; standard syntax doesn't allow us to list running processes only
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
66 `(("user" ("ps" "-fu" ,(number-to-string (user-uid))) 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
67 ("all" ("ps" "-ef") 2))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
68 "Alist of commands to get list of processes.
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
69 Each element has the form (NAME COMMAND PID-COLUMN).
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
70 NAME is a shorthand name to select the type of listing.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
71 COMMAND is a list (COMMAND-NAME ARG1 ARG2 ...),
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
72 where COMMAND-NAME is the command to generate the listing (usually \"ps\").
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
73 ARG1, ARG2, ... are arguments passed to COMMAND-NAME to generate
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
74 a particular listing. These arguments differ under various operating systems.
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
75 PID-COLUMN is the column number (starting from 1) of the process ID."
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
76 :group 'proced
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
77 :type '(repeat (group (string :tag "name")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
78 (cons (string :tag "command")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
79 (repeat (string :tag "option")))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
80 (integer :tag "PID column")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
81 (option (integer :tag "sort column")))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
82
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
83 (defcustom proced-command (if (zerop (user-real-uid)) "all" "user")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
84 "Name of process listing.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
85 Must be the car of an element of `proced-command-alist'."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
86 :group 'proced
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
87 :type '(string :tag "name"))
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
88 (make-variable-buffer-local 'proced-command)
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
89
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
90 (defcustom proced-signal-function 'signal-process
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
91 "Name of signal function.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
92 It can be an elisp function (usually `signal-process') or a string specifying
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
93 the external command (usually \"kill\")."
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
94 :group 'proced
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
95 :type '(choice (function :tag "function")
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
96 (string :tag "command")))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
97
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
98 (defcustom proced-signal-list
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
99 '(("HUP (1. Hangup)")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
100 ("INT (2. Terminal interrupt)")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
101 ("QUIT (3. Terminal quit)")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
102 ("ABRT (6. Process abort)")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
103 ("KILL (9. Kill -- cannot be caught or ignored)")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
104 ("ALRM (14. Alarm Clock)")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
105 ("TERM (15. Termination)"))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
106 "List of signals, used for minibuffer completion."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
107 :group 'proced
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
108 :type '(repeat (string :tag "signal")))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
109
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
110 (defvar proced-marker-char ?* ; the answer is 42
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
111 "In proced, the current mark character.")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
112
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
113 ;; face and font-lock code taken from dired
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
114 (defgroup proced-faces nil
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
115 "Faces used by Proced."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
116 :group 'proced
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
117 :group 'faces)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
118
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
119 (defface proced-header
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
120 '((t (:inherit font-lock-type-face)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
121 "Face used for proced headers."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
122 :group 'proced-faces)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
123 (defvar proced-header-face 'proced-header
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
124 "Face name used for proced headers.")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
125
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
126 (defface proced-mark
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
127 '((t (:inherit font-lock-constant-face)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
128 "Face used for proced marks."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
129 :group 'proced-faces)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
130 (defvar proced-mark-face 'proced-mark
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
131 "Face name used for proced marks.")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
132
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
133 (defface proced-marked
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
134 '((t (:inherit font-lock-warning-face)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
135 "Face used for marked processes."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
136 :group 'proced-faces)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
137 (defvar proced-marked-face 'proced-marked
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
138 "Face name used for marked processes.")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
139
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
140 (defvar proced-re-mark "^[^ \n]"
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
141 "Regexp matching a marked line.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
142 Important: the match ends just after the marker.")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
143
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
144 (defvar proced-header-regexp "\\`.*$"
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
145 "Regexp matching a header line.")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
146
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
147 (defvar proced-procname-column nil
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
148 "Proced command column.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
149 Initialized based on `proced-procname-column-regexp'.")
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
150 (make-variable-buffer-local 'proced-procname-column)
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
151
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
152 (defvar proced-font-lock-keywords
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
153 (list
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
154 ;;
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
155 ;; Process listing headers.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
156 (list proced-header-regexp '(0 proced-header-face))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
157 ;;
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
158 ;; Proced marks.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
159 (list proced-re-mark '(0 proced-mark-face))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
160 ;;
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
161 ;; Marked files.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
162 (list (concat "^[" (char-to-string proced-marker-char) "]")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
163 '(".+" (proced-move-to-procname) nil (0 proced-marked-face)))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
164
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
165 (defvar proced-mode-map
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
166 (let ((km (make-sparse-keymap)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
167 (define-key km " " 'next-line)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
168 (define-key km "n" 'next-line)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
169 (define-key km "p" 'previous-line)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
170 (define-key km "\C-?" 'previous-line)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
171 (define-key km "h" 'describe-mode)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
172 (define-key km "?" 'proced-help)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
173 (define-key km "d" 'proced-mark) ; Dired compatibility
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
174 (define-key km "m" 'proced-mark)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
175 (define-key km "M" 'proced-mark-all)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
176 (define-key km "u" 'proced-unmark)
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
177 (define-key km "\177" 'proced-unmark-backward)
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
178 (define-key km "U" 'proced-unmark-all)
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
179 (define-key km "t" 'proced-toggle-marks)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
180 (define-key km "h" 'proced-hide-processes)
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
181 (define-key km "x" 'proced-send-signal) ; Dired compatibility
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
182 (define-key km "k" 'proced-send-signal) ; kill processes
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
183 (define-key km "l" 'proced-listing-type)
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
184 (define-key km "g" 'revert-buffer) ; Dired compatibility
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
185 (define-key km "q" 'quit-window)
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
186 (define-key km [remap undo] 'proced-undo)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
187 (define-key km [remap advertised-undo] 'proced-undo)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
188 km)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
189 "Keymap for proced commands")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
190
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
191 (easy-menu-define
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
192 proced-menu proced-mode-map "Proced Menu"
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
193 '("Proced"
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
194 ["Mark" proced-mark t]
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
195 ["Unmark" proced-unmark t]
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
196 ["Mark All" proced-mark-all t]
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
197 ["Unmark All" proced-unmark-all t]
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
198 ["Toggle Marks" proced-unmark-all t]
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
199 "--"
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
200 ["Hide Marked Processes" proced-hide-processes t]
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
201 "--"
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
202 ["Revert" revert-buffer t]
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
203 ["Send signal" proced-send-signal t]
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
204 ["Change listing" proced-listing-type t]))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
205
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
206 (defconst proced-help-string
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
207 "(n)ext, (p)revious, (m)ark, (u)nmark, (k)ill, (q)uit (type ? for more help)"
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
208 "Help string for proced.")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
209
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
210 (defun proced-marker-regexp ()
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
211 (concat "^" (regexp-quote (char-to-string proced-marker-char))))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
212
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
213 (defun proced-success-message (action count)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
214 (message "%s %s process%s" action count (if (= 1 count) "" "es")))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
215
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
216 (defun proced-move-to-procname ()
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
217 "Move to the beginning of the process name on the current line.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
218 Return the position of the beginning of the process name, or nil if none found."
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
219 (beginning-of-line)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
220 (if proced-procname-column
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
221 (forward-char proced-procname-column)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
222 (forward-char 2)))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
223
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
224 (defsubst proced-skip-regexp ()
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
225 "Regexp to skip in process listing."
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
226 (apply 'concat (make-list (1- (nth 2 (assoc proced-command
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
227 proced-command-alist)))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
228 "\\s-+\\S-+")))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
229
94108
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
230 (define-derived-mode proced-mode nil "Proced"
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
231 "Mode for displaying UNIX system processes and sending signals to them.
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
232 Type \\[proced-mark-process] to mark a process for later commands.
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
233 Type \\[proced-send-signal] to send signals to marked processes.
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
234
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
235 \\{proced-mode-map}"
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
236 (abbrev-mode 0)
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
237 (auto-fill-mode 0)
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
238 (setq buffer-read-only t
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
239 truncate-lines t)
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
240 (set (make-local-variable 'revert-buffer-function) 'proced-revert)
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
241 (set (make-local-variable 'font-lock-defaults)
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
242 '(proced-font-lock-keywords t nil nil beginning-of-line)))
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
243
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
244 ;; Proced mode is suitable only for specially formatted data.
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
245 (put 'proced-mode 'mode-class 'special)
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
246
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
247 ;;;###autoload
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
248 (defun proced (&optional arg)
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
249 "Mode for displaying UNIX system processes and sending signals to them.
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
250 Type \\[proced-mark-process] to mark a process for later commands.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
251 Type \\[proced-send-signal] to send signals to marked processes.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
252
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
253 If invoked with optional ARG the window displaying the process
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
254 information will be displayed but not selected.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
255
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
256 \\{proced-mode-map}"
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
257 (interactive "P")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
258 (let ((proced-buffer (get-buffer-create "*Process Info*")) new)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
259 (set-buffer proced-buffer)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
260 (setq new (zerop (buffer-size)))
94108
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
261 (when new (proced-mode))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
262
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
263 (if (or new arg)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
264 (proced-update))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
265
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
266 (if arg
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
267 (display-buffer proced-buffer)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
268 (pop-to-buffer proced-buffer)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
269 (message (substitute-command-keys
94108
7ab68bf3a905 (proced-mode): Redefine as just the major-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents: 94066
diff changeset
270 "type \\[quit-window] to quit, \\[proced-help] for help")))))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
271
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
272
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
273 (defun proced-mark (&optional count)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
274 "Mark the current (or next COUNT) processes."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
275 (interactive "p")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
276 (proced-do-mark t count))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
277
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
278 (defun proced-unmark (&optional count)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
279 "Unmark the current (or next COUNT) processes."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
280 (interactive "p")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
281 (proced-do-mark nil count))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
282
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
283 (defun proced-unmark-backward (&optional count)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
284 "Unmark the previous (or COUNT previous) processes."
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
285 (interactive "p")
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
286 (proced-do-mark nil (- (or count 1))))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
287
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
288 (defun proced-do-mark (mark &optional count)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
289 "Mark the current (or next ARG) processes using MARK."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
290 (or count (setq count 1))
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
291 (let ((backward (< count 0))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
292 (line (line-number-at-pos))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
293 buffer-read-only)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
294 ;; do nothing in the first line
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
295 (unless (= line 1)
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
296 (setq count (1+ (if (<= 0 count) count
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
297 (min (- line 2) (abs count)))))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
298 (beginning-of-line)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
299 (while (not (or (zerop (setq count (1- count))) (eobp)))
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
300 (proced-insert-mark mark backward))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
301 (proced-move-to-procname))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
302
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
303 (defun proced-mark-all ()
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
304 "Mark all processes."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
305 (interactive)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
306 (proced-do-mark-all t))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
307
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
308 (defun proced-unmark-all ()
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
309 "Unmark all processes."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
310 (interactive)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
311 (proced-do-mark-all nil))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
312
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
313 (defun proced-do-mark-all (mark)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
314 "Mark all processes using MARK."
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
315 (let (buffer-read-only)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
316 (save-excursion
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
317 (goto-line 2)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
318 (while (not (eobp))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
319 (proced-insert-mark mark)))))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
320
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
321 (defun proced-toggle-marks ()
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
322 "Toggle marks: marked processes become unmarked, and vice versa."
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
323 (interactive)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
324 (let ((mark-re (proced-marker-regexp))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
325 buffer-read-only)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
326 (save-excursion
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
327 (goto-line 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
328 (while (not (eobp))
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
329 (cond ((looking-at mark-re)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
330 (proced-insert-mark nil))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
331 ((looking-at " ")
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
332 (proced-insert-mark t))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
333 (t
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
334 (forward-line 1)))))))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
335
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
336 (defun proced-insert-mark (mark &optional backward)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
337 "If MARK is non-nil, insert `proced-marker-char'.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
338 If BACKWARD is non-nil, move one line backwards before inserting the mark.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
339 Otherwise move one line forward after inserting the mark."
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
340 (if backward (forward-line -1))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
341 (insert (if mark proced-marker-char ?\s))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
342 (delete-char 1)
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
343 (unless backward (forward-line)))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
344
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
345 ;; Mostly analog of `dired-do-kill-lines'.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
346 ;; However, for negative args the target lines of `dired-do-kill-lines'
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
347 ;; include the current line, whereas `dired-mark' for negative args operates
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
348 ;; on the preceding lines. Here we are consistent with `dired-mark'.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
349 (defun proced-hide-processes (&optional arg quiet)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
350 "Hide marked processes.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
351 With prefix ARG, hide that many lines starting with the current line.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
352 \(A negative argument hides backward.)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
353 If QUIET is non-nil suppress status message.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
354 Returns count of hidden lines."
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
355 (interactive "P")
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
356 (let ((mark-re (proced-marker-regexp))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
357 (count 0)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
358 buffer-read-only)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
359 (save-excursion
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
360 (if arg
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
361 ;; Hide ARG lines starting with the current line.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
362 (let ((line (line-number-at-pos)))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
363 ;; do nothing in the first line
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
364 (unless (= line 1)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
365 (delete-region (line-beginning-position)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
366 (save-excursion
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
367 (if (<= 0 arg)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
368 (setq count (- arg (forward-line arg)))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
369 (setq count (min (- line 2) (abs arg)))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
370 (forward-line (- count)))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
371 (point)))))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
372 ;; Hide marked lines
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
373 (goto-line 2)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
374 (while (and (not (eobp))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
375 (re-search-forward mark-re nil t))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
376 (delete-region (match-beginning 0)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
377 (save-excursion (forward-line) (point)))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
378 (setq count (1+ count)))))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
379 (unless (zerop count) (proced-move-to-procname))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
380 (unless quiet
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
381 (proced-success-message "Hid" count))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
382 count))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
383
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
384 (defun proced-listing-type (command)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
385 "Select `proced' listing type COMMAND from `proced-command-alist'."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
386 (interactive
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
387 (list (completing-read "Listing type: " proced-command-alist nil t)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
388 (setq proced-command command)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
389 (proced-update))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
390
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
391 (defun proced-update (&optional quiet)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
392 "Update the `proced' process information. Preserves point and marks."
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
393 ;; This is the main function that generates and updates the process listing.
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
394 (interactive)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
395 (or quiet (message "Updating process information..."))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
396 (let* ((command (cdr (assoc proced-command proced-command-alist)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
397 (regexp (concat (proced-skip-regexp) "\\s-+\\([0-9]+\\>\\)"))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
398 (old-pos (if (save-excursion
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
399 (beginning-of-line)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
400 (looking-at (concat "^[* ]" regexp)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
401 (cons (match-string-no-properties 1)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
402 (current-column))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
403 buffer-read-only plist)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
404 (goto-char (point-min))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
405 ;; remember marked processes (whatever the mark was)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
406 (while (re-search-forward (concat "^\\(\\S-\\)" regexp) nil t)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
407 (push (cons (match-string-no-properties 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
408 (match-string-no-properties 1)) plist))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
409 ;; generate new listing
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
410 (erase-buffer)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
411 (apply 'call-process (caar command) nil t nil (cdar command))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
412 (goto-char (point-min))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
413 (while (not (eobp))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
414 (insert " ")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
415 (forward-line))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
416 ;; (delete-trailing-whitespace)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
417 (goto-char (point-min))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
418 (while (re-search-forward "[ \t\r]+$" nil t)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
419 (delete-region (match-beginning 0) (match-end 0)))
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
420 (set-buffer-modified-p nil)
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
421 ;; set `proced-procname-column'
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
422 (goto-char (point-min))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
423 (and proced-procname-column-regexp
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
424 (re-search-forward proced-procname-column-regexp nil t)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
425 (setq proced-procname-column (1- (match-beginning 0))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
426 ;; restore process marks
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
427 (if plist
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
428 (save-excursion
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
429 (goto-line 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
430 (let (mark)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
431 (while (re-search-forward (concat "^" regexp) nil t)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
432 (if (setq mark (assoc (match-string-no-properties 1) plist))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
433 (save-excursion
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
434 (beginning-of-line)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
435 (insert (cdr mark))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
436 (delete-char 1)))))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
437 ;; restore buffer position (if possible)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
438 (goto-line 2)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
439 (if (and old-pos
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
440 (re-search-forward
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
441 (concat "^[* ]" (proced-skip-regexp) "\\s-+" (car old-pos) "\\>")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
442 nil t))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
443 (progn
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
444 (beginning-of-line)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
445 (forward-char (cdr old-pos)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
446 (proced-move-to-procname))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
447 (or quiet (input-pending-p)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
448 (message "Updating process information...done."))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
449
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
450 (defun proced-revert (&rest args)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
451 "Analog of `revert-buffer'."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
452 (proced-update))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
453
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
454 ;; I do not want to reinvent the wheel. Should we rename `dired-pop-to-buffer'
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
455 ;; and move it to simple.el so that proced and ibuffer can easily use it, too?
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
456 (autoload 'dired-pop-to-buffer "dired")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
457
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
458 (defun proced-send-signal (&optional signal)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
459 "Send a SIGNAL to the marked processes.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
460 SIGNAL may be a string (HUP, INT, TERM, etc.) or a number.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
461 If SIGNAL is nil display marked processes and query interactively for SIGNAL."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
462 (interactive)
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
463 (let ((regexp (concat (proced-marker-regexp)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
464 (proced-skip-regexp) "\\s-+\\([0-9]+\\>\\).*$"))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
465 plist)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
466 ;; collect marked processes
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
467 (save-excursion
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
468 (goto-char (point-min))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
469 (while (re-search-forward regexp nil t)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
470 (push (cons (match-string-no-properties 1)
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
471 ;; How much info should we collect here? Would it be
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
472 ;; better to collect only the PID (to avoid ambiguities)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
473 ;; and the command name?
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
474 (substring (match-string-no-properties 0) 2))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
475 plist)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
476 (if (not plist)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
477 (message "No processes marked")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
478 (unless signal
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
479 ;; Display marked processes (code taken from `dired-mark-pop-up').
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
480 (let ((bufname " *Marked Processes*")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
481 (header (save-excursion
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
482 (goto-char (+ 2 (point-min)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
483 (buffer-substring-no-properties
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
484 (point) (line-end-position)))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
485 (with-current-buffer (get-buffer-create bufname)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
486 (setq truncate-lines t)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
487 (erase-buffer)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
488 (insert header "\n")
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
489 (dolist (proc plist)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
490 (insert (cdr proc) "\n"))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
491 (save-window-excursion
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
492 (dired-pop-to-buffer bufname) ; all we need
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
493 (let* ((completion-ignore-case t)
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
494 (pnum (if (= 1 (length plist))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
495 "1 process"
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
496 (format "%d processes" (length plist))))
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
497 ;; The following is an ugly hack. Is there a better way
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
498 ;; to help people like me to remember the signals and
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
499 ;; their meanings?
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
500 (tmp (completing-read (concat "Send signal [" pnum
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
501 "] (default TERM): ")
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
502 proced-signal-list
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
503 nil nil nil nil "TERM")))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
504 (setq signal (if (string-match "^\\(\\S-+\\)\\s-" tmp)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
505 (match-string 1 tmp) tmp))))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
506 ;; send signal
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
507 (let ((count 0)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
508 err-list)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
509 (if (functionp proced-signal-function)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
510 ;; use built-in `signal-process'
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
511 (let ((signal (if (stringp signal)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
512 (if (string-match "\\`[0-9]+\\'" signal)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
513 (string-to-number signal)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
514 (make-symbol signal))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
515 signal))) ; number
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
516 (dolist (process plist)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
517 (if (zerop (funcall
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
518 proced-signal-function
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
519 (string-to-number (car process)) signal))
94066
f446992a6a91 (proced-send-signal): Fix error recognition.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 94063
diff changeset
520 (setq count (1+ count))
f446992a6a91 (proced-send-signal): Fix error recognition.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 94063
diff changeset
521 (push (cdr process) err-list))))
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
522 ;; use external system call
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
523 (let ((signal (concat "-" (if (numberp signal)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
524 (number-to-string signal) signal))))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
525 (dolist (process plist)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
526 (if (zerop (call-process
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
527 proced-signal-function nil 0 nil
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
528 signal (car process)))
94066
f446992a6a91 (proced-send-signal): Fix error recognition.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 94063
diff changeset
529 (setq count (1+ count))
f446992a6a91 (proced-send-signal): Fix error recognition.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 94063
diff changeset
530 (push (cdr process) err-list)))))
94063
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
531 (if err-list
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
532 ;; FIXME: that's not enough to display the errors.
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
533 (message "%s: %s" signal err-list)
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
534 (proced-success-message "Sent signal to" count)))
ab8c45d22418 (proced-command-alist): Remove sort column.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93248
diff changeset
535 ;; final clean-up
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
536 (run-hooks 'proced-after-send-signal-hook)))))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
537
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
538 (defun proced-help ()
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
539 "Provide help for the `proced' user."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
540 (interactive)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
541 (if (eq last-command 'proced-help)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
542 (describe-mode)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
543 (message proced-help-string)))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
544
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
545 (defun proced-undo ()
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
546 "Undo in a proced buffer.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
547 This doesn't recover killed processes, it just undoes changes in the proced
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
548 buffer. You can use it to recover marks."
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
549 (interactive)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
550 (let (buffer-read-only)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
551 (undo))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
552 (message "Change in proced buffer undone.
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
553 Killed processes cannot be recovered by Emacs."))
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
554
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
555 (provide 'proced)
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
556
93248
072dbbf778d2 Add arch-tag.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents: 93213
diff changeset
557 ;; arch-tag: a6e312ad-9032-45aa-972d-31a8cfc545af
93212
134b2dc25692 proced.el: New file.
Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
parents:
diff changeset
558 ;;; proced.el ends here.