summaryrefslogtreecommitdiff
path: root/lisp
diff options
context:
space:
mode:
authorRoland Winkler <Roland.Winkler@physik.uni-erlangen.de>2008-12-14 23:16:09 +0000
committerRoland Winkler <Roland.Winkler@physik.uni-erlangen.de>2008-12-14 23:16:09 +0000
commit4ed46aefb2dcce9c51c1a6516374904be21f177c (patch)
tree340b056d6b9209ec2f6cbf7d9bd17e2f3655aa13 /lisp
parentb4f671ce5443c03c64e45a75a644712e438dbe22 (diff)
downloademacs-4ed46aefb2dcce9c51c1a6516374904be21f177c.tar.gz
(proced-sort-interactive, proced-sort-pcpu)
(proced-sort-pmem, proced-sort-start, proced-sort-time) (proced-sort-user, proced-sort-header): Prefix arg determines sorting order. Suggested by Dan Nicolaescu. (proced-revert): Doc fix.
Diffstat (limited to 'lisp')
-rw-r--r--lisp/ChangeLog8
-rw-r--r--lisp/proced.el110
2 files changed, 68 insertions, 50 deletions
diff --git a/lisp/ChangeLog b/lisp/ChangeLog
index bc03ab78c01..9ff2ec275ea 100644
--- a/lisp/ChangeLog
+++ b/lisp/ChangeLog
@@ -1,5 +1,13 @@
2008-12-14 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
+ * proced.el (proced-sort-interactive, proced-sort-pcpu)
+ (proced-sort-pmem, proced-sort-start, proced-sort-time)
+ (proced-sort-user, proced-sort-header): Prefix arg determines
+ sorting order. Suggested by Dan Nicolaescu.
+ (proced-revert): Doc fix.
+
+2008-12-14 Roland Winkler <Roland.Winkler@physik.uni-erlangen.de>
+
* proced.el (proced-grammar-alist): Allow refiner elements that
are cons pairs (function . help-echo) or nil.
(proced-refine): Use them.
diff --git a/lisp/proced.el b/lisp/proced.el
index 2988925c1d0..9f7b4206a47 100644
--- a/lisp/proced.el
+++ b/lisp/proced.el
@@ -345,6 +345,9 @@ Can be changed interactively via `proced-toggle-auto-update'."
;; Internal variables
+(defvar proced-available (not (null (list-system-processes)))
+ "Non-nil means Proced is known to work on this system.")
+
(defvar proced-process-alist nil
"Alist of processes displayed by Proced.
The car of each element is the PID, and the cdr is a list of
@@ -592,10 +595,7 @@ Type \\[proced-sort-interactive] or click on a header in the header line
to change the sort scheme. The current sort scheme is indicated in the
mode line, using \"+\" or \"-\" for ascending or descending sort order.
-An existing Proced listing can be refined by typing \\[proced-refine]
-with point on the attribute of a process. If point is on the attribute ATTR,
-this compares the value of ATTR of every process with the value of ATTR
-of the process at the position of point. See `proced-refine' for details.
+An existing Proced listing can be refined by typing \\[proced-refine].
Refining an existing listing does not update the variable `proced-filter'.
The attribute-specific rules for formatting, filtering, sorting, and refining
@@ -619,9 +619,6 @@ are defined in `proced-grammar-alist'.
;; Proced mode is suitable only for specially formatted data.
(put 'proced-mode 'mode-class 'special)
-(defvar proced-available (not (null (list-system-processes)))
- "Non-nil means Proced is known to work on this system.")
-
;;;###autoload
(defun proced (&optional arg)
"Generate a listing of UNIX system processes.
@@ -935,9 +932,9 @@ Optional EVENT is the location of the Proced field.
Refinement is controlled by the REFINER defined for each attribute ATTR
in `proced-grammar-alist'.
-If REFINER is a list of flags and point is on the attribute ATTR, this command
-compares the value of ATTR of every process with the value of ATTR
-of the process at the position of point.
+If REFINER is a list of flags and point is on a process's value of ATTR,
+this command compares the value of ATTR of every process with the value
+of ATTR of the process at the position of point.
The predicate for the comparison of two ATTR values is defined
in `proced-grammar-alist'. For each return value of the predicate
@@ -1073,12 +1070,16 @@ Return the sorted process list."
(sort process-alist 'proced-sort-p))
process-alist))
-(defun proced-sort-interactive (scheme &optional revert)
+(defun proced-sort-interactive (scheme &optional arg)
"Sort Proced buffer using SCHEME.
When called interactively, an empty string means nil, i.e., no sorting.
-With prefix REVERT non-nil revert listing.
-Repeated calls using the same value of SCHEME toggle the sort order.
+Prefix ARG controls sort order:
+- If prefix ARG is positive (negative), sort in ascending (descending) order.
+- If ARG is nil or 'no-arg and SCHEME is equal to the previous sorting scheme,
+ reverse the sorting order.
+- If ARG is nil or 'no-arg and SCHEME differs from the previous sorting scheme,
+ adopt the sorting order defined for SCHEME in `proced-grammar-alist'.
Set variable `proced-sort' to SCHEME. The current sort scheme is displayed
in the mode line, using \"+\" or \"-\" for ascending or descending order."
@@ -1086,60 +1087,68 @@ in the mode line, using \"+\" or \"-\" for ascending or descending order."
(let ((scheme (completing-read "Sort attribute: "
proced-grammar-alist nil t)))
(list (if (string= "" scheme) nil (intern scheme))
- current-prefix-arg)))
+ ;; like 'toggle in `define-derived-mode'
+ (or current-prefix-arg 'no-arg))))
+
(setq proced-descend
- ;; If `proced-sort-interactive' is called repeatedly for the same sort key,
- ;; the sort order is reversed.
- (if (equal proced-sort scheme)
- (not proced-descend)
- (nth 5 (assq (if (consp scheme) (car scheme) scheme)
- proced-grammar-alist)))
+ ;; If `proced-sort-interactive' is called repeatedly for the same
+ ;; sort key, the sort order is reversed.
+ (cond ((and (eq arg 'no-arg) (equal proced-sort scheme))
+ (not proced-descend))
+ ((eq arg 'no-arg)
+ (nth 5 (assq (if (consp scheme) (car scheme) scheme)
+ proced-grammar-alist)))
+ (arg (< (prefix-numeric-value arg) 0))
+ ((equal proced-sort scheme)
+ (not proced-descend))
+ (t (nth 5 (assq (if (consp scheme) (car scheme) scheme)
+ proced-grammar-alist))))
proced-sort scheme)
- (proced-update revert))
+ (proced-update))
-(defun proced-sort-pcpu (&optional revert)
+(defun proced-sort-pcpu (&optional arg)
"Sort Proced buffer by percentage CPU time (%CPU).
-Repeated calls toggle the sort order."
- (interactive "P")
- (proced-sort-interactive 'pcpu revert))
+Prefix ARG controls sort order, see `proced-sort-interactive'."
+ (interactive (list (or current-prefix-arg 'no-arg)))
+ (proced-sort-interactive 'pcpu arg))
-(defun proced-sort-pmem (&optional revert)
+(defun proced-sort-pmem (&optional arg)
"Sort Proced buffer by percentage memory usage (%MEM).
-Repeated calls toggle the sort order."
- (interactive "P")
- (proced-sort-interactive 'pmem revert))
+Prefix ARG controls sort order, see `proced-sort-interactive'."
+ (interactive (list (or current-prefix-arg 'no-arg)))
+ (proced-sort-interactive 'pmem arg))
-(defun proced-sort-pid (&optional revert)
+(defun proced-sort-pid (&optional arg)
"Sort Proced buffer by PID.
-Repeated calls toggle the sort order."
- (interactive "P")
- (proced-sort-interactive 'pid revert))
+Prefix ARG controls sort order, see `proced-sort-interactive'."
+ (interactive (list (or current-prefix-arg 'no-arg)))
+ (proced-sort-interactive 'pid arg))
-(defun proced-sort-start (&optional revert)
+(defun proced-sort-start (&optional arg)
"Sort Proced buffer by time the command started (START).
-Repeated calls toggle the sort order."
- (interactive "P")
- (proced-sort-interactive 'start revert))
+Prefix ARG controls sort order, see `proced-sort-interactive'."
+ (interactive (list (or current-prefix-arg 'no-arg)))
+ (proced-sort-interactive 'start arg))
-(defun proced-sort-time (&optional revert)
+(defun proced-sort-time (&optional arg)
"Sort Proced buffer by CPU time (TIME).
-Repeated calls toggle the sort order."
- (interactive "P")
- (proced-sort-interactive 'time revert))
+Prefix ARG controls sort order, see `proced-sort-interactive'."
+ (interactive (list (or current-prefix-arg 'no-arg)))
+ (proced-sort-interactive 'time arg))
-(defun proced-sort-user (&optional revert)
+(defun proced-sort-user (&optional arg)
"Sort Proced buffer by USER.
-Repeated calls toggle the sort order."
- (interactive "P")
- (proced-sort-interactive 'user revert))
+Prefix ARG controls sort order, see `proced-sort-interactive'."
+ (interactive (list (or current-prefix-arg 'no-arg)))
+ (proced-sort-interactive 'user arg))
-(defun proced-sort-header (event &optional revert)
+(defun proced-sort-header (event &optional arg)
"Sort Proced listing based on an attribute.
EVENT is a mouse event with starting position in the header line.
It is converted in the corresponding attribute key.
This command updates the variable `proced-sort'.
-Repeated calls for the same header toggle the sort order."
- (interactive "e\nP")
+Prefix ARG controls sort order, see `proced-sort-interactive'."
+ (interactive (list last-input-event (or last-prefix-arg 'no-arg)))
(let ((start (event-start event))
col key)
(save-selected-window
@@ -1149,7 +1158,7 @@ Repeated calls for the same header toggle the sort order."
(when (and (<= 0 col) (< col (length proced-header-line)))
(setq key (get-text-property col 'proced-key proced-header-line))
(if key
- (proced-sort-interactive key revert)
+ (proced-sort-interactive key arg)
(message "No sorter defined here."))))))
;;; Formating
@@ -1491,7 +1500,8 @@ Suppress status information if QUIET is nil."
"Updating process display...done.")))))
(defun proced-revert (&rest args)
- "Analog of `revert-buffer'."
+ "Reevaluate the process listing based on the currently running processes.
+Preserves point and marks."
(proced-update t))
;; I do not want to reinvent the wheel. Should we rename `dired-pop-to-buffer'