Mercurial > emacs
annotate lwlib/lwlib.c @ 26601:e23e3120d84f
(set_lface_from_font_name): Fix previous change.
(recompute_basic_faces): Change assert to abort.
author | Gerd Moellmann <gerd@gnu.org> |
---|---|
date | Fri, 26 Nov 1999 10:14:39 +0000 |
parents | e0d966fb548f |
children | 314e947f85ea |
rev | line source |
---|---|
5626 | 1 /* A general interface to the widgets of different toolkits. |
2 Copyright (C) 1992, 1993 Lucid, Inc. | |
3 | |
4 This file is part of the Lucid Widget Library. | |
5 | |
6 The Lucid Widget Library is free software; you can redistribute it and/or | |
7 modify it under the terms of the GNU General Public License as published by | |
8 the Free Software Foundation; either version 2, or (at your option) | |
9 any later version. | |
10 | |
11 The Lucid Widget Library is distributed in the hope that it will be useful, | |
12 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 GNU General Public License for more details. | |
15 | |
16 You should have received a copy of the GNU General Public License | |
17 along with GNU Emacs; see the file COPYING. If not, write to | |
14186
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
14163
diff
changeset
|
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
14163
diff
changeset
|
19 Boston, MA 02111-1307, USA. */ |
5626 | 20 |
21 #ifdef NeXT | |
22 #undef __STRICT_BSD__ /* ick */ | |
23 #endif | |
24 | |
26087
e0d966fb548f
Add support for large files, plus some locale improvements.
Paul Eggert <eggert@twinsun.com>
parents:
25718
diff
changeset
|
25 #ifdef HAVE_CONFIG_H |
e0d966fb548f
Add support for large files, plus some locale improvements.
Paul Eggert <eggert@twinsun.com>
parents:
25718
diff
changeset
|
26 #include <config.h> |
e0d966fb548f
Add support for large files, plus some locale improvements.
Paul Eggert <eggert@twinsun.com>
parents:
25718
diff
changeset
|
27 #endif |
e0d966fb548f
Add support for large files, plus some locale improvements.
Paul Eggert <eggert@twinsun.com>
parents:
25718
diff
changeset
|
28 |
5626 | 29 #include <sys/types.h> |
30 #include <stdio.h> | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
31 #include <ctype.h> |
5627
7ff2d6076466
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5626
diff
changeset
|
32 #include "lwlib-int.h" |
5626 | 33 #include "lwlib-utils.h" |
5706
75570af32e92
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5627
diff
changeset
|
34 #include <X11/StringDefs.h> |
5626 | 35 |
11676
d67c2cc998d4
[__osf__]: Include string.h and stdlib.h.
Richard M. Stallman <rms@gnu.org>
parents:
9929
diff
changeset
|
36 extern long *xmalloc(); |
d67c2cc998d4
[__osf__]: Include string.h and stdlib.h.
Richard M. Stallman <rms@gnu.org>
parents:
9929
diff
changeset
|
37 |
5626 | 38 #if defined (USE_LUCID) |
39 #include "lwlib-Xlw.h" | |
40 #endif | |
41 #if defined (USE_MOTIF) | |
42 #include "lwlib-Xm.h" | |
6306
19fc40b33f52
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
6305
diff
changeset
|
43 #else /* not USE_MOTIF */ |
19fc40b33f52
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
6305
diff
changeset
|
44 #if defined (USE_LUCID) |
19fc40b33f52
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
6305
diff
changeset
|
45 #define USE_XAW |
19fc40b33f52
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
6305
diff
changeset
|
46 #endif /* not USE_MOTIF && USE_LUCID */ |
5626 | 47 #endif |
48 #if defined (USE_OLIT) | |
49 #include "lwlib-Xol.h" | |
50 #endif | |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
51 #if defined (USE_XAW) |
21391 | 52 #include <X11/Xaw/Paned.h> |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
53 #include "lwlib-Xaw.h" |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
54 #endif |
5626 | 55 |
56 #if !defined (USE_LUCID) && !defined (USE_MOTIF) && !defined (USE_OLIT) | |
57 ERROR! At least one of USE_LUCID, USE_MOTIF or USE_OLIT must be defined. | |
58 #endif | |
59 | |
60 #if defined (USE_MOTIF) && defined (USE_OLIT) | |
61 ERROR! no more than one of USE_MOTIF and USE_OLIT may be defined. | |
62 #endif | |
63 | |
8785 | 64 #ifndef max |
65 #define max(x, y) ((x) > (y) ? (x) : (y)) | |
66 #endif | |
67 | |
5626 | 68 /* List of all widgets managed by the library. */ |
69 static widget_info* | |
70 all_widget_info = NULL; | |
71 | |
12187
18d061c3d0dd
(lwlib_toolkit_type): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
11861
diff
changeset
|
72 #ifdef USE_MOTIF |
18d061c3d0dd
(lwlib_toolkit_type): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
11861
diff
changeset
|
73 char *lwlib_toolkit_type = "motif"; |
18d061c3d0dd
(lwlib_toolkit_type): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
11861
diff
changeset
|
74 #else |
18d061c3d0dd
(lwlib_toolkit_type): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
11861
diff
changeset
|
75 char *lwlib_toolkit_type = "lucid"; |
18d061c3d0dd
(lwlib_toolkit_type): New variable.
Karl Heuer <kwzh@gnu.org>
parents:
11861
diff
changeset
|
76 #endif |
5626 | 77 /* Forward declarations */ |
78 static void | |
14163
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
79 instantiate_widget_instance (/* widget_instance* instance */); |
5626 | 80 |
21391 | 81 void |
7515
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
82 lwlib_memset (address, value, length) |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
83 char *address; |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
84 int value; |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
85 int length; |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
86 { |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
87 int i; |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
88 |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
89 for (i = 0; i < length; i++) |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
90 address[i] = value; |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
91 } |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
92 |
21391 | 93 void |
7515
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
94 lwlib_bcopy (from, to, length) |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
95 char *from; |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
96 char *to; |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
97 int length; |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
98 { |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
99 int i; |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
100 |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
101 for (i = 0; i < length; i++) |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
102 to[i] = from[i]; |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
103 } |
5626 | 104 /* utility functions for widget_instance and widget_info */ |
7423
4a5d0d109242
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6333
diff
changeset
|
105 char * |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
106 safe_strdup (s) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
107 char *s; |
5626 | 108 { |
109 char *result; | |
110 if (! s) return 0; | |
111 result = (char *) malloc (strlen (s) + 1); | |
112 if (! result) | |
113 return 0; | |
114 strcpy (result, s); | |
115 return result; | |
116 } | |
117 | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
118 /* Like strcmp but ignore differences in case. */ |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
119 |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
120 static int |
5853 | 121 my_strcasecmp (s1, s2) |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
122 char *s1, *s2; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
123 { |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
124 while (1) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
125 { |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
126 int c1 = *s1++; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
127 int c2 = *s2++; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
128 if (isupper (c1)) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
129 c1 = tolower (c1); |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
130 if (isupper (c2)) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
131 c2 = tolower (c2); |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
132 if (c1 != c2) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
133 return (c1 > c2 ? 1 : -1); |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
134 if (c1 == 0) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
135 return 0; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
136 } |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
137 } |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
138 |
5626 | 139 static void |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
140 safe_free_str (s) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
141 char *s; |
5626 | 142 { |
143 if (s) free (s); | |
144 } | |
145 | |
146 static widget_value *widget_value_free_list = 0; | |
5993
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
147 static int malloc_cpt = 0; |
5626 | 148 |
149 widget_value * | |
150 malloc_widget_value () | |
151 { | |
152 widget_value *wv; | |
153 if (widget_value_free_list) | |
154 { | |
155 wv = widget_value_free_list; | |
156 widget_value_free_list = wv->free_list; | |
157 wv->free_list = 0; | |
158 } | |
159 else | |
160 { | |
161 wv = (widget_value *) malloc (sizeof (widget_value)); | |
5993
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
162 malloc_cpt++; |
5626 | 163 } |
7515
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
164 lwlib_memset (wv, 0, sizeof (widget_value)); |
5626 | 165 return wv; |
166 } | |
167 | |
14163
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
168 /* this is analogous to free(). It frees only what was allocated |
5626 | 169 by malloc_widget_value(), and no substructures. |
170 */ | |
171 void | |
172 free_widget_value (wv) | |
173 widget_value *wv; | |
174 { | |
175 if (wv->free_list) | |
176 abort (); | |
5993
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
177 |
5999
b135bb2b4bfe
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5993
diff
changeset
|
178 if (malloc_cpt > 25) |
5993
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
179 { |
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
180 /* When the number of already allocated cells is too big, |
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
181 We free it. */ |
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
182 free (wv); |
5999
b135bb2b4bfe
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5993
diff
changeset
|
183 malloc_cpt--; |
5993
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
184 } |
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
185 else |
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
186 { |
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
187 wv->free_list = widget_value_free_list; |
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
188 widget_value_free_list = wv; |
5feb28cb62c8
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5853
diff
changeset
|
189 } |
5626 | 190 } |
191 | |
192 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
193 free_widget_value_tree (wv) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
194 widget_value *wv; |
5626 | 195 { |
196 if (!wv) | |
197 return; | |
198 | |
199 if (wv->name) free (wv->name); | |
200 if (wv->value) free (wv->value); | |
201 if (wv->key) free (wv->key); | |
202 | |
203 wv->name = wv->value = wv->key = (char *) 0xDEADBEEF; | |
204 | |
205 if (wv->toolkit_data && wv->free_toolkit_data) | |
206 { | |
14611
69fca906f068
(free_widget_value_tree, merge_widget_value):
Karl Heuer <kwzh@gnu.org>
parents:
14594
diff
changeset
|
207 XtFree (wv->toolkit_data); |
5626 | 208 wv->toolkit_data = (void *) 0xDEADBEEF; |
209 } | |
210 | |
211 if (wv->contents && (wv->contents != (widget_value*)1)) | |
212 { | |
213 free_widget_value_tree (wv->contents); | |
214 wv->contents = (widget_value *) 0xDEADBEEF; | |
215 } | |
216 if (wv->next) | |
217 { | |
218 free_widget_value_tree (wv->next); | |
219 wv->next = (widget_value *) 0xDEADBEEF; | |
220 } | |
221 free_widget_value (wv); | |
222 } | |
223 | |
224 static widget_value * | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
225 copy_widget_value_tree (val, change) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
226 widget_value* val; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
227 change_type change; |
5626 | 228 { |
229 widget_value* copy; | |
230 | |
231 if (!val) | |
232 return NULL; | |
233 if (val == (widget_value *) 1) | |
234 return val; | |
235 | |
236 copy = malloc_widget_value (); | |
237 copy->name = safe_strdup (val->name); | |
238 copy->value = safe_strdup (val->value); | |
239 copy->key = safe_strdup (val->key); | |
240 copy->enabled = val->enabled; | |
25036 | 241 copy->button_type = val->button_type; |
5626 | 242 copy->selected = val->selected; |
243 copy->edited = False; | |
244 copy->change = change; | |
14879
70f79ccb9875
(merge_widget_value): Set the this_one_change field.
Richard M. Stallman <rms@gnu.org>
parents:
14663
diff
changeset
|
245 copy->this_one_change = change; |
5626 | 246 copy->contents = copy_widget_value_tree (val->contents, change); |
247 copy->call_data = val->call_data; | |
248 copy->next = copy_widget_value_tree (val->next, change); | |
249 copy->toolkit_data = NULL; | |
250 copy->free_toolkit_data = False; | |
251 return copy; | |
252 } | |
253 | |
254 static widget_info * | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
255 allocate_widget_info (type, name, id, val, pre_activate_cb, selection_cb, post_activate_cb) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
256 char* type; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
257 char* name; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
258 LWLIB_ID id; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
259 widget_value* val; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
260 lw_callback pre_activate_cb; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
261 lw_callback selection_cb; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
262 lw_callback post_activate_cb; |
5626 | 263 { |
264 widget_info* info = (widget_info*)malloc (sizeof (widget_info)); | |
265 info->type = safe_strdup (type); | |
266 info->name = safe_strdup (name); | |
267 info->id = id; | |
268 info->val = copy_widget_value_tree (val, STRUCTURAL_CHANGE); | |
269 info->busy = False; | |
270 info->pre_activate_cb = pre_activate_cb; | |
271 info->selection_cb = selection_cb; | |
272 info->post_activate_cb = post_activate_cb; | |
273 info->instances = NULL; | |
274 | |
275 info->next = all_widget_info; | |
276 all_widget_info = info; | |
277 | |
278 return info; | |
279 } | |
280 | |
281 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
282 free_widget_info (info) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
283 widget_info* info; |
5626 | 284 { |
285 safe_free_str (info->type); | |
286 safe_free_str (info->name); | |
287 free_widget_value_tree (info->val); | |
7515
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
288 lwlib_memset ((void*)info, 0xDEADBEEF, sizeof (widget_info)); |
5626 | 289 free (info); |
290 } | |
291 | |
292 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
293 mark_widget_destroyed (widget, closure, call_data) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
294 Widget widget; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
295 XtPointer closure; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
296 XtPointer call_data; |
5626 | 297 { |
298 widget_instance* instance = (widget_instance*)closure; | |
299 | |
300 /* be very conservative */ | |
301 if (instance->widget == widget) | |
302 instance->widget = NULL; | |
303 } | |
304 | |
305 static widget_instance * | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
306 allocate_widget_instance (info, parent, pop_up_p) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
307 widget_info* info; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
308 Widget parent; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
309 Boolean pop_up_p; |
5626 | 310 { |
311 widget_instance* instance = | |
312 (widget_instance*)malloc (sizeof (widget_instance)); | |
313 instance->parent = parent; | |
314 instance->pop_up_p = pop_up_p; | |
315 instance->info = info; | |
316 instance->next = info->instances; | |
317 info->instances = instance; | |
318 | |
14163
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
319 instantiate_widget_instance (instance); |
5626 | 320 |
321 XtAddCallback (instance->widget, XtNdestroyCallback, | |
322 mark_widget_destroyed, (XtPointer)instance); | |
323 return instance; | |
324 } | |
325 | |
326 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
327 free_widget_instance (instance) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
328 widget_instance* instance; |
5626 | 329 { |
7515
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
330 lwlib_memset ((void*)instance, 0xDEADBEEF, sizeof (widget_instance)); |
5626 | 331 free (instance); |
332 } | |
333 | |
334 static widget_info * | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
335 get_widget_info (id, remove_p) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
336 LWLIB_ID id; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
337 Boolean remove_p; |
5626 | 338 { |
339 widget_info* info; | |
340 widget_info* prev; | |
341 for (prev = NULL, info = all_widget_info; | |
342 info; | |
343 prev = info, info = info->next) | |
344 if (info->id == id) | |
345 { | |
346 if (remove_p) | |
347 { | |
348 if (prev) | |
349 prev->next = info->next; | |
350 else | |
351 all_widget_info = info->next; | |
352 } | |
353 return info; | |
354 } | |
355 return NULL; | |
356 } | |
357 | |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
358 /* Internal function used by the library dependent implementation to get the |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
359 widget_value for a given widget in an instance */ |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
360 widget_info * |
6333
f3fe542e8cd7
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
6306
diff
changeset
|
361 lw_get_widget_info (id) |
f3fe542e8cd7
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
6306
diff
changeset
|
362 LWLIB_ID id; |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
363 { |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
364 return get_widget_info (id, 0); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
365 } |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
366 |
5626 | 367 static widget_instance * |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
368 get_widget_instance (widget, remove_p) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
369 Widget widget; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
370 Boolean remove_p; |
5626 | 371 { |
372 widget_info* info; | |
373 widget_instance* instance; | |
374 widget_instance* prev; | |
375 for (info = all_widget_info; info; info = info->next) | |
376 for (prev = NULL, instance = info->instances; | |
377 instance; | |
378 prev = instance, instance = instance->next) | |
379 if (instance->widget == widget) | |
380 { | |
381 if (remove_p) | |
382 { | |
383 if (prev) | |
384 prev->next = instance->next; | |
385 else | |
386 info->instances = instance->next; | |
387 } | |
388 return instance; | |
389 } | |
390 return (widget_instance *) 0; | |
391 } | |
392 | |
393 static widget_instance* | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
394 find_instance (id, parent, pop_up_p) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
395 LWLIB_ID id; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
396 Widget parent; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
397 Boolean pop_up_p; |
5626 | 398 { |
399 widget_info* info = get_widget_info (id, False); | |
400 widget_instance* instance; | |
401 | |
402 if (info) | |
403 for (instance = info->instances; instance; instance = instance->next) | |
404 if (instance->parent == parent && instance->pop_up_p == pop_up_p) | |
405 return instance; | |
406 | |
407 return NULL; | |
408 } | |
409 | |
410 | |
411 /* utility function for widget_value */ | |
412 static Boolean | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
413 safe_strcmp (s1, s2) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
414 char* s1; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
415 char* s2; |
5626 | 416 { |
417 if (!!s1 ^ !!s2) return True; | |
418 return (s1 && s2) ? strcmp (s1, s2) : s1 ? False : !!s2; | |
419 } | |
420 | |
421 | |
422 #if 0 | |
423 # define EXPLAIN(name, oc, nc, desc, a1, a2) \ | |
424 printf ("Change: \"%s\"\tmax(%s=%d,%s=%d)\t%s %d %d\n", \ | |
425 name, \ | |
426 (oc == NO_CHANGE ? "none" : \ | |
427 (oc == INVISIBLE_CHANGE ? "invisible" : \ | |
428 (oc == VISIBLE_CHANGE ? "visible" : \ | |
429 (oc == STRUCTURAL_CHANGE ? "structural" : "???")))), \ | |
430 oc, \ | |
431 (nc == NO_CHANGE ? "none" : \ | |
432 (nc == INVISIBLE_CHANGE ? "invisible" : \ | |
433 (nc == VISIBLE_CHANGE ? "visible" : \ | |
434 (nc == STRUCTURAL_CHANGE ? "structural" : "???")))), \ | |
435 nc, desc, a1, a2) | |
436 #else | |
437 # define EXPLAIN(name, oc, nc, desc, a1, a2) | |
438 #endif | |
439 | |
440 | |
441 static widget_value * | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
442 merge_widget_value (val1, val2, level) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
443 widget_value* val1; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
444 widget_value* val2; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
445 int level; |
5626 | 446 { |
14879
70f79ccb9875
(merge_widget_value): Set the this_one_change field.
Richard M. Stallman <rms@gnu.org>
parents:
14663
diff
changeset
|
447 change_type change, this_one_change; |
5626 | 448 widget_value* merged_next; |
449 widget_value* merged_contents; | |
450 | |
451 if (!val1) | |
452 { | |
453 if (val2) | |
454 return copy_widget_value_tree (val2, STRUCTURAL_CHANGE); | |
455 else | |
456 return NULL; | |
457 } | |
458 if (!val2) | |
459 { | |
460 free_widget_value_tree (val1); | |
461 return NULL; | |
462 } | |
463 | |
464 change = NO_CHANGE; | |
465 | |
466 if (safe_strcmp (val1->name, val2->name)) | |
467 { | |
468 EXPLAIN (val1->name, change, STRUCTURAL_CHANGE, "name change", | |
469 val1->name, val2->name); | |
470 change = max (change, STRUCTURAL_CHANGE); | |
471 safe_free_str (val1->name); | |
472 val1->name = safe_strdup (val2->name); | |
473 } | |
474 if (safe_strcmp (val1->value, val2->value)) | |
475 { | |
476 EXPLAIN (val1->name, change, VISIBLE_CHANGE, "value change", | |
477 val1->value, val2->value); | |
478 change = max (change, VISIBLE_CHANGE); | |
479 safe_free_str (val1->value); | |
480 val1->value = safe_strdup (val2->value); | |
481 } | |
482 if (safe_strcmp (val1->key, val2->key)) | |
483 { | |
484 EXPLAIN (val1->name, change, VISIBLE_CHANGE, "key change", | |
485 val1->key, val2->key); | |
486 change = max (change, VISIBLE_CHANGE); | |
487 safe_free_str (val1->key); | |
488 val1->key = safe_strdup (val2->key); | |
489 } | |
490 if (val1->enabled != val2->enabled) | |
491 { | |
492 EXPLAIN (val1->name, change, VISIBLE_CHANGE, "enablement change", | |
493 val1->enabled, val2->enabled); | |
494 change = max (change, VISIBLE_CHANGE); | |
495 val1->enabled = val2->enabled; | |
496 } | |
25036 | 497 if (val1->button_type != val2->button_type) |
498 { | |
499 EXPLAIN (val1->name, change, VISIBLE_CHANGE, "button type change", | |
500 val1->button_type, val2->button_type); | |
501 change = max (change, VISIBLE_CHANGE); | |
502 val1->button_type = val2->button_type; | |
503 } | |
5626 | 504 if (val1->selected != val2->selected) |
505 { | |
506 EXPLAIN (val1->name, change, VISIBLE_CHANGE, "selection change", | |
507 val1->selected, val2->selected); | |
508 change = max (change, VISIBLE_CHANGE); | |
509 val1->selected = val2->selected; | |
510 } | |
511 if (val1->call_data != val2->call_data) | |
512 { | |
513 EXPLAIN (val1->name, change, INVISIBLE_CHANGE, "call-data change", | |
514 val1->call_data, val2->call_data); | |
515 change = max (change, INVISIBLE_CHANGE); | |
516 val1->call_data = val2->call_data; | |
517 } | |
518 | |
519 if (level > 0) | |
520 { | |
521 merged_contents = | |
522 merge_widget_value (val1->contents, val2->contents, level - 1); | |
523 | |
524 if (val1->contents && !merged_contents) | |
525 { | |
14163
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
526 /* This used to say INVISIBLE_CHANGE, |
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
527 but it is visible and vitally important when |
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
528 the contents of the menu bar itself are entirely deleted. |
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
529 |
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
530 But maybe it doesn't matter. This fails to fix the bug. */ |
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
531 EXPLAIN (val1->name, change, STRUCTURAL_CHANGE, "(contents gone)", |
5626 | 532 0, 0); |
14163
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
533 change = max (change, STRUCTURAL_CHANGE); |
5626 | 534 } |
535 else if (merged_contents && merged_contents->change != NO_CHANGE) | |
536 { | |
537 EXPLAIN (val1->name, change, INVISIBLE_CHANGE, "(contents change)", | |
538 0, 0); | |
539 change = max (change, INVISIBLE_CHANGE); | |
15854
184808f2a73c
(merge_widget_value): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
15790
diff
changeset
|
540 #if 0 /* This was replaced by the August 9 1996 change in lwlib-Xm.c. */ |
15790
fb5e87397205
(merge_widget_value) [USE_MOTIF]: Pass along the change flag from
Richard M. Stallman <rms@gnu.org>
parents:
15630
diff
changeset
|
541 #ifdef USE_MOTIF |
fb5e87397205
(merge_widget_value) [USE_MOTIF]: Pass along the change flag from
Richard M. Stallman <rms@gnu.org>
parents:
15630
diff
changeset
|
542 change = max (merged_contents->change, change); |
fb5e87397205
(merge_widget_value) [USE_MOTIF]: Pass along the change flag from
Richard M. Stallman <rms@gnu.org>
parents:
15630
diff
changeset
|
543 #endif |
15854
184808f2a73c
(merge_widget_value): Undo previous change.
Richard M. Stallman <rms@gnu.org>
parents:
15790
diff
changeset
|
544 #endif |
5626 | 545 } |
546 | |
547 val1->contents = merged_contents; | |
548 } | |
549 | |
14879
70f79ccb9875
(merge_widget_value): Set the this_one_change field.
Richard M. Stallman <rms@gnu.org>
parents:
14663
diff
changeset
|
550 this_one_change = change; |
70f79ccb9875
(merge_widget_value): Set the this_one_change field.
Richard M. Stallman <rms@gnu.org>
parents:
14663
diff
changeset
|
551 |
5626 | 552 merged_next = merge_widget_value (val1->next, val2->next, level); |
553 | |
554 if (val1->next && !merged_next) | |
555 { | |
556 EXPLAIN (val1->name, change, STRUCTURAL_CHANGE, "(following gone)", | |
557 0, 0); | |
558 change = max (change, STRUCTURAL_CHANGE); | |
559 } | |
560 else if (merged_next) | |
561 { | |
562 if (merged_next->change) | |
563 EXPLAIN (val1->name, change, merged_next->change, "(following change)", | |
564 0, 0); | |
565 change = max (change, merged_next->change); | |
566 } | |
567 | |
568 val1->next = merged_next; | |
569 | |
14879
70f79ccb9875
(merge_widget_value): Set the this_one_change field.
Richard M. Stallman <rms@gnu.org>
parents:
14663
diff
changeset
|
570 val1->this_one_change = this_one_change; |
5626 | 571 val1->change = change; |
572 | |
573 if (change > NO_CHANGE && val1->toolkit_data) | |
574 { | |
575 if (val1->free_toolkit_data) | |
14611
69fca906f068
(free_widget_value_tree, merge_widget_value):
Karl Heuer <kwzh@gnu.org>
parents:
14594
diff
changeset
|
576 XtFree (val1->toolkit_data); |
5626 | 577 val1->toolkit_data = NULL; |
578 } | |
579 | |
580 return val1; | |
581 } | |
582 | |
583 | |
584 /* modifying the widgets */ | |
585 static Widget | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
586 name_to_widget (instance, name) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
587 widget_instance* instance; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
588 char* name; |
5626 | 589 { |
590 Widget widget = NULL; | |
591 | |
592 if (!instance->widget) | |
593 return NULL; | |
594 | |
595 if (!strcmp (XtName (instance->widget), name)) | |
596 widget = instance->widget; | |
597 else | |
598 { | |
599 int length = strlen (name) + 2; | |
7515
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
600 char* real_name = (char *) xmalloc (length); |
5626 | 601 real_name [0] = '*'; |
602 strcpy (real_name + 1, name); | |
603 | |
604 widget = XtNameToWidget (instance->widget, real_name); | |
7515
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
605 |
d31babe815e7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7423
diff
changeset
|
606 free (real_name); |
5626 | 607 } |
608 return widget; | |
609 } | |
610 | |
611 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
612 set_one_value (instance, val, deep_p) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
613 widget_instance* instance; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
614 widget_value* val; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
615 Boolean deep_p; |
5626 | 616 { |
617 Widget widget = name_to_widget (instance, val->name); | |
618 | |
619 if (widget) | |
620 { | |
621 #if defined (USE_LUCID) | |
622 if (lw_lucid_widget_p (instance->widget)) | |
623 xlw_update_one_widget (instance, widget, val, deep_p); | |
624 #endif | |
625 #if defined (USE_MOTIF) | |
626 if (lw_motif_widget_p (instance->widget)) | |
627 xm_update_one_widget (instance, widget, val, deep_p); | |
628 #endif | |
629 #if defined (USE_OLIT) | |
630 if (lw_olit_widget_p (instance->widget)) | |
631 xol_update_one_widget (instance, widget, val, deep_p); | |
632 #endif | |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
633 #if defined (USE_XAW) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
634 if (lw_xaw_widget_p (instance->widget)) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
635 xaw_update_one_widget (instance, widget, val, deep_p); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
636 #endif |
5626 | 637 } |
638 } | |
639 | |
640 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
641 update_one_widget_instance (instance, deep_p) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
642 widget_instance* instance; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
643 Boolean deep_p; |
5626 | 644 { |
645 widget_value *val; | |
646 | |
647 if (!instance->widget) | |
648 /* the widget was destroyed */ | |
649 return; | |
650 | |
651 for (val = instance->info->val; val; val = val->next) | |
652 if (val->change != NO_CHANGE) | |
653 set_one_value (instance, val, deep_p); | |
654 } | |
655 | |
656 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
657 update_all_widget_values (info, deep_p) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
658 widget_info* info; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
659 Boolean deep_p; |
5626 | 660 { |
661 widget_instance* instance; | |
662 widget_value* val; | |
663 | |
664 for (instance = info->instances; instance; instance = instance->next) | |
665 update_one_widget_instance (instance, deep_p); | |
666 | |
667 for (val = info->val; val; val = val->next) | |
668 val->change = NO_CHANGE; | |
669 } | |
670 | |
671 void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
672 lw_modify_all_widgets (id, val, deep_p) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
673 LWLIB_ID id; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
674 widget_value* val; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
675 Boolean deep_p; |
5626 | 676 { |
677 widget_info* info = get_widget_info (id, False); | |
678 widget_value* new_val; | |
679 widget_value* next_new_val; | |
680 widget_value* cur; | |
681 widget_value* prev; | |
682 widget_value* next; | |
683 int found; | |
684 | |
685 if (!info) | |
686 return; | |
687 | |
688 for (new_val = val; new_val; new_val = new_val->next) | |
689 { | |
690 next_new_val = new_val->next; | |
691 new_val->next = NULL; | |
692 found = False; | |
693 for (prev = NULL, cur = info->val; cur; prev = cur, cur = cur->next) | |
694 if (!strcmp (cur->name, new_val->name)) | |
695 { | |
696 found = True; | |
697 next = cur->next; | |
698 cur->next = NULL; | |
699 cur = merge_widget_value (cur, new_val, deep_p ? 1000 : 1); | |
700 if (prev) | |
701 prev->next = cur ? cur : next; | |
702 else | |
703 info->val = cur ? cur : next; | |
704 if (cur) | |
705 cur->next = next; | |
706 break; | |
707 } | |
708 if (!found) | |
709 { | |
710 /* Could not find it, add it */ | |
711 if (prev) | |
712 prev->next = copy_widget_value_tree (new_val, STRUCTURAL_CHANGE); | |
713 else | |
714 info->val = copy_widget_value_tree (new_val, STRUCTURAL_CHANGE); | |
715 } | |
716 new_val->next = next_new_val; | |
717 } | |
718 | |
719 update_all_widget_values (info, deep_p); | |
720 } | |
721 | |
722 | |
723 /* creating the widgets */ | |
724 | |
725 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
726 initialize_widget_instance (instance) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
727 widget_instance* instance; |
5626 | 728 { |
729 widget_value* val; | |
730 | |
731 for (val = instance->info->val; val; val = val->next) | |
732 val->change = STRUCTURAL_CHANGE; | |
733 | |
734 update_one_widget_instance (instance, True); | |
735 | |
736 for (val = instance->info->val; val; val = val->next) | |
737 val->change = NO_CHANGE; | |
738 } | |
739 | |
740 | |
741 static widget_creation_function | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
742 find_in_table (type, table) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
743 char* type; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
744 widget_creation_entry* table; |
5626 | 745 { |
746 widget_creation_entry* cur; | |
747 for (cur = table; cur->type; cur++) | |
5853 | 748 if (!my_strcasecmp (type, cur->type)) |
5626 | 749 return cur->function; |
750 return NULL; | |
751 } | |
752 | |
753 static Boolean | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
754 dialog_spec_p (name) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
755 char* name; |
5626 | 756 { |
757 /* return True if name matches [EILPQeilpq][1-9][Bb] or | |
758 [EILPQeilpq][1-9][Bb][Rr][1-9] */ | |
759 if (!name) | |
760 return False; | |
761 | |
762 switch (name [0]) | |
763 { | |
764 case 'E': case 'I': case 'L': case 'P': case 'Q': | |
765 case 'e': case 'i': case 'l': case 'p': case 'q': | |
766 if (name [1] >= '0' && name [1] <= '9') | |
767 { | |
768 if (name [2] != 'B' && name [2] != 'b') | |
769 return False; | |
770 if (!name [3]) | |
771 return True; | |
772 if ((name [3] == 'T' || name [3] == 't') && !name [4]) | |
773 return True; | |
774 if ((name [3] == 'R' || name [3] == 'r') | |
775 && name [4] >= '0' && name [4] <= '9' && !name [5]) | |
776 return True; | |
777 return False; | |
778 } | |
779 else | |
780 return False; | |
781 | |
782 default: | |
783 return False; | |
784 } | |
785 } | |
786 | |
787 static void | |
14163
2422ceecd9d2
(instantiate_widget_instance): Renamed from
Richard M. Stallman <rms@gnu.org>
parents:
12744
diff
changeset
|
788 instantiate_widget_instance (instance) |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
789 widget_instance* instance; |
5626 | 790 { |
791 widget_creation_function function = NULL; | |
792 | |
793 #if defined (USE_LUCID) | |
794 if (!function) | |
795 function = find_in_table (instance->info->type, xlw_creation_table); | |
796 #endif | |
797 #if defined(USE_MOTIF) | |
798 if (!function) | |
799 function = find_in_table (instance->info->type, xm_creation_table); | |
800 #endif | |
801 #if defined (USE_OLIT) | |
802 if (!function) | |
803 function = find_in_table (instance->info->type, xol_creation_table); | |
804 #endif | |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
805 #if defined (USE_XAW) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
806 if (!function) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
807 function = find_in_table (instance->info->type, xaw_creation_table); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
808 #endif |
5626 | 809 |
810 if (!function) | |
811 { | |
812 if (dialog_spec_p (instance->info->type)) | |
813 { | |
814 #if defined (USE_LUCID) | |
815 /* not yet */ | |
816 #endif | |
817 #if defined(USE_MOTIF) | |
818 if (!function) | |
819 function = xm_create_dialog; | |
820 #endif | |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
821 #if defined (USE_XAW) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
822 if (!function) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
823 function = xaw_create_dialog; |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
824 #endif |
5626 | 825 #if defined (USE_OLIT) |
826 /* not yet */ | |
827 #endif | |
828 } | |
829 } | |
830 | |
831 if (!function) | |
832 { | |
833 printf ("No creation function for widget type %s\n", | |
834 instance->info->type); | |
835 abort (); | |
836 } | |
837 | |
838 instance->widget = (*function) (instance); | |
839 | |
840 if (!instance->widget) | |
841 abort (); | |
842 | |
843 /* XtRealizeWidget (instance->widget);*/ | |
844 } | |
845 | |
846 void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
847 lw_register_widget (type, name, id, val, pre_activate_cb, selection_cb, post_activate_cb) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
848 char* type; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
849 char* name; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
850 LWLIB_ID id; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
851 widget_value* val; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
852 lw_callback pre_activate_cb; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
853 lw_callback selection_cb; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
854 lw_callback post_activate_cb; |
5626 | 855 { |
856 if (!get_widget_info (id, False)) | |
857 allocate_widget_info (type, name, id, val, pre_activate_cb, selection_cb, | |
858 post_activate_cb); | |
859 } | |
860 | |
861 Widget | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
862 lw_get_widget (id, parent, pop_up_p) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
863 LWLIB_ID id; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
864 Widget parent; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
865 Boolean pop_up_p; |
5626 | 866 { |
867 widget_instance* instance; | |
868 | |
869 instance = find_instance (id, parent, pop_up_p); | |
870 return instance ? instance->widget : NULL; | |
871 } | |
872 | |
873 Widget | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
874 lw_make_widget (id, parent, pop_up_p) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
875 LWLIB_ID id; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
876 Widget parent; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
877 Boolean pop_up_p; |
5626 | 878 { |
879 widget_instance* instance; | |
880 widget_info* info; | |
881 | |
882 instance = find_instance (id, parent, pop_up_p); | |
883 if (!instance) | |
884 { | |
885 info = get_widget_info (id, False); | |
886 if (!info) | |
887 return NULL; | |
888 instance = allocate_widget_instance (info, parent, pop_up_p); | |
889 initialize_widget_instance (instance); | |
890 } | |
891 if (!instance->widget) | |
892 abort (); | |
893 return instance->widget; | |
894 } | |
895 | |
896 Widget | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
897 lw_create_widget (type, name, id, val, parent, pop_up_p, pre_activate_cb, selection_cb, post_activate_cb) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
898 char* type; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
899 char* name; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
900 LWLIB_ID id; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
901 widget_value* val; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
902 Widget parent; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
903 Boolean pop_up_p; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
904 lw_callback pre_activate_cb; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
905 lw_callback selection_cb; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
906 lw_callback post_activate_cb; |
5626 | 907 { |
908 lw_register_widget (type, name, id, val, pre_activate_cb, selection_cb, | |
909 post_activate_cb); | |
910 return lw_make_widget (id, parent, pop_up_p); | |
911 } | |
912 | |
913 | |
914 /* destroying the widgets */ | |
915 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
916 destroy_one_instance (instance) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
917 widget_instance* instance; |
5626 | 918 { |
919 /* Remove the destroy callback on the widget; that callback will try to | |
920 dereference the instance object (to set its widget slot to 0, since the | |
921 widget is dead.) Since the instance is now dead, we don't have to worry | |
922 about the fact that its widget is dead too. | |
923 | |
924 This happens in the Phase2Destroy of the widget, so this callback would | |
925 not have been run until arbitrarily long after the instance was freed. | |
926 */ | |
927 if (instance->widget) | |
928 XtRemoveCallback (instance->widget, XtNdestroyCallback, | |
929 mark_widget_destroyed, (XtPointer)instance); | |
930 | |
931 if (instance->widget) | |
932 { | |
933 /* The else are pretty tricky here, including the empty statement | |
934 at the end because it would be very bad to destroy a widget | |
935 twice. */ | |
936 #if defined (USE_LUCID) | |
937 if (lw_lucid_widget_p (instance->widget)) | |
938 xlw_destroy_instance (instance); | |
939 else | |
940 #endif | |
941 #if defined (USE_MOTIF) | |
942 if (lw_motif_widget_p (instance->widget)) | |
943 xm_destroy_instance (instance); | |
944 else | |
945 #endif | |
946 #if defined (USE_OLIT) | |
947 if (lw_olit_widget_p (instance->widget)) | |
948 xol_destroy_instance (instance); | |
949 else | |
950 #endif | |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
951 #if defined (USE_XAW) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
952 if (lw_xaw_widget_p (instance->widget)) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
953 xaw_destroy_instance (instance); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
954 else |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
955 #endif |
5626 | 956 /* do not remove the empty statement */ |
957 ; | |
958 } | |
959 | |
960 free_widget_instance (instance); | |
961 } | |
962 | |
963 void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
964 lw_destroy_widget (w) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
965 Widget w; |
5626 | 966 { |
967 widget_instance* instance = get_widget_instance (w, True); | |
968 | |
969 if (instance) | |
970 { | |
971 widget_info *info = instance->info; | |
972 /* instance has already been removed from the list; free it */ | |
973 destroy_one_instance (instance); | |
974 /* if there are no instances left, free the info too */ | |
975 if (!info->instances) | |
976 lw_destroy_all_widgets (info->id); | |
977 } | |
978 } | |
979 | |
980 void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
981 lw_destroy_all_widgets (id) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
982 LWLIB_ID id; |
5626 | 983 { |
984 widget_info* info = get_widget_info (id, True); | |
985 widget_instance* instance; | |
986 widget_instance* next; | |
987 | |
988 if (info) | |
989 { | |
990 for (instance = info->instances; instance; ) | |
991 { | |
992 next = instance->next; | |
993 destroy_one_instance (instance); | |
994 instance = next; | |
995 } | |
996 free_widget_info (info); | |
997 } | |
998 } | |
999 | |
1000 void | |
1001 lw_destroy_everything () | |
1002 { | |
1003 while (all_widget_info) | |
1004 lw_destroy_all_widgets (all_widget_info->id); | |
1005 } | |
1006 | |
1007 void | |
1008 lw_destroy_all_pop_ups () | |
1009 { | |
1010 widget_info* info; | |
1011 widget_info* next; | |
1012 widget_instance* instance; | |
1013 | |
1014 for (info = all_widget_info; info; info = next) | |
1015 { | |
1016 next = info->next; | |
1017 instance = info->instances; | |
1018 if (instance && instance->pop_up_p) | |
1019 lw_destroy_all_widgets (info->id); | |
1020 } | |
1021 } | |
1022 | |
1023 #ifdef USE_MOTIF | |
11861 | 1024 extern Widget first_child (/* Widget */); /* garbage */ |
5626 | 1025 #endif |
1026 | |
1027 Widget | |
1028 lw_raise_all_pop_up_widgets () | |
1029 { | |
1030 widget_info* info; | |
1031 widget_instance* instance; | |
1032 Widget result = NULL; | |
1033 | |
1034 for (info = all_widget_info; info; info = info->next) | |
1035 for (instance = info->instances; instance; instance = instance->next) | |
1036 if (instance->pop_up_p) | |
1037 { | |
1038 Widget widget = instance->widget; | |
1039 if (widget) | |
1040 { | |
1041 if (XtIsManaged (widget) | |
1042 #ifdef USE_MOTIF | |
1043 /* What a complete load of crap!!!! | |
1044 When a dialogShell is on the screen, it is not managed! | |
1045 */ | |
1046 || (lw_motif_widget_p (instance->widget) && | |
1047 XtIsManaged (first_child (widget))) | |
1048 #endif | |
1049 ) | |
1050 { | |
1051 if (!result) | |
1052 result = widget; | |
1053 XMapRaised (XtDisplay (widget), XtWindow (widget)); | |
1054 } | |
1055 } | |
1056 } | |
1057 return result; | |
1058 } | |
1059 | |
1060 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1061 lw_pop_all_widgets (id, up) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1062 LWLIB_ID id; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1063 Boolean up; |
5626 | 1064 { |
1065 widget_info* info = get_widget_info (id, False); | |
1066 widget_instance* instance; | |
1067 | |
1068 if (info) | |
1069 for (instance = info->instances; instance; instance = instance->next) | |
1070 if (instance->pop_up_p && instance->widget) | |
1071 { | |
1072 #if defined (USE_LUCID) | |
1073 if (lw_lucid_widget_p (instance->widget)) | |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1074 { |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1075 XtRealizeWidget (instance->widget); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1076 xlw_pop_instance (instance, up); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1077 } |
5626 | 1078 #endif |
1079 #if defined (USE_MOTIF) | |
1080 if (lw_motif_widget_p (instance->widget)) | |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1081 { |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1082 XtRealizeWidget (instance->widget); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1083 xm_pop_instance (instance, up); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1084 } |
5626 | 1085 #endif |
1086 #if defined (USE_OLIT) | |
1087 if (lw_olit_widget_p (instance->widget)) | |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1088 { |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1089 XtRealizeWidget (instance->widget); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1090 xol_pop_instance (instance, up); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1091 } |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1092 #endif |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1093 #if defined (USE_XAW) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1094 if (lw_xaw_widget_p (instance->widget)) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1095 { |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1096 XtRealizeWidget (XtParent (instance->widget)); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1097 XtRealizeWidget (instance->widget); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1098 xaw_pop_instance (instance, up); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1099 } |
5626 | 1100 #endif |
1101 } | |
1102 } | |
1103 | |
1104 void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1105 lw_pop_up_all_widgets (id) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1106 LWLIB_ID id; |
5626 | 1107 { |
1108 lw_pop_all_widgets (id, True); | |
1109 } | |
1110 | |
1111 void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1112 lw_pop_down_all_widgets (id) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1113 LWLIB_ID id; |
5626 | 1114 { |
1115 lw_pop_all_widgets (id, False); | |
1116 } | |
1117 | |
1118 void | |
12744
0c5625e91a11
(lw_popup_menu): New arg event, passed along.
Richard M. Stallman <rms@gnu.org>
parents:
12187
diff
changeset
|
1119 lw_popup_menu (widget, event) |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1120 Widget widget; |
12744
0c5625e91a11
(lw_popup_menu): New arg event, passed along.
Richard M. Stallman <rms@gnu.org>
parents:
12187
diff
changeset
|
1121 XEvent *event; |
5626 | 1122 { |
1123 #if defined (USE_LUCID) | |
1124 if (lw_lucid_widget_p (widget)) | |
12744
0c5625e91a11
(lw_popup_menu): New arg event, passed along.
Richard M. Stallman <rms@gnu.org>
parents:
12187
diff
changeset
|
1125 xlw_popup_menu (widget, event); |
5626 | 1126 #endif |
1127 #if defined (USE_MOTIF) | |
1128 if (lw_motif_widget_p (widget)) | |
12744
0c5625e91a11
(lw_popup_menu): New arg event, passed along.
Richard M. Stallman <rms@gnu.org>
parents:
12187
diff
changeset
|
1129 xm_popup_menu (widget, event); |
5626 | 1130 #endif |
1131 #if defined (USE_OLIT) | |
1132 if (lw_olit_widget_p (widget)) | |
12744
0c5625e91a11
(lw_popup_menu): New arg event, passed along.
Richard M. Stallman <rms@gnu.org>
parents:
12187
diff
changeset
|
1133 xol_popup_menu (widget, event); |
5626 | 1134 #endif |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1135 #if defined (USE_XAW) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1136 if (lw_xaw_widget_p (widget)) |
12744
0c5625e91a11
(lw_popup_menu): New arg event, passed along.
Richard M. Stallman <rms@gnu.org>
parents:
12187
diff
changeset
|
1137 xaw_popup_menu (widget, event); |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1138 #endif |
5626 | 1139 } |
1140 | |
1141 /* get the values back */ | |
1142 static Boolean | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1143 get_one_value (instance, val) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1144 widget_instance* instance; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1145 widget_value* val; |
5626 | 1146 { |
1147 Widget widget = name_to_widget (instance, val->name); | |
1148 | |
1149 if (widget) | |
1150 { | |
1151 #if defined (USE_LUCID) | |
1152 if (lw_lucid_widget_p (instance->widget)) | |
1153 xlw_update_one_value (instance, widget, val); | |
1154 #endif | |
1155 #if defined (USE_MOTIF) | |
1156 if (lw_motif_widget_p (instance->widget)) | |
1157 xm_update_one_value (instance, widget, val); | |
1158 #endif | |
1159 #if defined (USE_OLIT) | |
1160 if (lw_olit_widget_p (instance->widget)) | |
1161 xol_update_one_value (instance, widget, val); | |
1162 #endif | |
6305
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1163 #if defined (USE_XAW) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1164 if (lw_xaw_widget_p (instance->widget)) |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1165 xaw_update_one_value (instance, widget, val); |
65beaa9aa1e4
*** empty log message ***
Fred Pierresteguy <F.Pierresteguy@frcl.bull.fr>
parents:
5999
diff
changeset
|
1166 #endif |
5626 | 1167 return True; |
1168 } | |
1169 else | |
1170 return False; | |
1171 } | |
1172 | |
1173 Boolean | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1174 lw_get_some_values (id, val_out) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1175 LWLIB_ID id; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1176 widget_value* val_out; |
5626 | 1177 { |
1178 widget_info* info = get_widget_info (id, False); | |
1179 widget_instance* instance; | |
1180 widget_value* val; | |
1181 Boolean result = False; | |
1182 | |
1183 if (!info) | |
1184 return False; | |
1185 | |
1186 instance = info->instances; | |
1187 if (!instance) | |
1188 return False; | |
1189 | |
1190 for (val = val_out; val; val = val->next) | |
1191 if (get_one_value (instance, val)) | |
1192 result = True; | |
1193 | |
1194 return result; | |
1195 } | |
1196 | |
1197 widget_value* | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1198 lw_get_all_values (id) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1199 LWLIB_ID id; |
5626 | 1200 { |
1201 widget_info* info = get_widget_info (id, False); | |
1202 widget_value* val = info->val; | |
1203 if (lw_get_some_values (id, val)) | |
1204 return val; | |
1205 else | |
1206 return NULL; | |
1207 } | |
1208 | |
1209 /* internal function used by the library dependent implementation to get the | |
1210 widget_value for a given widget in an instance */ | |
1211 widget_value* | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1212 lw_get_widget_value_for_widget (instance, w) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1213 widget_instance* instance; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1214 Widget w; |
5626 | 1215 { |
1216 char* name = XtName (w); | |
1217 widget_value* cur; | |
1218 for (cur = instance->info->val; cur; cur = cur->next) | |
1219 if (!strcmp (cur->name, name)) | |
1220 return cur; | |
1221 return NULL; | |
1222 } | |
1223 | |
1224 /* update other instances value when one thing changed */ | |
14594
37d38d8040a1
(lw_internal_update_other_instances): Move static var
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
1225 |
37d38d8040a1
(lw_internal_update_other_instances): Move static var
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
1226 /* To forbid recursive calls */ |
37d38d8040a1
(lw_internal_update_other_instances): Move static var
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
1227 static Boolean lwlib_updating; |
37d38d8040a1
(lw_internal_update_other_instances): Move static var
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
1228 |
5626 | 1229 /* This function can be used as a an XtCallback for the widgets that get |
1230 modified to update other instances of the widgets. Closure should be the | |
1231 widget_instance. */ | |
1232 void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1233 lw_internal_update_other_instances (widget, closure, call_data) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1234 Widget widget; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1235 XtPointer closure; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1236 XtPointer call_data; |
5626 | 1237 { |
1238 widget_instance* instance = (widget_instance*)closure; | |
1239 char* name = XtName (widget); | |
1240 widget_info* info; | |
1241 widget_instance* cur; | |
1242 widget_value* val; | |
1243 | |
14594
37d38d8040a1
(lw_internal_update_other_instances): Move static var
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
1244 /* Avoid possibly infinite recursion. */ |
37d38d8040a1
(lw_internal_update_other_instances): Move static var
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
1245 if (lwlib_updating) |
5626 | 1246 return; |
1247 | |
1248 /* protect against the widget being destroyed */ | |
1249 if (XtWidgetBeingDestroyedP (widget)) | |
1250 return; | |
1251 | |
1252 /* Return immediately if there are no other instances */ | |
1253 info = instance->info; | |
1254 if (!info->instances->next) | |
1255 return; | |
1256 | |
14594
37d38d8040a1
(lw_internal_update_other_instances): Move static var
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
1257 lwlib_updating = True; |
5626 | 1258 |
1259 for (val = info->val; val && strcmp (val->name, name); val = val->next); | |
1260 | |
1261 if (val && get_one_value (instance, val)) | |
1262 for (cur = info->instances; cur; cur = cur->next) | |
1263 if (cur != instance) | |
1264 set_one_value (cur, val, True); | |
1265 | |
14594
37d38d8040a1
(lw_internal_update_other_instances): Move static var
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
1266 lwlib_updating = False; |
5626 | 1267 } |
1268 | |
1269 | |
1270 /* get the id */ | |
1271 | |
1272 LWLIB_ID | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1273 lw_get_widget_id (w) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1274 Widget w; |
5626 | 1275 { |
1276 widget_instance* instance = get_widget_instance (w, False); | |
1277 | |
1278 return instance ? instance->info->id : 0; | |
1279 } | |
1280 | |
1281 /* set the keyboard focus */ | |
1282 void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1283 lw_set_keyboard_focus (parent, w) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1284 Widget parent; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1285 Widget w; |
5626 | 1286 { |
1287 #if defined (USE_MOTIF) | |
1288 xm_set_keyboard_focus (parent, w); | |
1289 #else | |
1290 XtSetKeyboardFocus (parent, w); | |
1291 #endif | |
1292 } | |
1293 | |
1294 /* Show busy */ | |
1295 static void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1296 show_one_widget_busy (w, flag) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1297 Widget w; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1298 Boolean flag; |
5626 | 1299 { |
1300 Pixel foreground = 0; | |
1301 Pixel background = 1; | |
1302 Widget widget_to_invert = XtNameToWidget (w, "*sheet"); | |
1303 if (!widget_to_invert) | |
1304 widget_to_invert = w; | |
1305 | |
1306 XtVaGetValues (widget_to_invert, | |
1307 XtNforeground, &foreground, | |
1308 XtNbackground, &background, | |
1309 0); | |
1310 XtVaSetValues (widget_to_invert, | |
1311 XtNforeground, background, | |
1312 XtNbackground, foreground, | |
1313 0); | |
1314 } | |
1315 | |
1316 void | |
5724
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1317 lw_show_busy (w, busy) |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1318 Widget w; |
02a4aeb69cae
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
5706
diff
changeset
|
1319 Boolean busy; |
5626 | 1320 { |
1321 widget_instance* instance = get_widget_instance (w, False); | |
1322 widget_info* info; | |
1323 widget_instance* next; | |
1324 | |
1325 if (instance) | |
1326 { | |
1327 info = instance->info; | |
1328 if (info->busy != busy) | |
1329 { | |
1330 for (next = info->instances; next; next = next->next) | |
1331 if (next->widget) | |
1332 show_one_widget_busy (next->widget, busy); | |
1333 info->busy = busy; | |
1334 } | |
1335 } | |
1336 } | |
8785 | 1337 |
1338 /* This hack exists because Lucid/Athena need to execute the strange | |
1339 function below to support geometry management. */ | |
1340 void | |
1341 lw_refigure_widget (w, doit) | |
1342 Widget w; | |
1343 Boolean doit; | |
1344 { | |
9929
72dc1c5b3939
(lw_refigure_widget): Use the macro USE_XAW rather than XAW.
Paul Reilly <pmr@pajato.com>
parents:
9226
diff
changeset
|
1345 #if defined (USE_XAW) |
8785 | 1346 XawPanedSetRefigureMode (w, doit); |
1347 #endif | |
1348 #if defined (USE_MOTIF) | |
1349 if (doit) | |
11714
b62d02709ec7
(lw_refigure_widget) [USE_MOTIF]: Fix backward if.
Richard M. Stallman <rms@gnu.org>
parents:
11676
diff
changeset
|
1350 XtManageChild (w); |
8785 | 1351 else |
11714
b62d02709ec7
(lw_refigure_widget) [USE_MOTIF]: Fix backward if.
Richard M. Stallman <rms@gnu.org>
parents:
11676
diff
changeset
|
1352 XtUnmanageChild (w); |
8785 | 1353 #endif |
1354 } | |
1355 | |
1356 /* Toolkit independent way of determining if an event window is in the | |
1357 menubar. */ | |
1358 Boolean | |
1359 lw_window_is_in_menubar (win, menubar_widget) | |
1360 Window win; | |
1361 Widget menubar_widget; | |
1362 { | |
1363 return menubar_widget | |
1364 #if defined (USE_LUCID) | |
1365 && XtWindow (menubar_widget) == win; | |
1366 #endif | |
1367 #if defined (USE_MOTIF) | |
14663
d9cafe0ebb7d
(lw_window_is_in_menubar) [USE_MOTIF]:
Richard M. Stallman <rms@gnu.org>
parents:
14611
diff
changeset
|
1368 && ((XtWindow (menubar_widget) == win) |
d9cafe0ebb7d
(lw_window_is_in_menubar) [USE_MOTIF]:
Richard M. Stallman <rms@gnu.org>
parents:
14611
diff
changeset
|
1369 || (XtWindowToWidget (XtDisplay (menubar_widget), win) |
d9cafe0ebb7d
(lw_window_is_in_menubar) [USE_MOTIF]:
Richard M. Stallman <rms@gnu.org>
parents:
14611
diff
changeset
|
1370 && (XtParent (XtWindowToWidget (XtDisplay (menubar_widget), win)) |
d9cafe0ebb7d
(lw_window_is_in_menubar) [USE_MOTIF]:
Richard M. Stallman <rms@gnu.org>
parents:
14611
diff
changeset
|
1371 == menubar_widget))); |
8785 | 1372 #endif |
1373 } | |
1374 | |
1375 /* Motif hack to set the main window areas. */ | |
1376 void | |
1377 lw_set_main_areas (parent, menubar, work_area) | |
1378 Widget parent; | |
1379 Widget menubar; | |
1380 Widget work_area; | |
1381 { | |
1382 #if defined (USE_MOTIF) | |
9093
f8546f467db6
(lw_set_main_areas): Move call to XmMainSetAreas() to `lwlib-Xm.c'.
Paul Reilly <pmr@pajato.com>
parents:
8785
diff
changeset
|
1383 xm_set_main_areas (parent, menubar, work_area); |
8785 | 1384 #endif |
1385 } | |
1386 | |
1387 /* Manage resizing for Motif. This disables resizing when the menubar | |
1388 is about to be modified. */ | |
1389 void | |
1390 lw_allow_resizing (w, flag) | |
1391 Widget w; | |
1392 Boolean flag; | |
1393 { | |
1394 #if defined (USE_MOTIF) | |
9226
fc3f748ccf9e
(lw_set_main_areas): Use xm_set_main_areas().
Paul Reilly <pmr@pajato.com>
parents:
9093
diff
changeset
|
1395 xm_manage_resizing (w, flag); |
8785 | 1396 #endif |
1397 } | |
25036 | 1398 |
1399 | |
1400 /* Value is non-zero if LABEL is a menu separator. If it is, *TYPE is | |
1401 set to an appropriate enumerator of type enum menu_separator. | |
1402 MOTIF_P non-zero means map separator types not supported by Motif | |
1403 to similar ones that are supported. */ | |
1404 | |
1405 int | |
1406 lw_separator_p (label, type, motif_p) | |
1407 char *label; | |
1408 enum menu_separator *type; | |
1409 int motif_p; | |
1410 { | |
1411 int separator_p; | |
1412 | |
1413 if (strlen (label) >= 3 | |
1414 && bcmp (label, "--:", 3) == 0) | |
1415 { | |
1416 static struct separator_table | |
1417 { | |
1418 char *name; | |
1419 enum menu_separator type; | |
1420 } | |
1421 separator_names[] = | |
1422 { | |
25627
157324e02b30
(lw_separator_p): Add `--:space' with the same
Gerd Moellmann <gerd@gnu.org>
parents:
25562
diff
changeset
|
1423 "space", SEPARATOR_NO_LINE, |
25036 | 1424 "noLine", SEPARATOR_NO_LINE, |
1425 "singleLine", SEPARATOR_SINGLE_LINE, | |
1426 "doubleLine", SEPARATOR_DOUBLE_LINE, | |
1427 "singleDashedLine", SEPARATOR_SINGLE_DASHED_LINE, | |
1428 "doubleDashedLine", SEPARATOR_DOUBLE_DASHED_LINE, | |
1429 "shadowEtchedIn", SEPARATOR_SHADOW_ETCHED_IN, | |
1430 "shadowEtchedOut", SEPARATOR_SHADOW_ETCHED_OUT, | |
1431 "shadowEtchedInDash", SEPARATOR_SHADOW_ETCHED_IN_DASH, | |
1432 "shadowEtchedOutDash", SEPARATOR_SHADOW_ETCHED_OUT_DASH, | |
1433 "shadowDoubleEtchedIn", SEPARATOR_SHADOW_DOUBLE_ETCHED_IN, | |
1434 "shadowDoubleEtchedOut", SEPARATOR_SHADOW_DOUBLE_ETCHED_OUT, | |
1435 "shadowDoubleEtchedInDash", SEPARATOR_SHADOW_DOUBLE_ETCHED_IN_DASH, | |
1436 "shadowDoubleEtchedOutDash", SEPARATOR_SHADOW_DOUBLE_ETCHED_OUT_DASH, | |
1437 0 | |
1438 }; | |
1439 | |
1440 int i; | |
1441 | |
1442 label += 3; | |
1443 for (i = 0; separator_names[i].name; ++i) | |
1444 if (strcmp (label, separator_names[i].name) == 0) | |
1445 { | |
1446 separator_p = 1; | |
1447 *type = separator_names[i].type; | |
1448 | |
1449 /* If separator type is not supported under Motif, | |
1450 use a similar one. */ | |
1451 if (motif_p && *type >= SEPARATOR_SHADOW_DOUBLE_ETCHED_IN) | |
1452 *type -= 4; | |
1453 break; | |
1454 } | |
1455 } | |
25562
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1456 else if (strlen (label) > 3 |
25718
096f3085e905
(lw_separator_p): Check for new-style separators
Gerd Moellmann <gerd@gnu.org>
parents:
25627
diff
changeset
|
1457 && bcmp (label, "--", 2) == 0 |
096f3085e905
(lw_separator_p): Check for new-style separators
Gerd Moellmann <gerd@gnu.org>
parents:
25627
diff
changeset
|
1458 && label[2] != '-') |
25562
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1459 { |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1460 /* Alternative, more Emacs-style names. */ |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1461 static struct separator_table |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1462 { |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1463 char *name; |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1464 enum menu_separator type; |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1465 } |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1466 separator_names[] = |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1467 { |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1468 "space", SEPARATOR_NO_LINE, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1469 "no-line", SEPARATOR_NO_LINE, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1470 "single-line", SEPARATOR_SINGLE_LINE, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1471 "double-line", SEPARATOR_DOUBLE_LINE, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1472 "single-dashed-line", SEPARATOR_SINGLE_DASHED_LINE, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1473 "double-dashed-line", SEPARATOR_DOUBLE_DASHED_LINE, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1474 "shadow-etched-in", SEPARATOR_SHADOW_ETCHED_IN, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1475 "shadow-etched-out", SEPARATOR_SHADOW_ETCHED_OUT, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1476 "shadow-etched-in-dash", SEPARATOR_SHADOW_ETCHED_IN_DASH, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1477 "shadow-etched-out-dash", SEPARATOR_SHADOW_ETCHED_OUT_DASH, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1478 "shadow-double-etched-in", SEPARATOR_SHADOW_DOUBLE_ETCHED_IN, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1479 "shadow-double-etched-out", SEPARATOR_SHADOW_DOUBLE_ETCHED_OUT, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1480 "shadow-double-etched-in-dash", SEPARATOR_SHADOW_DOUBLE_ETCHED_IN_DASH, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1481 "shadow-double-etched-out-dash",SEPARATOR_SHADOW_DOUBLE_ETCHED_OUT_DASH, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1482 0 |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1483 }; |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1484 |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1485 int i; |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1486 |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1487 label += 2; |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1488 for (i = 0; separator_names[i].name; ++i) |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1489 if (strcmp (label, separator_names[i].name) == 0) |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1490 { |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1491 separator_p = 1; |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1492 *type = separator_names[i].type; |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1493 |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1494 /* If separator type is not supported under Motif, |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1495 use a similar one. */ |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1496 if (motif_p && *type >= SEPARATOR_SHADOW_DOUBLE_ETCHED_IN) |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1497 *type -= 4; |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1498 break; |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1499 } |
374f4e51615c
(lw_separator_p): Add alternative separator type names.
Gerd Moellmann <gerd@gnu.org>
parents:
25036
diff
changeset
|
1500 } |
25036 | 1501 else |
1502 { | |
1503 /* Old-style separator, maybe. It's a separator if it contains | |
1504 only dashes. */ | |
1505 while (*label == '-') | |
1506 ++label; | |
1507 separator_p = *label == 0; | |
1508 *type = SEPARATOR_SHADOW_ETCHED_IN; | |
1509 } | |
1510 | |
1511 return separator_p; | |
1512 } | |
1513 |