annotate src/dialog-x.c @ 771:943eaba38521

[xemacs-hg @ 2002-03-13 08:51:24 by ben] The big ben-mule-21-5 check-in! Various files were added and deleted. See CHANGES-ben-mule. There are still some test suite failures. No crashes, though. Many of the failures have to do with problems in the test suite itself rather than in the actual code. I'll be addressing these in the next day or so -- none of the test suite failures are at all critical. Meanwhile I'll be trying to address the biggest issues -- i.e. build or run failures, which will almost certainly happen on various platforms. All comments should be sent to ben@xemacs.org -- use a Cc: if necessary when sending to mailing lists. There will be pre- and post- tags, something like pre-ben-mule-21-5-merge-in, and post-ben-mule-21-5-merge-in.
author ben
date Wed, 13 Mar 2002 08:54:06 +0000
parents 183866b06e0b
children 6728e641994e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
1 /* Implements elisp-programmable dialog boxes -- X interface.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
2 Copyright (C) 1993, 1994 Free Software Foundation, Inc.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
3 Copyright (C) 1995 Tinker Systems and INS Engineering Corp.
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
4 Copyright (C) 2000 Ben Wing.
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
5
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
6 This file is part of XEmacs.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
7
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
8 XEmacs is free software; you can redistribute it and/or modify it
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
9 under the terms of the GNU General Public License as published by the
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
10 Free Software Foundation; either version 2, or (at your option) any
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
11 later version.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
12
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
13 XEmacs is distributed in the hope that it will be useful, but WITHOUT
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
16 for more details.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
17
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
19 along with XEmacs; see the file COPYING. If not, write to
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
20 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
21 Boston, MA 02111-1307, USA. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
22
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
23 /* Synched up with: Not in FSF. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
24
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
25 /* This file Mule-ized by Ben Wing, 7-8-00. */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
26
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
27 #include <config.h>
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
28 #include "lisp.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
29
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
30 #include "console-x.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
31 #include "EmacsFrame.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
32 #include "gui-x.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
33
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
34 #include "buffer.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
35 #include "commands.h" /* zmacs_regions */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
36 #include "events.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
37 #include "frame.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
38 #include "gui.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
39 #include "opaque.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
40 #include "window.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
41
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
42
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
43 static void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
44 maybe_run_dbox_text_callback (LWLIB_ID id)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
45 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
46 widget_value *wv;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
47 int got_some;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
48 wv = xmalloc_widget_value ();
436
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
49 wv->name = xstrdup ("value");
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
50 got_some = lw_get_some_values (id, wv);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
51 if (got_some)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
52 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
53 Lisp_Object text_field_callback;
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
54 Extbyte *text_field_value = wv->value;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
55 VOID_TO_LISP (text_field_callback, wv->call_data);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
56 text_field_callback = XCAR (XCDR (text_field_callback));
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
57 if (text_field_value)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
58 {
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
59 void *tmp =
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
60 LISP_TO_VOID (cons3 (Qnil,
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
61 list2 (text_field_callback,
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
62 build_ext_string (text_field_value,
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
63 Qlwlib_encoding)),
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
64 Qnil));
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
65 popup_selection_callback (0, id, (XtPointer) tmp);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
66 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
67 }
436
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
68 /* This code tried to optimize, newing/freeing. This is generally
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
69 unsafe so we will always strdup and always use
436
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
70 free_widget_value_tree. */
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
71 free_widget_value_tree (wv);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
72 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
73
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
74 static void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
75 dbox_selection_callback (Widget widget, LWLIB_ID id, XtPointer client_data)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
76 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
77 /* This is called with client_data == -1 when WM_DELETE_WINDOW is sent
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
78 instead of a button being selected. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
79 struct device *d = get_device_from_display (XtDisplay (widget));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
80 struct frame *f = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
81 Widget cur_widget = widget;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
82
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
83 /* The parent which is actually connected to our EmacsFrame may be a
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
84 ways up the tree. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
85 while (!f && cur_widget)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
86 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
87 f = x_any_window_to_frame (d, XtWindow (cur_widget));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
88 cur_widget = XtParent (cur_widget);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
89 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
90
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
91 if (popup_handled_p (id))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
92 return;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
93 assert (popup_up_p != 0);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
94 ungcpro_popup_callbacks (id);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
95 popup_up_p--;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
96 maybe_run_dbox_text_callback (id);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
97 popup_selection_callback (widget, id, client_data);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
98 /* #### need to error-protect! will do so when i merge in
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
99 my working ws */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
100 va_run_hook_with_args (Qdelete_dialog_box_hook, 1, make_int (id));
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
101 lw_destroy_all_widgets (id);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
102
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
103 /* The Motif dialog box sets the keyboard focus to itself. When it
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
104 goes away we have to take care of getting the focus back
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
105 ourselves. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
106 #ifdef EXTERNAL_WIDGET
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
107 /* #### Not sure if this special case is necessary. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
108 if (!FRAME_X_EXTERNAL_WINDOW_P (f) && f)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
109 #else
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
110 if (f)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
111 #endif
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
112 lw_set_keyboard_focus (FRAME_X_SHELL_WIDGET (f), FRAME_X_TEXT_WIDGET (f));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
113 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
114
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
115 static const Extbyte * const button_names [] = {
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
116 "button1", "button2", "button3", "button4", "button5",
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
117 "button6", "button7", "button8", "button9", "button10" };
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
118
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
119 static widget_value *
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
120 dbox_descriptor_to_widget_value (Lisp_Object keys)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
121 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
122 /* This function can GC */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
123 int lbuttons = 0, rbuttons = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
124 int partition_seen = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
125 int text_field_p = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
126 int allow_text_p = 1;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
127 widget_value *prev = 0, *kids = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
128 int n = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
129 int count = specpdl_depth ();
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
130 Lisp_Object wv_closure, gui_item;
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
131 Lisp_Object question = Qnil;
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
132 Lisp_Object title = Qnil; /* #### currently unused */
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
133 Lisp_Object buttons = Qnil;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
134
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
135 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
136 EXTERNAL_PROPERTY_LIST_LOOP_3 (key, value, keys)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
137 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
138 if (EQ (key, Q_question))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
139 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
140 CHECK_STRING (value);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
141 question = value;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
142 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
143 else if (EQ (key, Q_title))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
144 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
145 CHECK_STRING (value);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
146 title = value;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
147 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
148 else if (EQ (key, Q_buttons))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
149 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
150 CHECK_LIST (value);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
151 buttons = value;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
152 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
153 else
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
154 invalid_constant ("Unrecognized question-dialog keyword", key);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
155 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
156 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
157
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
158 if (NILP (question))
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
159 sferror ("Dialog descriptor provides no question", keys);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
160
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
161 /* Inhibit GC during this conversion. The reasons for this are
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
162 the same as in menu_item_descriptor_to_widget_value(); see
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
163 the large comment above that function. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
164
771
943eaba38521 [xemacs-hg @ 2002-03-13 08:51:24 by ben]
ben
parents: 563
diff changeset
165 begin_gc_forbidden ();
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
166
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
167 kids = prev = xmalloc_widget_value ();
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
168
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
169 /* Also make sure that we free the partially-created widget_value
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
170 tree on Lisp error. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
171
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
172 wv_closure = make_opaque_ptr (kids);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
173 record_unwind_protect (widget_value_unwind, wv_closure);
436
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
174 prev->name = xstrdup ("message");
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
175 LISP_STRING_TO_EXTERNAL_MALLOC (question, prev->value, Qlwlib_encoding);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
176 prev->enabled = 1;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
177
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
178 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
179 EXTERNAL_LIST_LOOP_2 (button, buttons)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
180 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
181 widget_value *wv;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
182
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
183 if (NILP (button))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
184 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
185 if (partition_seen)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
186 sferror ("More than one partition (nil) seen in dbox spec",
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
187 keys);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
188 partition_seen = 1;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
189 continue;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
190 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
191 CHECK_VECTOR (button);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
192 wv = xmalloc_widget_value ();
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
193
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
194 gui_item = gui_parse_item_keywords (button);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
195 if (!button_item_to_widget_value (Qdialog,
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
196 gui_item, wv, allow_text_p, 1, 0, 1))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
197 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
198 free_widget_value_tree (wv);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
199 continue;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
200 }
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
201
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
202 if (wv->type == TEXT_TYPE)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
203 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
204 text_field_p = 1;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
205 allow_text_p = 0; /* only allow one */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
206 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
207 else /* it's a button */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
208 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
209 allow_text_p = 0; /* only allow text field at the front */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
210 if (wv->value)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
211 xfree (wv->value);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
212 wv->value = wv->name; /* what a mess... */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
213 wv->name = xstrdup (button_names [n]);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
214
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
215 if (partition_seen)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
216 rbuttons++;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
217 else
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
218 lbuttons++;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
219 n++;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
220
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
221 if (lbuttons > 9 || rbuttons > 9)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
222 sferror ("Too many buttons (9)",
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
223 keys); /* #### this leaks */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
224 }
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
225
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
226 prev->next = wv;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
227 prev = wv;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
228 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
229 }
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
230
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
231 if (n == 0)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
232 sferror ("Dialog boxes must have some buttons", keys);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
233
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
234 {
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
235 Extbyte type = (text_field_p ? 'P' : 'Q');
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
236 static Extbyte tmp_dbox_name [255];
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
237
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
238 widget_value *dbox;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
239 sprintf (tmp_dbox_name, "%c%dBR%d", type, lbuttons + rbuttons, rbuttons);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
240 dbox = xmalloc_widget_value ();
436
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
241 dbox->name = xstrdup (tmp_dbox_name);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
242 dbox->contents = kids;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
243
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
244 /* No more need to free the half-filled-in structures. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
245 set_opaque_ptr (wv_closure, 0);
771
943eaba38521 [xemacs-hg @ 2002-03-13 08:51:24 by ben]
ben
parents: 563
diff changeset
246 unbind_to (count);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
247 return dbox;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
248 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
249 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
250
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
251 static Lisp_Object
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
252 x_make_dialog_box_internal (struct frame* f, Lisp_Object type,
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
253 Lisp_Object keys)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
254 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
255 int dbox_id;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
256 widget_value *data;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
257 Widget parent, dbox;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
258
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
259 if (!EQ (type, Qquestion))
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
260 signal_error (Qunimplemented, "Dialog box type", type);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
261
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
262 data = dbox_descriptor_to_widget_value (keys);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
263
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
264 parent = FRAME_X_SHELL_WIDGET (f);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
265
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
266 dbox_id = new_lwlib_id ();
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
267 dbox = lw_create_widget (data->name, "dialog", dbox_id, data, parent, 1, 0,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
268 dbox_selection_callback, 0);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
269 lw_modify_all_widgets (dbox_id, data, True);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
270 lw_modify_all_widgets (dbox_id, data->contents, True);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
271 free_popup_widget_value_tree (data);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
272
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
273 gcpro_popup_callbacks (dbox_id);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
274
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
275 /* Setting zmacs-region-stays is necessary here because executing a
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
276 command from a dialog is really a two-command process: the first
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
277 command (bound to the button-click) simply pops up the dialog,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
278 and returns. This causes a sequence of magic-events (destined
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
279 for the dialog widget) to begin. Eventually, a dialog item is
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
280 selected, and a misc-user-event blip is pushed onto the end of
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
281 the input stream, which is then executed by the event loop.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
282
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
283 So there are two command-events, with a bunch of magic-events
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
284 between them. We don't want the *first* command event to alter
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
285 the state of the region, so that the region can be available as
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
286 an argument for the second command. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
287 if (zmacs_regions)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
288 zmacs_region_stays = 1;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
289
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
290 popup_up_p++;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
291 lw_pop_up_all_widgets (dbox_id);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
292
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
293 /* #### this could (theoretically) cause problems if we are up for
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
294 a REALLY REALLY long time -- too big to fit into lisp integer. */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
295 return make_int (dbox_id);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
296 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
297
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
298 void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
299 syms_of_dialog_x (void)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
300 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
301 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
302
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
303 void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
304 console_type_create_dialog_x (void)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
305 {
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
306 CONSOLE_HAS_METHOD (x, make_dialog_box_internal);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
307 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
308
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
309 void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
310 vars_of_dialog_x (void)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
311 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
312 #if defined (LWLIB_DIALOGS_LUCID)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
313 Fprovide (intern ("lucid-dialogs"));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
314 #elif defined (LWLIB_DIALOGS_MOTIF)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
315 Fprovide (intern ("motif-dialogs"));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
316 #elif defined (LWLIB_DIALOGS_ATHENA)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
317 Fprovide (intern ("athena-dialogs"));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
318 #endif
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
319 }