annotate lisp/dialog-gtk.el @ 622:11502791fc1c

[xemacs-hg @ 2001-06-22 01:49:57 by ben] dired-msw.c: Fix problem noted by Michael Sperber with directories containing [] and code that destructively modifies an existing string. term\AT386.el: Fix warnings. term\apollo.el: Removed. Kill kill kill. Sync with FSF and remove most crap. term\linux.el: Removed. Sync with FSF. Don't define most defns, because they are automatically defined by termcap. But do add defns for keys that normally get defined as f13, f14, etc. and really ought to be shift-f3, shift-f4, etc. (NOTE: I did this based on Cygwin, which emulates the Linux console. I would appreciate it if someone on Linux could verify.) term\cygwin.el: New. Load term/linux. term\lk201.el, term\news.el, term\vt100.el: Sync with FSF. Fix warnings. dialog-gtk.el: Fix warning. For 21.4: help.el, update-elc.el: Compile in proper order. Maybe for 21.4: keydefs.el: Add a defn for M-?, previously undefined, to access help -- in case the terminal is not set up right, or f1 gets redefined. README: Rewrite.
author ben
date Fri, 22 Jun 2001 01:50:04 +0000
parents 4d7fdf497470
children a307f9a2021d
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
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
10 ;; XEmacs is free software; you can redistribute it and/or modify it
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
11 ;; under the terms of the GNU General Public License as published by
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
12 ;; the Free Software Foundation; either version 2, or (at your option)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
13 ;; any later version.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
14
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
15 ;; XEmacs is distributed in the hope that it will be useful, but
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
16 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
17 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
18 ;; General Public License for more details.
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
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
21 ;; along with XEmacs; see the file COPYING. If not, write to the
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
22 ;; Free Software Foundation, 59 Temple Place - Suite 330,
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
23 ;; Boston, MA 02111-1307, USA.
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 ;;; Synched up with: Not in FSF.
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 ;;; Commentary:
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 ;; This file is dumped with XEmacs (when dialog boxes are compiled in).
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
30
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
31 (require 'cl)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
32 (require 'gtk-password-dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
33 (require 'gtk-file-dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
34
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
35 (globally-declare-fboundp
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
36 '(gtk-signal-connect
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
37 gtk-main-quit gtk-window-set-transient-for
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
38 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
39 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
40 gtk-color-selection-get-color
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
41 gtk-color-selection-dialog-colorsel
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
42 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
43 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
44 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
45 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
46 gtk-label-new gtk-button-new-with-label
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
47 gtk-widget-set-sensitive gtk-widget-show gtk-dialog-action-area))
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
48
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
49 (defun popup-builtin-open-dialog (keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
50 ;; Allowed keywords are:
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
51 ;;
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
52 ;; :initial-filename fname
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
53 ;; :initial-directory dir
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
54 ;; :filter-list (filter-desc filter ...)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
55 ;; :directory t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
56 ;; :title string
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
57 ;; :allow-multi-select t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
58 ;; :create-prompt-on-nonexistent t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
59 ;; :overwrite-prompt t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
60 ;; :file-must-exist t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
61 ;; :no-network-button t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
62 ;; :no-read-only-return t/nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
63 (let ((initial-filename (plist-get keys :initial-filename))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
64 (clicked-ok nil)
622
11502791fc1c [xemacs-hg @ 2001-06-22 01:49:57 by ben]
ben
parents: 608
diff changeset
65 (widget nil)
11502791fc1c [xemacs-hg @ 2001-06-22 01:49:57 by ben]
ben
parents: 608
diff changeset
66 filename)
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
67 (setq widget (gtk-file-dialog-new
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
68 :directory (plist-get keys :directory)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
69 :callback `(lambda (f)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
70 (setq clicked-ok t
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
71 filename f))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
72 :initial-directory (or (plist-get keys :initial-directory nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
73 (if initial-filename
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
74 (file-name-directory initial-filename)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
75 default-directory))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
76 :filter-list (plist-to-alist
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
77 (plist-get keys :filter-list nil))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
78 :file-must-exist (plist-get keys :file-must-exist nil)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
79
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
80 (gtk-signal-connect widget 'destroy (lambda (obj data) (gtk-main-quit)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
81
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
82 (gtk-window-set-transient-for widget (frame-property nil 'shell-widget))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
83 (gtk-widget-show-all widget)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
84 (gtk-main)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
85 (if (not clicked-ok)
608
4d7fdf497470 [xemacs-hg @ 2001-06-04 16:59:51 by wmperry]
wmperry
parents: 502
diff changeset
86 (signal 'quit nil)
4d7fdf497470 [xemacs-hg @ 2001-06-04 16:59:51 by wmperry]
wmperry
parents: 502
diff changeset
87 filename)))
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
88
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
89 (defalias 'popup-builtin-save-as-dialog 'popup-builtin-open-dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
90
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
91 (defun popup-builtin-color-dialog (keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
92 ;; Allowed keys:
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
93 ;; :initial-color COLOR
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 462
diff changeset
94 (let (;(initial-color (or (plist-get keys :initial-color) "white"))
462
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
95 (title (or (plist-get keys :title "Select color...")))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
96 (dialog nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
97 (clicked-ok nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
98 (color nil))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
99 (setq dialog (gtk-color-selection-dialog-new title))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
100 (gtk-signal-connect
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
101 (gtk-color-selection-dialog-ok-button dialog) 'clicked
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
102 (lambda (button colorsel)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
103 (gtk-widget-hide-all dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
104 (setq color (gtk-color-selection-get-color colorsel)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
105 clicked-ok t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
106 (gtk-main-quit))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
107 (gtk-color-selection-dialog-colorsel dialog))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
108
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
109 (gtk-signal-connect
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
110 (gtk-color-selection-dialog-cancel-button dialog) 'clicked
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
111 (lambda (&rest ignored)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
112 (gtk-main-quit)))
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 (put dialog 'modal t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
115 (put dialog 'type 'dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
116 (gtk-window-set-transient-for dialog (frame-property nil 'shell-widget))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
117
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
118 (unwind-protect
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
119 (progn
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
120 (gtk-widget-show-now dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
121 (gtk-main))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
122 '(gtk-widget-destroy dialog))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
123 (if (not clicked-ok)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
124 (signal 'quit nil))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
125 ;; Need to convert from (R G B A) to #rrggbb
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
126 (format "#%02x%02x%02x"
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
127 (* 256 (nth 0 color))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
128 (* 256 (nth 1 color))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
129 (* 256 (nth 2 color)))))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
130
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
131 (defun popup-builtin-password-dialog (keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
132 ;; Format is (default callback :keyword value)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
133 ;; Allowed keywords are:
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
134 ;;
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
135 ;; :title string
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
136 :; :prompt string
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
137 ;; :default string
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
138 ;; :verify boolean
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
139 ;; :verify-prompt string
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
140 (let* ((default (plist-get keys :default))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
141 (dialog nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
142 (clicked-ok nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
143 (passwd nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
144 (info nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
145 (generic-cb (lambda (x)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
146 (setq clicked-ok t
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
147 passwd x))))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
148
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
149 ;; Convert the descriptor to keywords and create the dialog
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
150 (setq info (copy-list keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
151 info (plist-put info :callback generic-cb)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
152 info (plist-put info :default default)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
153 dialog (apply 'gtk-password-dialog-new info))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
154
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
155 ;; Clicking any button or closing the box exits the main loop.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
156 (gtk-signal-connect (gtk-password-dialog-ok-button dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
157 'clicked
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
158 (lambda (&rest ignored)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
159 (gtk-main-quit)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
160
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
161 (gtk-signal-connect (gtk-password-dialog-cancel-button dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
162 'clicked
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
163 (lambda (&rest ignored)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
164 (gtk-main-quit)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
165
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
166 (gtk-signal-connect dialog
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
167 'delete-event
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
168 (lambda (&rest ignored)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
169 (gtk-main-quit)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
170
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
171 (gtk-widget-grab-focus (gtk-password-dialog-entry-widget dialog))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
172
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
173 ;; Make us modal...
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
174 (put dialog 'modal t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
175 (gtk-window-set-transient-for dialog (frame-property nil 'shell-widget))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
176
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
177 ;; Realize the damn thing & wait for some action...
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
178 (gtk-widget-show-all dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
179 (gtk-main)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
180
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
181 (if (not clicked-ok)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
182 (signal 'quit nil))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
183
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
184 (gtk-widget-destroy dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
185 passwd))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
186
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
187 (defun popup-builtin-question-dialog (keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
188 ;; Allowed keywords:
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
189 ;; :question STRING
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
190 ;; :buttons BUTTONDESC
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
191 (let ((title (or (plist-get keys :title) "Question"))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
192 (buttons-descr (plist-get keys :buttons))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
193 (question (or (plist-get keys :question) "Question goes here..."))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
194 (dialog nil) ; GtkDialog
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
195 (buttons nil) ; List of GtkButton objects
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
196 (activep t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
197 (flushrightp nil)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
198 (errp t))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
199 (if (not buttons-descr)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
200 (error 'syntax-error
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
201 "Dialog descriptor must supply at least one button"))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
202
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
203 ;; Do the basics - create the dialog, set the window title, and
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
204 ;; add the label asking the question.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
205 (unwind-protect
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
206 (progn
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
207 (setq dialog (gtk-dialog-new))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
208 (gtk-window-set-title dialog title)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
209 (gtk-container-set-border-width dialog 3)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
210 (gtk-box-set-spacing (gtk-dialog-vbox dialog) 5)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
211 (gtk-container-add (gtk-dialog-vbox dialog) (gtk-label-new question))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
212
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
213 ;; Create the buttons.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
214 (mapc (lambda (button)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
215 ;; Handle flushright buttons
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
216 (if (null button)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
217 (setq flushrightp t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
218
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
219 ;; More sanity checking first of all.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
220 (if (not (vectorp button))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
221 (error "Button descriptor is not a vector: %S" button))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
222
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
223 (if (< (length button) 3)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
224 (error "Button descriptor is too small: %S" button))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
225
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
226 (push (gtk-button-new-with-label (aref button 0)) buttons)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
227
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
228 ;; Need to detect what flavor of descriptor it is.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
229 (if (not (keywordp (aref button 2)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
230 ;; Simple style... just [ name callback activep ]
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
231 ;; We ignore the 'suffix' entry, because that is what
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
232 ;; the X code does.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
233 (setq activep (aref button 2))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
234 (let ((ctr 2)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
235 (len (length button)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
236 (if (logand len 1)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
237 (error
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
238 "Button descriptor has an odd number of keywords and values: %S"
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
239 button))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
240 (while (< ctr len)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
241 (if (eq (aref button ctr) :active)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
242 (setq activep (aref button (1+ ctr))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
243 ctr len))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
244 (setq ctr (+ ctr 2)))))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
245 (gtk-widget-set-sensitive (car buttons) (eval activep))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
246
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
247 ;; Apply the callback
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
248 (gtk-signal-connect
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
249 (car buttons) 'clicked
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
250 (lambda (button data)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
251 (push (make-event 'misc-user
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
252 (list 'object (car data)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
253 'function
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
254 (if (symbolp (car data))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
255 'call-interactively
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
256 'eval)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
257 unread-command-events)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
258 (gtk-main-quit)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
259 t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
260 (cons (aref button 1) dialog))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
261
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
262 (gtk-widget-show (car buttons))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
263 (funcall (if flushrightp 'gtk-box-pack-end 'gtk-box-pack-start)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
264 (gtk-dialog-action-area dialog) (car buttons)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
265 nil t 2)))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
266 buttons-descr)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
267
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
268 ;; Make sure they can't close it with the window manager
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
269 (gtk-signal-connect dialog 'delete-event (lambda (&rest ignored) t))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
270 (gtk-window-set-transient-for dialog (frame-property nil 'shell-widget))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
271 (put dialog 'type 'dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
272 (put dialog 'modal t)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
273 (gtk-widget-show-all dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
274 (gtk-main)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
275 (gtk-widget-destroy dialog)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
276 (setq errp nil))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
277 (if (not errp)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
278 ;; Nothing, we successfully showed the dialog
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
279 nil
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
280 ;; We need to destroy all the widgets, just in case.
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
281 (mapc 'gtk-widget-destroy buttons)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
282 (gtk-widget-destroy dialog)))))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
283
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
284 (defun gtk-make-dialog-box-internal (type keys)
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
285 (case type
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
286 (file
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
287 (popup-builtin-open-dialog keys))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
288 (password
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
289 (popup-builtin-password-dialog keys))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
290 (question
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
291 (popup-builtin-question-dialog keys))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
292 (color
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
293 (popup-builtin-color-dialog keys))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
294 (find
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
295 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
296 (font
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
297 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
298 (replace
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
299 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
300 (mswindows-message
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
301 ;; This should really be renamed!
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
302 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
303 (print
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
304 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
305 (page-setup
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
306 )
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
307 (print-setup
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 (default
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
310 (error "Unknown type of dialog: %S" type))))
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
311
0784d089fdc9 Import from CVS: tag r21-2-46
cvs
parents:
diff changeset
312 (provide 'dialog-gtk)