annotate lisp/dialog-gtk.el @ 5773:94a6b8fbd56e

Use a face, show more context around open parenthesis, #'blink-matching-open lisp/ChangeLog addition: 2013-12-17 Aidan Kehoe <kehoea@parhasard.net> * simple.el (blink-matching-open): When showing the opening parenthesis in the minibiffer, use the isearch face for it, in case there are multiple parentheses in the text shown. When writing moderately involved macros, it's often not enough just to show the backquote context before the parenthesis (e.g. @,.`). Skip over that when searching for useful context in the same way we skip over space and tab. * simple.el (message): * simple.el (lmessage): If there are no ARGS, don't call #'format. This allows extent information to be passed through to the minibuffer. It's probably better still to update #'format to preserve extent info.
author Aidan Kehoe <kehoea@parhasard.net>
date Tue, 17 Dec 2013 20:49:52 +0200
parents ac37a5f7e5be
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
1 ;;; dialog-gtk.el --- Dialog-box support for XEmacs w/GTK primitives
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
2
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
3 ;; Copyright (C) 2000 Free Software Foundation, Inc.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
4
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
5 ;; Maintainer: William M. Perry <wmperry@gnu.org>
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
6 ;; Keywords: extensions, internal, dumped
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
7
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
8 ;; This file is part of XEmacs.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
9
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 2367
diff changeset
10 ;; XEmacs is free software: you can redistribute it and/or modify it
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 2367
diff changeset
11 ;; under the terms of the GNU General Public License as published by the
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 2367
diff changeset
12 ;; Free Software Foundation, either version 3 of the License, or (at your
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 2367
diff changeset
13 ;; option) any later version.
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
14
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 2367
diff changeset
15 ;; XEmacs is distributed in the hope that it will be useful, but WITHOUT
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 2367
diff changeset
16 ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 2367
diff changeset
17 ;; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 2367
diff changeset
18 ;; for more details.
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
19
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
20 ;; You should have received a copy of the GNU General Public License
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 2367
diff changeset
21 ;; along with XEmacs. If not, see <http://www.gnu.org/licenses/>.
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
22
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
23 ;;; Synched up with: Not in FSF.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
24
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
25 ;;; Commentary:
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
26
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
27 ;; This file is dumped with XEmacs (when dialog boxes are compiled in).
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
28
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
29 (require 'cl)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
30 (require 'gtk-password-dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
31 (require 'gtk-file-dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
32
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
33 (globally-declare-fboundp
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
34 '(gtk-signal-connect
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
35 gtk-main-quit gtk-window-set-transient-for
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
36 gtk-widget-show-all gtk-main gtk-color-selection-dialog-new
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
37 gtk-color-selection-dialog-ok-button gtk-widget-hide-all
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
38 gtk-color-selection-get-color
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
39 gtk-color-selection-dialog-colorsel
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
40 gtk-color-selection-dialog-cancel-button gtk-widget-show-now
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
41 gtk-widget-grab-focus gtk-widget-destroy gtk-dialog-new
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
42 gtk-window-set-title gtk-container-set-border-width
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
43 gtk-box-set-spacing gtk-dialog-vbox gtk-container-add
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
44 gtk-label-new gtk-button-new-with-label
2081
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
45 gtk-widget-set-sensitive gtk-widget-show gtk-dialog-action-area
2367
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 2081
diff changeset
46 gtk-label-parse-uline gtk-widget-add-accelerator gtk-accel-group-new
ecf1ebac70d8 [xemacs-hg @ 2004-11-04 23:05:23 by ben]
ben
parents: 2081
diff changeset
47 gtk-misc-set-alignment gtk-button-new gtk-window-add-accel-group))
2081
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
48
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
49 (defun gtk-popup-convert-underscores (str)
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
50 ;; Convert the XEmacs button accelerator representation to Gtk mnemonic
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
51 ;; form. If no accelerator has been provided, put one at the start of the
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
52 ;; string (this mirrors the behaviour under X). This algorithm is also found
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
53 ;; in menubar-gtk.c:convert_underscores().
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
54 (let ((new-str (string))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
55 (i 0)
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
56 (found-accel nil))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
57 (while (< i (length str))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
58 (let ((c (aref str i)))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
59 (cond ((eq c ?%)
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
60 (setq i (1+ i))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
61 (if (and (not (eq (aref str i) ?_)) (not (eq (aref str i) ?%)))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
62 (setq i (1- i)))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
63 (setq found-accel 1)
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
64 )
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
65 ((eq c ?_)
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
66 (setq new-str (concat new-str "_")))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
67 ))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
68 (setq new-str (concat new-str (string (aref str i))))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
69 (setq i (1+ i))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
70 )
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
71 (if found-accel new-str (concat "_" new-str))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
72 ))
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
73
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
74 (defun popup-builtin-open-dialog (keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
75 ;; Allowed keywords are:
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
76 ;;
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
77 ;; :initial-filename fname
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
78 ;; :initial-directory dir
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
79 ;; :filter-list (filter-desc filter ...)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
80 ;; :directory t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
81 ;; :title string
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
82 ;; :allow-multi-select t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
83 ;; :create-prompt-on-nonexistent t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
84 ;; :overwrite-prompt t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
85 ;; :file-must-exist t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
86 ;; :no-network-button t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
87 ;; :no-read-only-return t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
88 (let ((initial-filename (plist-get keys :initial-filename))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
89 (clicked-ok nil)
622
11502791fc1c [xemacs-hg @ 2001-06-22 01:49:57 by ben]
ben
parents: 608
diff changeset
90 (widget nil)
11502791fc1c [xemacs-hg @ 2001-06-22 01:49:57 by ben]
ben
parents: 608
diff changeset
91 filename)
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
92 (setq widget (gtk-file-dialog-new
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
93 :directory (plist-get keys :directory)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
94 :callback `(lambda (f)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
95 (setq clicked-ok t
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
96 filename f))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
97 :initial-directory (or (plist-get keys :initial-directory nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
98 (if initial-filename
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
99 (file-name-directory initial-filename)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
100 default-directory))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
101 :filter-list (plist-to-alist
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
102 (plist-get keys :filter-list nil))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
103 :file-must-exist (plist-get keys :file-must-exist nil)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
104
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
105 (gtk-signal-connect widget 'destroy (lambda (obj data) (gtk-main-quit)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
106
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
107 (gtk-window-set-transient-for widget (frame-property nil 'shell-widget))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
108 (gtk-widget-show-all widget)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
109 (gtk-main)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
110 (if (not clicked-ok)
608
4d7fdf497470 [xemacs-hg @ 2001-06-04 16:59:51 by wmperry]
wmperry
parents: 502
diff changeset
111 (signal 'quit nil)
4d7fdf497470 [xemacs-hg @ 2001-06-04 16:59:51 by wmperry]
wmperry
parents: 502
diff changeset
112 filename)))
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
113
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
114 (defalias 'popup-builtin-save-as-dialog 'popup-builtin-open-dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
115
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
116 (defun popup-builtin-color-dialog (keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
117 ;; Allowed keys:
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
118 ;; :initial-color COLOR
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
119 (let (;(initial-color (or (plist-get keys :initial-color) "white"))
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
120 (title (or (plist-get keys :title "Select color...")))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
121 (dialog nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
122 (clicked-ok nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
123 (color nil))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
124 (setq dialog (gtk-color-selection-dialog-new title))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
125 (gtk-signal-connect
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
126 (gtk-color-selection-dialog-ok-button dialog) 'clicked
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
127 (lambda (button colorsel)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
128 (gtk-widget-hide-all dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
129 (setq color (gtk-color-selection-get-color colorsel)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
130 clicked-ok t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
131 (gtk-main-quit))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
132 (gtk-color-selection-dialog-colorsel dialog))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
133
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
134 (gtk-signal-connect
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
135 (gtk-color-selection-dialog-cancel-button dialog) 'clicked
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
136 (lambda (&rest ignored)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
137 (gtk-main-quit)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
138
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
139 (put dialog 'modal t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
140 (put dialog 'type 'dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
141 (gtk-window-set-transient-for dialog (frame-property nil 'shell-widget))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
142
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
143 (unwind-protect
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
144 (progn
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
145 (gtk-widget-show-now dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
146 (gtk-main))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
147 '(gtk-widget-destroy dialog))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
148 (if (not clicked-ok)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
149 (signal 'quit nil))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
150 ;; Need to convert from (R G B A) to #rrggbb
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
151 (format "#%02x%02x%02x"
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
152 (* 256 (nth 0 color))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
153 (* 256 (nth 1 color))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
154 (* 256 (nth 2 color)))))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
155
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
156 (defun popup-builtin-password-dialog (keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
157 ;; Format is (default callback :keyword value)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
158 ;; Allowed keywords are:
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
159 ;;
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
160 ;; :title string
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
161 :; :prompt string
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
162 ;; :default string
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
163 ;; :verify boolean
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
164 ;; :verify-prompt string
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
165 (let* ((default (plist-get keys :default))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
166 (dialog nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
167 (clicked-ok nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
168 (passwd nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
169 (info nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
170 (generic-cb (lambda (x)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
171 (setq clicked-ok t
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
172 passwd x))))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
173
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
174 ;; Convert the descriptor to keywords and create the dialog
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
175 (setq info (copy-list keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
176 info (plist-put info :callback generic-cb)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
177 info (plist-put info :default default)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
178 dialog (apply 'gtk-password-dialog-new info))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
179
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
180 ;; Clicking any button or closing the box exits the main loop.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
181 (gtk-signal-connect (gtk-password-dialog-ok-button dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
182 'clicked
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
183 (lambda (&rest ignored)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
184 (gtk-main-quit)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
185
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
186 (gtk-signal-connect (gtk-password-dialog-cancel-button dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
187 'clicked
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
188 (lambda (&rest ignored)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
189 (gtk-main-quit)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
190
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
191 (gtk-signal-connect dialog
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
192 'delete-event
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
193 (lambda (&rest ignored)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
194 (gtk-main-quit)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
195
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
196 (gtk-widget-grab-focus (gtk-password-dialog-entry-widget dialog))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
197
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
198 ;; Make us modal...
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
199 (put dialog 'modal t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
200 (gtk-window-set-transient-for dialog (frame-property nil 'shell-widget))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
201
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
202 ;; Realize the damn thing & wait for some action...
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
203 (gtk-widget-show-all dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
204 (gtk-main)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
205
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
206 (if (not clicked-ok)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
207 (signal 'quit nil))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
208
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
209 (gtk-widget-destroy dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
210 passwd))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
211
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
212 (defun popup-builtin-question-dialog (keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
213 ;; Allowed keywords:
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
214 ;; :question STRING
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
215 ;; :buttons BUTTONDESC
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
216 (let ((title (or (plist-get keys :title) "Question"))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
217 (buttons-descr (plist-get keys :buttons))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
218 (question (or (plist-get keys :question) "Question goes here..."))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
219 (dialog nil) ; GtkDialog
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
220 (buttons nil) ; List of GtkButton objects
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
221 (activep t)
707
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
222 (callback nil)
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
223 (flushrightp nil)
707
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
224 (length nil)
2081
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
225 (label nil)
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
226 (gui-button nil)
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
227 (accel-group (gtk-accel-group-new))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
228 (accel-key nil)
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
229 (errp t))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
230 (if (not buttons-descr)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
231 (error 'syntax-error
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
232 "Dialog descriptor must supply at least one button"))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
233
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
234 ;; Do the basics - create the dialog, set the window title, and
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
235 ;; add the label asking the question.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
236 (unwind-protect
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
237 (progn
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
238 (setq dialog (gtk-dialog-new))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
239 (gtk-window-set-title dialog title)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
240 (gtk-container-set-border-width dialog 3)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
241 (gtk-box-set-spacing (gtk-dialog-vbox dialog) 5)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
242 (gtk-container-add (gtk-dialog-vbox dialog) (gtk-label-new question))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
243
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
244 ;; Create the buttons.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
245 (mapc (lambda (button)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
246 ;; Handle flushright buttons
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
247 (if (null button)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
248 (setq flushrightp t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
249
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
250 ;; More sanity checking first of all.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
251 (if (not (vectorp button))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
252 (error "Button descriptor is not a vector: %S" button))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
253
707
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
254 (setq length (length button))
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
255
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
256 (cond
5366
f00192e1cd49 Examining the result of #'length: `eql', not `=', it's better style & cheaper
Aidan Kehoe <kehoea@parhasard.net>
parents: 2367
diff changeset
257 ((eql length 1) ; [ "name" ]
707
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
258 (setq callback nil
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
259 activep nil))
5366
f00192e1cd49 Examining the result of #'length: `eql', not `=', it's better style & cheaper
Aidan Kehoe <kehoea@parhasard.net>
parents: 2367
diff changeset
260 ((eql length 2) ; [ "name" callback ]
707
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
261 (setq callback (aref button 1)
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
262 activep t))
5366
f00192e1cd49 Examining the result of #'length: `eql', not `=', it's better style & cheaper
Aidan Kehoe <kehoea@parhasard.net>
parents: 2367
diff changeset
263 ((and (or (eql length 3) (eql length 4))
707
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
264 (not (keywordp (aref button 2))))
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
265 ;; [ "name" callback active-p ] or
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
266 ;; [ "name" callback active-p suffix ]
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
267 ;; We ignore the 'suffix' entry, because that is
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
268 ;; what the X code does.
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
269 (setq callback (aref button 1)
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
270 activep (aref button 2)))
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
271 (t ; 100% keyword specification
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
272 (let ((plist (cdr (mapcar 'identity button))))
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
273 (setq activep (plist-get plist :active)
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
274 callback (plist-get plist :callback)))))
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
275
2081
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
276 ;; Create the label and determine what the mnemonic key is.
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
277 (setq label (gtk-label-new ""))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
278 (setq accel-key (gtk-label-parse-uline label
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
279 (gtk-popup-convert-underscores (aref button 0))))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
280 ;; Place the label in the button.
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
281 (gtk-misc-set-alignment label 0.5 0.5)
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
282 (setq gui-button (gtk-button-new))
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
283 (gtk-container-add gui-button label)
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
284 ;; Add ALT-mnemonic to the dialog's accelerator group.
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
285 (gtk-widget-add-accelerator gui-button "clicked" accel-group
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
286 accel-key
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
287 8 ; GDK_MOD1_MASK
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
288 4 ; GTK_ACCEL_LOCKED
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
289 )
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
290
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
291 (push gui-button buttons)
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
292 (gtk-widget-set-sensitive (car buttons) (eval activep))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
293
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
294 ;; Apply the callback
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
295 (gtk-signal-connect
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
296 (car buttons) 'clicked
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
297 (lambda (button data)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
298 (push (make-event 'misc-user
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
299 (list 'object (car data)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
300 'function
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
301 (if (symbolp (car data))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
302 'call-interactively
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
303 'eval)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
304 unread-command-events)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
305 (gtk-main-quit)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
306 t)
707
a307f9a2021d [xemacs-hg @ 2001-12-20 05:49:28 by andyp]
andyp
parents: 622
diff changeset
307 (cons callback dialog))
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
308
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
309 (gtk-widget-show (car buttons))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
310 (funcall (if flushrightp 'gtk-box-pack-end 'gtk-box-pack-start)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
311 (gtk-dialog-action-area dialog) (car buttons)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
312 nil t 2)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
313 buttons-descr)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
314
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
315 ;; Make sure they can't close it with the window manager
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
316 (gtk-signal-connect dialog 'delete-event (lambda (&rest ignored) t))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
317 (gtk-window-set-transient-for dialog (frame-property nil 'shell-widget))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
318 (put dialog 'type 'dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
319 (put dialog 'modal t)
2081
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
320 ;; Make the dialog listen for global mnemonic keys/
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
321 (gtk-window-add-accel-group dialog accel-group)
e8db6a10ad42 [xemacs-hg @ 2004-05-15 07:31:43 by malcolmp]
malcolmp
parents: 707
diff changeset
322
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
323 (gtk-widget-show-all dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
324 (gtk-main)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
325 (gtk-widget-destroy dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
326 (setq errp nil))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
327 (if (not errp)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
328 ;; Nothing, we successfully showed the dialog
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
329 nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
330 ;; We need to destroy all the widgets, just in case.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
331 (mapc 'gtk-widget-destroy buttons)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
332 (gtk-widget-destroy dialog)))))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
333
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
334 (defun gtk-make-dialog-box-internal (type keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
335 (case type
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
336 (file
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
337 (popup-builtin-open-dialog keys))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
338 (password
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
339 (popup-builtin-password-dialog keys))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
340 (question
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
341 (popup-builtin-question-dialog keys))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
342 (color
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
343 (popup-builtin-color-dialog keys))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
344 (find
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
345 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
346 (font
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
347 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
348 (replace
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
349 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
350 (mswindows-message
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
351 ;; This should really be renamed!
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
352 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
353 (print
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
354 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
355 (page-setup
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
356 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
357 (print-setup
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
358 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
359 (default
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
360 (error "Unknown type of dialog: %S" type))))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
361
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
362 (provide 'dialog-gtk)