# HG changeset patch # User Roland McGrath # Date 763991664 0 # Node ID 2f1e5e14dc25c6e8e846c9e3787d0ede2cc26cb3 # Parent 185b1fd3a5259ae5804b06ecd84d5c1c2cc8101e (map-y-or-n-p): Use a dialog box when triggered by a mouse event. diff -r 185b1fd3a525 -r 2f1e5e14dc25 lisp/map-ynp.el --- a/lisp/map-ynp.el Fri Mar 18 07:09:57 1994 +0000 +++ b/lisp/map-ynp.el Fri Mar 18 11:54:24 1994 +0000 @@ -1,6 +1,6 @@ ;;; map-ynp.el --- General-purpose boolean question-asker. -;;; Copyright (C) 1991, 1992, 1993 Free Software Foundation, Inc. +;;; Copyright (C) 1991, 1992, 1993, 1994 Free Software Foundation, Inc. ;; Author: Roland McGrath ;; Keywords: lisp, extensions @@ -76,23 +76,9 @@ are meaningful here. Returns the number of actions taken." - (let* ((user-keys (if action-alist - (concat (mapconcat (function - (lambda (elt) - (key-description - (char-to-string (car elt))))) - action-alist ", ") - " ") - "")) - ;; Make a map that defines each user key as a vector containing - ;; its definition. - (map (cons 'keymap - (append (mapcar (lambda (elt) - (cons (car elt) (vector (nth 1 elt)))) - action-alist) - query-replace-map))) - (actions 0) - prompt char elt tail def delayed-switch-frame + (let* ((actions 0) + user-keys mouse-event map prompt char elt tail def + delayed-switch-frame (next (if (or (and list (symbolp list)) (subrp list) (byte-code-function-p list) @@ -107,6 +93,37 @@ list (cdr list)) t) nil)))))) + (if (listp last-nonmenu-event) + ;; Make a list describing a dialog box. + (let ((object (capitalize (nth 0 help))) + (objects (capitalize (nth 1 help))) + (action (capitalize (nth 2 help)))) + (setq map (` (("Yes" . act) ("No" . skip) ("Quit" . exit) + ((, (if help (concat action " " object " And Quit") + "Do it and Quit")) . act-and-exit) + ((, (if help (concat action " All " objects) + "Do All")) . automatic) + (,@ (mapcar (lambda (elt) + (cons (concat (capitalize (nth 2 elt)) + " " object) + (vector (nth 1 elt)))) + action-alist)))) + mouse-event last-nonmenu-event)) + (setq user-keys (if action-alist + (concat (mapconcat (function + (lambda (elt) + (key-description + (char-to-string (car elt))))) + action-alist ", ") + " ") + "") + ;; Make a map that defines each user key as a vector containing + ;; its definition. + map (cons 'keymap + (append (mapcar (lambda (elt) + (cons (car elt) (vector (nth 1 elt)))) + action-alist) + query-replace-map)))) (unwind-protect (progn (if (stringp prompter) @@ -118,17 +135,23 @@ (progn (setq quit-flag nil) ;; Prompt the user about this object. - (let ((cursor-in-echo-area (not no-cursor-in-echo-area))) - (message "%s(y, n, !, ., q, %sor %s) " + (if mouse-event + (setq def (or (x-popup-dialog mouse-event + (list "gratuitous" + (cons prompt map))) + 'quit)) + ;; Prompt in the echo area. + (let ((cursor-in-echo-area (not no-cursor-in-echo-area))) + (message "%s(y, n, !, ., q, %sor %s) " + prompt user-keys + (key-description (vector help-char))) + (setq char (read-event))) + ;; Show the answer to the question. + (message "%s(y, n, !, ., q, %sor %s) %s" prompt user-keys - (key-description (vector help-char))) - (setq char (read-event))) - ;; Show the answer to the question. - (message "%s(y, n, !, ., q, %sor %s) %s" - prompt user-keys - (key-description (vector help-char)) - (single-key-description char)) - (setq def (lookup-key map (vector char))) + (key-description (vector help-char)) + (single-key-description char)) + (setq def (lookup-key map (vector char)))) (cond ((eq def 'exit) (setq next (function (lambda () nil)))) ((eq def 'act) @@ -171,17 +194,17 @@ ! to %s all remaining %s; ESC or `q' to exit;\n" action object object action objects) - (mapconcat (function - (lambda (elt) - (format "%c to %s" - (nth 0 elt) - (nth 2 elt)))) - action-alist - ";\n") - (if action-alist ";\n") - (format "or . (period) to %s \ + (mapconcat (function + (lambda (elt) + (format "%c to %s" + (nth 0 elt) + (nth 2 elt)))) + action-alist + ";\n") + (if action-alist ";\n") + (format "or . (period) to %s \ the current %s and exit." - action object))))) + action object))))) (setq next (` (lambda () (setq next '(, next))