summaryrefslogtreecommitdiff
path: root/lisp/wid-edit.el
diff options
context:
space:
mode:
authorRichard M. Stallman <rms@gnu.org>1997-05-31 01:37:15 +0000
committerRichard M. Stallman <rms@gnu.org>1997-05-31 01:37:15 +0000
commite5dfabb4897fc40ec5f3a282981f40b3e8049539 (patch)
tree7b2887acf205009bbc8df7dc12c76c618dc27076 /lisp/wid-edit.el
parent6d1ab9d4d67b291df337a404a93fd065bf426359 (diff)
downloademacs-e5dfabb4897fc40ec5f3a282981f40b3e8049539.tar.gz
(widget-default-format-handler): Don't use push.
(widget-push-button-value-create): Likewise. (widget-group-value-create): Likewise. (widget-sublist): New function. (widget-item-match-inline): Use widget-subllist. (widget-remove-if): New function. (widget-choose): Use widget-remove-if.
Diffstat (limited to 'lisp/wid-edit.el')
-rw-r--r--lisp/wid-edit.el73
1 files changed, 48 insertions, 25 deletions
diff --git a/lisp/wid-edit.el b/lisp/wid-edit.el
index 561c7efb42b..6de406f4c4c 100644
--- a/lisp/wid-edit.el
+++ b/lisp/wid-edit.el
@@ -31,7 +31,6 @@
;;; Code:
(require 'widget)
-(require 'cl)
;;; Compatibility.
@@ -225,7 +224,7 @@ minibuffer."
(car (event-object val))))
(cdr (assoc val items))))
(t
- (setq items (remove-if 'stringp items))
+ (setq items (widget-remove-if 'stringp items))
(let ((val (completing-read (concat title ": ") items nil t)))
(if (stringp val)
(let ((try (try-completion val items)))
@@ -234,6 +233,14 @@ minibuffer."
(cdr (assoc val items)))
nil)))))
+(defun widget-remove-if (predictate list)
+ (let (result (tail list))
+ (while tail
+ (or (funcall predictate (car tail))
+ (setq result (cons (car tail) result)))
+ (setq tail (cdr tail)))
+ (nreverse result)))
+
;;; Widget text specifications.
;;
;; These functions are for specifying text properties.
@@ -1306,19 +1313,20 @@ Optional EVENT is the event that triggered the action."
;; Get rid of trailing newlines.
(when (string-match "\n+\\'" doc-text)
(setq doc-text (substring doc-text 0 (match-beginning 0))))
- (push (if (string-match "\n." doc-text)
- ;; Allow multiline doc to be hiden.
- (widget-create-child-and-convert
- widget 'widget-help
- :doc (progn
- (string-match "\\`.*" doc-text)
- (match-string 0 doc-text))
- :widget-doc doc-text
- "?")
- ;; A single line is just inserted.
- (widget-create-child-and-convert
- widget 'item :format "%d" :doc doc-text nil))
- buttons)))
+ (setq buttons
+ (cons (if (string-match "\n." doc-text)
+ ;; Allow multiline doc to be hiden.
+ (widget-create-child-and-convert
+ widget 'widget-help
+ :doc (progn
+ (string-match "\\`.*" doc-text)
+ (match-string 0 doc-text))
+ :widget-doc doc-text
+ "?")
+ ;; A single line is just inserted.
+ (widget-create-child-and-convert
+ widget 'item :format "%d" :doc doc-text nil))
+ buttons))))
(t
(error "Unknown escape `%c'" escape)))
(widget-put widget :buttons buttons)))
@@ -1423,9 +1431,22 @@ Optional EVENT is the event that triggered the action."
(let ((value (widget-get widget :value)))
(and (listp value)
(<= (length value) (length values))
- (let ((head (subseq values 0 (length value))))
+ (let ((head (widget-sublist values 0 (length value))))
(and (equal head value)
- (cons head (subseq values (length value))))))))
+ (cons head (widget-sublist values (length value))))))))
+
+(defun widget-sublist (list start &optional end)
+ "Return the sublist of LIST from START to END.
+If END is omitted, it defaults to the length of LIST."
+ (let (len)
+ (if (> start 0) (setq list (nthcdr start list)))
+ (if end
+ (if (<= end start)
+ nil
+ (setq list (copy-sequence list))
+ (setcdr (nthcdr (- end start 1) list) nil)
+ list)
+ (copy-sequence list))))
(defun widget-item-action (widget &optional event)
;; Just notify itself.
@@ -1474,7 +1495,8 @@ Optional EVENT is the event that triggered the action."
(progn
(unless gui
(setq gui (make-gui-button tag 'widget-gui-action widget))
- (push (cons tag gui) widget-push-button-cache))
+ (setq widget-push-button-cache
+ (cons (cons tag gui) widget-push-button-cache)))
(widget-glyph-insert-glyph widget
(make-glyph
(list (nth 0 (aref gui 1))
@@ -2429,13 +2451,14 @@ when he invoked the menu."
(and (eq (preceding-char) ?\n)
(widget-get widget :indent)
(insert-char ? (widget-get widget :indent)))
- (push (cond ((null answer)
- (widget-create-child widget arg))
- ((widget-get arg :inline)
- (widget-create-child-value widget arg (car answer)))
- (t
- (widget-create-child-value widget arg (car (car answer)))))
- children))
+ (setq children
+ (cons (cond ((null answer)
+ (widget-create-child widget arg))
+ ((widget-get arg :inline)
+ (widget-create-child-value widget arg (car answer)))
+ (t
+ (widget-create-child-value widget arg (car (car answer)))))
+ children)))
(widget-put widget :children (nreverse children))))
(defun widget-group-match (widget values)