annotate src/dialog-x.c @ 5750:66d2f63df75f

Correct some spelling and formatting in behavior.el. Mentioned in tracker issue 826, the third thing mentioned there (the file name at the bottom of the file) had already been fixed. lisp/ChangeLog addition: 2013-08-05 Aidan Kehoe <kehoea@parhasard.net> * behavior.el: (override-behavior): Correct some spelling and formatting here, thank you Steven Mitchell in tracker issue 826.
author Aidan Kehoe <kehoea@parhasard.net>
date Mon, 05 Aug 2013 10:05:32 +0100
parents 56144c8593a8
children
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.
5169
6c6d78781d59 cleanup of code related to xfree(), better KKCC backtrace capabilities, document XD_INLINE_LISP_OBJECT_BLOCK_PTR, fix some memory leaks, other code cleanup
Ben Wing <ben@xemacs.org>
parents: 5013
diff changeset
4 Copyright (C) 2000, 2002, 2003, 2010 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
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 5169
diff changeset
8 XEmacs is free software: you can redistribute it and/or modify it
428
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
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 5169
diff changeset
10 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: 5169
diff changeset
11 option) any later version.
428
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
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 5169
diff changeset
19 along with XEmacs. If not, see <http://www.gnu.org/licenses/>. */
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
20
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
21 /* Synched up with: Not in FSF. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
22
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
23 /* This file Mule-ized by Ben Wing, 7-8-00. */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
24
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
25 #include <config.h>
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
26 #include "lisp.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
27
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
28 #include "buffer.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
29 #include "commands.h" /* zmacs_regions */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
30 #include "events.h"
872
79c6ff3eef26 [xemacs-hg @ 2002-06-20 21:18:01 by ben]
ben
parents: 853
diff changeset
31 #include "frame-impl.h"
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
32 #include "gui.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
33 #include "opaque.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
34 #include "window.h"
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
35
872
79c6ff3eef26 [xemacs-hg @ 2002-06-20 21:18:01 by ben]
ben
parents: 853
diff changeset
36 #include "console-x-impl.h"
79c6ff3eef26 [xemacs-hg @ 2002-06-20 21:18:01 by ben]
ben
parents: 853
diff changeset
37
79c6ff3eef26 [xemacs-hg @ 2002-06-20 21:18:01 by ben]
ben
parents: 853
diff changeset
38 #include "EmacsFrame.h"
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
39
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
40 static void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
41 maybe_run_dbox_text_callback (LWLIB_ID id)
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 widget_value *wv;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
44 int got_some;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
45 wv = xmalloc_widget_value ();
436
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
46 wv->name = xstrdup ("value");
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
47 got_some = lw_get_some_values (id, wv);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
48 if (got_some)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
49 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
50 Lisp_Object text_field_callback;
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
51 Extbyte *text_field_value = wv->value;
5013
ae48681c47fa changes to VOID_TO_LISP et al.
Ben Wing <ben@xemacs.org>
parents: 4982
diff changeset
52 text_field_callback = GET_LISP_FROM_VOID (wv->call_data);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
53 text_field_callback = XCAR (XCDR (text_field_callback));
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
54 if (text_field_value)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
55 {
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
56 void *tmp =
5013
ae48681c47fa changes to VOID_TO_LISP et al.
Ben Wing <ben@xemacs.org>
parents: 4982
diff changeset
57 STORE_LISP_IN_VOID (cons3 (Qnil,
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
58 list2 (text_field_callback,
4953
304aebb79cd3 function renamings to track names of char typedefs
Ben Wing <ben@xemacs.org>
parents: 3466
diff changeset
59 build_extstring (text_field_value,
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
60 Qlwlib_encoding)),
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
61 Qnil));
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
62 popup_selection_callback (0, id, (XtPointer) tmp);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
63 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
64 }
436
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
65 /* This code tried to optimize, newing/freeing. This is generally
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
66 unsafe so we will always strdup and always use
436
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
67 free_widget_value_tree. */
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
68 free_widget_value_tree (wv);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
69 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
70
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
71 static void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
72 dbox_selection_callback (Widget widget, LWLIB_ID id, XtPointer client_data)
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 /* 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
75 instead of a button being selected. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
76 struct device *d = get_device_from_display (XtDisplay (widget));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
77 struct frame *f = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
78 Widget cur_widget = widget;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
79
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
80 /* The parent which is actually connected to our EmacsFrame may be a
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
81 ways up the tree. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
82 while (!f && cur_widget)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
83 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
84 f = x_any_window_to_frame (d, XtWindow (cur_widget));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
85 cur_widget = XtParent (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
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
88 if (popup_handled_p (id))
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
89 return;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
90 assert (popup_up_p != 0);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
91 ungcpro_popup_callbacks (id);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
92 popup_up_p--;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
93 maybe_run_dbox_text_callback (id);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
94 popup_selection_callback (widget, id, client_data);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
95 /* #### need to error-protect! will do so when i merge in
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
96 my working ws */
5581
56144c8593a8 Mechanically change INT to FIXNUM in our sources.
Aidan Kehoe <kehoea@parhasard.net>
parents: 5402
diff changeset
97 va_run_hook_with_args (Qdelete_dialog_box_hook, 1, make_fixnum (id));
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
98 lw_destroy_all_widgets (id);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
99
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
100 /* The Motif dialog box sets the keyboard focus to itself. When it
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
101 goes away we have to take care of getting the focus back
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
102 ourselves. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
103 #ifdef EXTERNAL_WIDGET
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
104 /* #### Not sure if this special case is necessary. */
3466
4d52aea479a2 [xemacs-hg @ 2006-06-21 17:30:33 by james]
james
parents: 2286
diff changeset
105 if (f && !FRAME_X_EXTERNAL_WINDOW_P (f))
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
106 #else
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
107 if (f)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
108 #endif
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
109 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
110 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
111
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
112 static const Extbyte * const button_names [] = {
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
113 "button1", "button2", "button3", "button4", "button5",
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
114 "button6", "button7", "button8", "button9", "button10" };
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
115
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
116 static widget_value *
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
117 dbox_descriptor_to_widget_value (Lisp_Object keys)
428
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 /* This function can GC */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
120 int lbuttons = 0, rbuttons = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
121 int partition_seen = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
122 int text_field_p = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
123 int allow_text_p = 1;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
124 widget_value *prev = 0, *kids = 0;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
125 int n = 0;
853
2b6fa2618f76 [xemacs-hg @ 2002-05-28 08:44:22 by ben]
ben
parents: 826
diff changeset
126 int count;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
127 Lisp_Object wv_closure, gui_item;
444
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
128 Lisp_Object question = Qnil;
576fb035e263 Import from CVS: tag r21-2-37
cvs
parents: 442
diff changeset
129 Lisp_Object buttons = Qnil;
2286
04bc9d2f42c7 [xemacs-hg @ 2004-09-20 19:18:55 by james]
james
parents: 1726
diff changeset
130 /* Lisp_Object title = Qnil; #### currently unused */
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
131
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
132 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
133 EXTERNAL_PROPERTY_LIST_LOOP_3 (key, value, keys)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
134 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
135 if (EQ (key, Q_question))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
136 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
137 CHECK_STRING (value);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
138 question = value;
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 else if (EQ (key, Q_title))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
141 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
142 CHECK_STRING (value);
2286
04bc9d2f42c7 [xemacs-hg @ 2004-09-20 19:18:55 by james]
james
parents: 1726
diff changeset
143 /* title = value; */
442
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 else if (EQ (key, Q_buttons))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
146 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
147 CHECK_LIST (value);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
148 buttons = value;
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 else
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
151 invalid_constant ("Unrecognized question-dialog keyword", key);
442
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 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
154
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
155 if (NILP (question))
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
156 sferror ("Dialog descriptor provides no question", keys);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
157
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
158 /* Inhibit GC during this conversion. The reasons for this are
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
159 the same as in menu_item_descriptor_to_widget_value(); see
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
160 the large comment above that function. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
161
853
2b6fa2618f76 [xemacs-hg @ 2002-05-28 08:44:22 by ben]
ben
parents: 826
diff changeset
162 count = begin_gc_forbidden ();
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
163
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
164 kids = prev = xmalloc_widget_value ();
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
165
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
166 /* Also make sure that we free the partially-created widget_value
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
167 tree on Lisp error. */
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 wv_closure = make_opaque_ptr (kids);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
170 record_unwind_protect (widget_value_unwind, wv_closure);
436
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
171 prev->name = xstrdup ("message");
4981
4aebb0131297 Cleanups/renaming of EXTERNAL_TO_C_STRING and friends
Ben Wing <ben@xemacs.org>
parents: 4953
diff changeset
172 prev->value = LISP_STRING_TO_EXTERNAL_MALLOC (question, Qlwlib_encoding);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
173 prev->enabled = 1;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
174
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
175 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
176 EXTERNAL_LIST_LOOP_2 (button, buttons)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
177 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
178 widget_value *wv;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
179
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
180 if (NILP (button))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
181 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
182 if (partition_seen)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
183 sferror ("More than one partition (nil) seen in dbox spec",
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
184 keys);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
185 partition_seen = 1;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
186 continue;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
187 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
188 CHECK_VECTOR (button);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
189 wv = xmalloc_widget_value ();
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
190
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
191 gui_item = gui_parse_item_keywords (button);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
192 if (!button_item_to_widget_value (Qdialog,
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
193 gui_item, wv, allow_text_p, 1, 0, 1))
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
194 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
195 free_widget_value_tree (wv);
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
196 continue;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
197 }
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
198
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
199 if (wv->type == TEXT_TYPE)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
200 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
201 text_field_p = 1;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
202 allow_text_p = 0; /* only allow one */
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 else /* it's a button */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
205 {
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
206 allow_text_p = 0; /* only allow text field at the front */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
207 if (wv->value)
4976
16112448d484 Rename xfree(FOO, TYPE) -> xfree(FOO)
Ben Wing <ben@xemacs.org>
parents: 4953
diff changeset
208 xfree (wv->value);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
209 wv->value = wv->name; /* what a mess... */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
210 wv->name = xstrdup (button_names [n]);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
211
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
212 if (partition_seen)
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
213 rbuttons++;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
214 else
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
215 lbuttons++;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
216 n++;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
217
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
218 if (lbuttons > 9 || rbuttons > 9)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
219 sferror ("Too many buttons (9)",
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
220 keys); /* #### this leaks */
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
221 }
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
222
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
223 prev->next = wv;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
224 prev = wv;
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
225 }
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
226 }
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
227
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
228 if (n == 0)
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
229 sferror ("Dialog boxes must have some buttons", keys);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
230
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
231 {
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
232 Extbyte type = (text_field_p ? 'P' : 'Q');
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
233 static Extbyte tmp_dbox_name [255];
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
234
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
235 widget_value *dbox;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
236 sprintf (tmp_dbox_name, "%c%dBR%d", type, lbuttons + rbuttons, rbuttons);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
237 dbox = xmalloc_widget_value ();
436
080151679be2 Import from CVS: tag r21-2-26
cvs
parents: 428
diff changeset
238 dbox->name = xstrdup (tmp_dbox_name);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
239 dbox->contents = kids;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
240
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
241 /* No more need to free the half-filled-in structures. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
242 set_opaque_ptr (wv_closure, 0);
771
943eaba38521 [xemacs-hg @ 2002-03-13 08:51:24 by ben]
ben
parents: 563
diff changeset
243 unbind_to (count);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
244 return dbox;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
245 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
246 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
247
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
248 static Lisp_Object
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
249 x_make_dialog_box_internal (struct frame* f, Lisp_Object type,
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
250 Lisp_Object keys)
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
251 {
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
252 int dbox_id;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
253 widget_value *data;
2286
04bc9d2f42c7 [xemacs-hg @ 2004-09-20 19:18:55 by james]
james
parents: 1726
diff changeset
254 Widget parent;
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
255
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
256 if (!EQ (type, Qquestion))
563
183866b06e0b [xemacs-hg @ 2001-05-24 07:50:48 by ben]
ben
parents: 444
diff changeset
257 signal_error (Qunimplemented, "Dialog box type", type);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
258
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
259 data = dbox_descriptor_to_widget_value (keys);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
260
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
261 parent = FRAME_X_SHELL_WIDGET (f);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
262
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
263 dbox_id = new_lwlib_id ();
2286
04bc9d2f42c7 [xemacs-hg @ 2004-09-20 19:18:55 by james]
james
parents: 1726
diff changeset
264 (void) lw_create_widget (data->name, "dialog", dbox_id, data, parent, 1, 0,
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
265 dbox_selection_callback, 0);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
266 lw_modify_all_widgets (dbox_id, data, True);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
267 lw_modify_all_widgets (dbox_id, data->contents, True);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
268 free_popup_widget_value_tree (data);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
269
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
270 gcpro_popup_callbacks (dbox_id);
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
271
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
272 /* Setting zmacs-region-stays is necessary here because executing a
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
273 command from a dialog is really a two-command process: the first
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
274 command (bound to the button-click) simply pops up the dialog,
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
275 and returns. This causes a sequence of magic-events (destined
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
276 for the dialog widget) to begin. Eventually, a dialog item is
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
277 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
278 the input stream, which is then executed by the event loop.
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
279
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
280 So there are two command-events, with a bunch of magic-events
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
281 between them. We don't want the *first* command event to alter
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
282 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
283 an argument for the second command. */
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
284 if (zmacs_regions)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
285 zmacs_region_stays = 1;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
286
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
287 popup_up_p++;
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
288 lw_pop_up_all_widgets (dbox_id);
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
289
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
290 /* #### this could (theoretically) cause problems if we are up for
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
291 a REALLY REALLY long time -- too big to fit into lisp integer. */
5581
56144c8593a8 Mechanically change INT to FIXNUM in our sources.
Aidan Kehoe <kehoea@parhasard.net>
parents: 5402
diff changeset
292 return make_fixnum (dbox_id);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
293 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
294
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
295 void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
296 syms_of_dialog_x (void)
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 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
299
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
300 void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
301 console_type_create_dialog_x (void)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
302 {
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 436
diff changeset
303 CONSOLE_HAS_METHOD (x, make_dialog_box_internal);
428
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
304 }
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
305
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
306 void
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
307 vars_of_dialog_x (void)
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 #if defined (LWLIB_DIALOGS_LUCID)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
310 Fprovide (intern ("lucid-dialogs"));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
311 #elif defined (LWLIB_DIALOGS_MOTIF)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
312 Fprovide (intern ("motif-dialogs"));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
313 #elif defined (LWLIB_DIALOGS_ATHENA)
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
314 Fprovide (intern ("athena-dialogs"));
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
315 #endif
3ecd8885ac67 Import from CVS: tag r21-2-22
cvs
parents:
diff changeset
316 }