annotate src/device-x.c @ 0:376386a54a3c r19-14

Import from CVS: tag r19-14
author cvs
date Mon, 13 Aug 2007 08:45:50 +0200
parents
children ac2d302a0011
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1 /* Device functions for X windows.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2 Copyright (C) 1994, 1995 Board of Trustees, University of Illinois.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3 Copyright (C) 1994, 1995 Free Software Foundation, Inc.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
4
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
5 This file is part of XEmacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
6
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
7 XEmacs is free software; you can redistribute it and/or modify it
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
8 under the terms of the GNU General Public License as published by the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
9 Free Software Foundation; either version 2, or (at your option) any
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
10 later version.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
11
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
12 XEmacs is distributed in the hope that it will be useful, but WITHOUT
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
15 for more details.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
16
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
18 along with XEmacs; see the file COPYING. If not, write to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
20 Boston, MA 02111-1307, USA. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
21
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
22 /* Synched up with: Not in FSF. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
23
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
24 /* Original authors: Jamie Zawinski and the FSF */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
25 /* Rewritten by Ben Wing and Chuck Thompson. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
26
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
27 #include <config.h>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
28 #include "lisp.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
29
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
30 #include "console-x.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
31 #include "xintrinsicp.h" /* CoreP.h needs this */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
32 #include <X11/CoreP.h> /* Numerous places access the fields of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
33 a core widget directly. We could
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
34 use XtVaGetValues(), but ... */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
35 #include "xgccache.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
36 #include <X11/Shell.h>
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
37 #include "xmu.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
38 #include "glyphs-x.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
39 #include "objects-x.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
40
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
41 #include "buffer.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
42 #include "events.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
43 #include "faces.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
44 #include "frame.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
45 #include "redisplay.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
46 #include "sysdep.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
47 #include "window.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
48
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
49 #include "sysfile.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
50 #include "systime.h"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
51
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
52 Lisp_Object Vdefault_x_device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
53
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
54 /* Qdisplay in general.c */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
55 Lisp_Object Qx_error;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
56 Lisp_Object Qinit_pre_x_win, Qinit_post_x_win;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
57
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
58 /* The application class of Emacs. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
59 Lisp_Object Vx_emacs_application_class;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
60
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
61 Lisp_Object Vx_initial_argv_list; /* #### ugh! */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
62
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
63 static XrmOptionDescRec emacs_options[] =
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
64 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
65 {"-geometry", ".geometry", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
66 {"-iconic", ".iconic", XrmoptionNoArg, (XtPointer) "yes"},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
67
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
68 {"-internal-border-width", "*EmacsFrame.internalBorderWidth", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
69 {"-ib", "*EmacsFrame.internalBorderWidth", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
70 {"-scrollbar-width", "*EmacsFrame.scrollBarWidth", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
71 {"-scrollbar-height", "*EmacsFrame.scrollBarHeight", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
72
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
73 /* #### Beware! If the type of the shell changes, update this. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
74 {"-T", "*TopLevelEmacsShell.title", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
75 {"-wn", "*TopLevelEmacsShell.title", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
76 {"-title", "*TopLevelEmacsShell.title", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
77 {"-iconname", "*TopLevelEmacsShell.iconName", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
78 {"-in", "*TopLevelEmacsShell.iconName", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
79 {"-mc", "*pointerColor", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
80 {"-cr", "*cursorColor", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
81 {"-fontset", "*FontSet", XrmoptionSepArg, NULL},
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
82 };
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
83
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
84 static void validify_resource_string (char *str);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
85
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
86 /* Functions to synchronize mirroring resources and specifiers */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
87 int in_resource_setting;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
88 int in_specifier_change_function;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
89
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
90
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
91 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
92 /* helper functions */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
93 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
94
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
95 struct device *
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
96 get_device_from_display (Display *dpy)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
97 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
98 Lisp_Object devcons, concons;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
99
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
100 DEVICE_LOOP_NO_BREAK (devcons, concons)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
101 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
102 struct device *d = XDEVICE (XCAR (devcons));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
103 if (DEVICE_X_P (d) && DEVICE_X_DISPLAY (d) == dpy)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
104 return d;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
105 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
106
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
107 /* Only devices we are actually managing should ever be used as an
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
108 argument to this function. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
109 abort ();
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
110
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
111 return 0; /* suppress compiler warning */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
112 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
113
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
114 struct device *
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
115 decode_x_device (Lisp_Object device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
116 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
117 XSETDEVICE (device, decode_device (device));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
118 CHECK_X_DEVICE (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
119 return XDEVICE (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
120 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
121
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
122 Display *
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
123 get_x_display (Lisp_Object device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
124 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
125 return DEVICE_X_DISPLAY (decode_x_device (device));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
126 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
127
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
128
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
129 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
130 /* initializing an X connection */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
131 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
132
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
133 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
134 allocate_x_device_struct (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
135 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
136 d->device_data = (struct x_device *) xmalloc (sizeof (struct x_device));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
137
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
138 /* zero out all slots. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
139 memset (d->device_data, 0, sizeof (struct x_device));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
140 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
141
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
142 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
143 Xatoms_of_device_x (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
144 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
145 Display *display = DEVICE_X_DISPLAY (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
146 #define ATOM(x) XInternAtom (display, (x), False)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
147
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
148 DEVICE_XATOM_WM_PROTOCOLS (d) = ATOM ("WM_PROTOCOLS");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
149 DEVICE_XATOM_WM_DELETE_WINDOW (d) = ATOM ("WM_DELETE_WINDOW");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
150 DEVICE_XATOM_WM_SAVE_YOURSELF (d) = ATOM ("WM_SAVE_YOURSELF");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
151 DEVICE_XATOM_WM_TAKE_FOCUS (d) = ATOM ("WM_TAKE_FOCUS");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
152 DEVICE_XATOM_WM_STATE (d) = ATOM ("WM_STATE");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
153 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
154
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
155 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
156 sanity_check_geometry_resource (Display *dpy)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
157 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
158 char *app_name, *app_class, *s;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
159 char buf1 [255], buf2 [255];
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
160 char *type;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
161 XrmValue value;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
162 XtGetApplicationNameAndClass (dpy, &app_name, &app_class);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
163 strcpy (buf1, app_name);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
164 strcpy (buf2, app_class);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
165 for (s = buf1; *s; s++) if (*s == '.') *s = '_';
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
166 strcat (buf1, "._no_._such_._resource_.geometry");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
167 strcat (buf2, "._no_._such_._resource_.Geometry");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
168 if (XrmGetResource (XtDatabase (dpy), buf1, buf2, &type, &value) == True)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
169 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
170 warn_when_safe (Qgeometry, Qerror,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
171 "\n"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
172 "Apparently \"%s*geometry: %s\" or \"%s*geometry: %s\" was\n"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
173 "specified in the resource database. Specifying \"*geometry\" will make\n"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
174 "XEmacs (and most other X programs) malfunction in obscure ways. (i.e.\n"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
175 "the Xt or Xm libraries will probably crash, which is a very bad thing.)\n"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
176 "You should always use \".geometry\" or \"*EmacsFrame.geometry\" instead.\n",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
177 app_name, (char *) value.addr,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
178 app_class, (char *) value.addr);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
179 suppress_early_backtrace = 1;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
180 error ("Invalid geometry resource");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
181 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
182 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
183
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
184 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
185 x_init_device_class (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
186 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
187 Display *dpy = DEVICE_X_DISPLAY (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
188 if (DisplayCells (dpy, DefaultScreen (dpy)) > 2)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
189 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
190 switch (DefaultVisualOfScreen (DefaultScreenOfDisplay (dpy))->class)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
191 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
192 case StaticGray:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
193 case GrayScale:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
194 DEVICE_CLASS (d) = Qgrayscale;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
195 break;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
196 default:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
197 DEVICE_CLASS (d) = Qcolor;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
198 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
199 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
200 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
201 DEVICE_CLASS (d) = Qmono;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
202 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
203
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
204 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
205 x_init_device (struct device *d, Lisp_Object props)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
206 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
207 Lisp_Object display;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
208 Lisp_Object device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
209 Display *dpy;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
210 int argc;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
211 char **argv;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
212 CONST char *app_class;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
213 CONST char *disp_name;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
214
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
215 XSETDEVICE (device, d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
216 display = DEVICE_CONNECTION (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
217
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
218 allocate_x_device_struct (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
219
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
220 if (NILP (Vdefault_x_device))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
221 Vdefault_x_device = device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
222
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
223 make_argc_argv (Vx_initial_argv_list, &argc, &argv);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
224
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
225 if (STRINGP (Vx_emacs_application_class) &&
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
226 string_length (XSTRING (Vx_emacs_application_class)) > 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
227 GET_C_STRING_CTEXT_DATA_ALLOCA (Vx_emacs_application_class, app_class);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
228 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
229 app_class = "Emacs";
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
230
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
231 GET_C_STRING_CTEXT_DATA_ALLOCA (display, disp_name);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
232
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
233 slow_down_interrupts ();
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
234 /* The Xt code can't deal with signals here. Yuck. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
235 dpy = DEVICE_X_DISPLAY (d) =
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
236 XtOpenDisplay (Xt_app_con, disp_name, NULL, app_class, emacs_options,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
237 XtNumber (emacs_options), &argc, argv);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
238 speed_up_interrupts ();
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
239
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
240 if (dpy == 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
241 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
242 suppress_early_backtrace = 1;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
243 signal_simple_error ("X server not responding\n", display);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
244 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
245
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
246 if (NILP (DEVICE_NAME (d)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
247 DEVICE_NAME (d) = display;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
248
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
249 /* We're going to modify the string in-place, so be a nice XEmacs */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
250 DEVICE_NAME (d) = Fcopy_sequence (DEVICE_NAME (d));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
251 /* colons and periods can't appear in individual elements of resource
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
252 strings */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
253 validify_resource_string ((char *) string_data (XSTRING (DEVICE_NAME (d))));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
254 DEVICE_XT_APP_SHELL (d) = XtAppCreateShell (NULL, app_class,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
255 applicationShellWidgetClass,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
256 dpy, NULL, 0);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
257
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
258
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
259 Vx_initial_argv_list = make_arg_list (argc, argv);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
260 free_argc_argv (argv);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
261
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
262 DEVICE_X_WM_COMMAND_FRAME (d) = Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
263
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
264 sanity_check_geometry_resource (dpy);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
265
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
266 /* In event-Xt.c */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
267 x_init_modifier_mapping (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
268
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
269 DEVICE_INFD (d) = DEVICE_OUTFD (d) = ConnectionNumber (dpy);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
270 init_baud_rate (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
271 init_one_device (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
272
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
273 DEVICE_X_GC_CACHE (d) =
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
274 make_gc_cache (dpy, RootWindow (dpy, DefaultScreen (dpy)));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
275 DEVICE_X_GRAY_PIXMAP (d) = None;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
276 Xatoms_of_device_x (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
277 Xatoms_of_xselect (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
278 Xatoms_of_objects_x (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
279 x_init_device_class (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
280
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
281 /* Run the the elisp side of the X device initialization. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
282 call0 (Qinit_pre_x_win);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
283 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
284
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
285 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
286 x_finish_init_device (struct device *d, Lisp_Object props)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
287 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
288 call0 (Qinit_post_x_win);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
289 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
290
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
291 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
292 x_mark_device (struct device *d, void (*markobj) (Lisp_Object))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
293 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
294 ((markobj) (DEVICE_X_DATA (d)->WM_COMMAND_frame));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
295 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
296
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
297
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
298 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
299 /* closing an X connection */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
300 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
301
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
302 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
303 free_x_device_struct (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
304 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
305 xfree (d->device_data);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
306 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
307
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
308 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
309 x_delete_device (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
310 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
311 Lisp_Object device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
312 Display *display;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
313 #ifdef FREE_CHECKING
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
314 extern void (*__free_hook)();
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
315 int checking_free;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
316 #endif
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
317
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
318 XSETDEVICE (device, d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
319 display = DEVICE_X_DISPLAY (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
320
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
321 if (display)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
322 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
323 #ifdef FREE_CHECKING
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
324 checking_free = (__free_hook != 0);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
325
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
326 /* Disable strict free checking, to avoid bug in X library */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
327 if (checking_free)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
328 disable_strict_free_check ();
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
329 #endif
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
330
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
331 free_gc_cache (DEVICE_X_GC_CACHE (d));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
332 if (DEVICE_X_DATA (d)->x_modifier_keymap)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
333 XFreeModifiermap (DEVICE_X_DATA (d)->x_modifier_keymap);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
334 if (DEVICE_X_DATA (d)->x_keysym_map)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
335 XFree ((char *) DEVICE_X_DATA (d)->x_keysym_map);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
336
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
337 XtCloseDisplay (display);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
338 DEVICE_X_DISPLAY (d) = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
339 #ifdef FREE_CHECKING
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
340 if (checking_free)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
341 enable_strict_free_check ();
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
342 #endif
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
343 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
344
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
345 if (EQ (device, Vdefault_x_device))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
346 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
347 Lisp_Object devcons, concons;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
348 /* #### handle deleting last X device */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
349 Vdefault_x_device = Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
350 DEVICE_LOOP_NO_BREAK (devcons, concons)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
351 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
352 if (DEVICE_X_P (XDEVICE (XCAR (devcons))))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
353 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
354 Vdefault_x_device = XCAR (devcons);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
355 goto double_break;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
356 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
357 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
358 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
359 double_break:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
360 free_x_device_struct (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
361 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
362
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
363
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
364 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
365 /* handle X errors */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
366 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
367
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
368 static CONST char *events[] =
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
369 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
370 "0: ERROR!",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
371 "1: REPLY",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
372 "KeyPress",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
373 "KeyRelease",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
374 "ButtonPress",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
375 "ButtonRelease",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
376 "MotionNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
377 "EnterNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
378 "LeaveNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
379 "FocusIn",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
380 "FocusOut",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
381 "KeymapNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
382 "Expose",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
383 "GraphicsExpose",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
384 "NoExpose",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
385 "VisibilityNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
386 "CreateNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
387 "DestroyNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
388 "UnmapNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
389 "MapNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
390 "MapRequest",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
391 "ReparentNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
392 "ConfigureNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
393 "ConfigureRequest",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
394 "GravityNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
395 "ResizeRequest",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
396 "CirculateNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
397 "CirculateRequest",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
398 "PropertyNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
399 "SelectionClear",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
400 "SelectionRequest",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
401 "SelectionNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
402 "ColormapNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
403 "ClientMessage",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
404 "MappingNotify",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
405 "LASTEvent"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
406 };
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
407
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
408 CONST char *
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
409 x_event_name (int event_type)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
410 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
411 if (event_type < 0) return 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
412 if (event_type >= (sizeof (events) / sizeof (char *))) return 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
413 return events [event_type];
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
414 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
415
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
416 /* Handling errors.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
417
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
418 If an X error occurs which we are not expecting, we have no alternative
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
419 but to print it to stderr. It would be nice to stuff it into a pop-up
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
420 buffer, or to print it in the minibuffer, but that's not possible, because
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
421 one is not allowed to do any I/O on the display connection from an error
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
422 handler. The guts of Xlib expect these functions to either return or exit.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
423
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
424 However, there are occasions when we might expect an error to reasonably
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
425 occur. The interface to this is as follows:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
426
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
427 Before calling some X routine which may error, call
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
428 expect_x_error (dpy);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
429
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
430 Just after calling the X routine, call either:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
431
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
432 x_error_occurred_p (dpy);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
433
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
434 to ask whether an error happened (and was ignored), or:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
435
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
436 signal_if_x_error (dpy, resumable_p);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
437
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
438 which will call Fsignal() with args appropriate to the X error, if there
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
439 was one. (Resumable_p is whether the debugger should be allowed to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
440 continue from the call to signal.)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
441
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
442 You must call one of these two routines immediately after calling the X
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
443 routine; think of them as bookends like BLOCK_INPUT and UNBLOCK_INPUT.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
444 */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
445
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
446 static int error_expected;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
447 static int error_occurred;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
448 static XErrorEvent last_error;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
449
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
450 /* OVERKILL! */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
451
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
452 #ifdef EXTERNAL_WIDGET
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
453 static Lisp_Object
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
454 x_error_handler_do_enqueue (Lisp_Object frame)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
455 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
456 enqueue_magic_eval_event (io_error_delete_frame, frame);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
457 return Qt;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
458 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
459
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
460 static Lisp_Object
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
461 x_error_handler_error (Lisp_Object data, Lisp_Object dummy)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
462 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
463 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
464 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
465 #endif /* EXTERNAL_WIDGET */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
466
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
467 int
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
468 x_error_handler (Display *disp, XErrorEvent *event)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
469 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
470 if (error_expected)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
471 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
472 error_expected = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
473 error_occurred = 1;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
474 last_error = *event;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
475 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
476 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
477 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
478 #ifdef EXTERNAL_WIDGET
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
479 struct frame *f;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
480 struct device *d = get_device_from_display (disp);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
481
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
482 if ((event->error_code == BadWindow ||
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
483 event->error_code == BadDrawable)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
484 && ((f = x_any_window_to_frame (d, event->resourceid)) != 0))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
485 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
486 Lisp_Object frame;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
487
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
488 /* one of the windows comprising one of our frames has died.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
489 This occurs particularly with ExternalShell frames when the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
490 client that owns the ExternalShell's window dies.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
491
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
492 We cannot do any I/O on the display connection so we need
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
493 to enqueue an eval event so that the deletion happens
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
494 later.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
495
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
496 Furthermore, we need to trap any errors (out-of-memory) that
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
497 may occur when Fenqueue_eval_event is called.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
498 */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
499
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
500 if (f->being_deleted)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
501 return 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
502 XSETFRAME (frame, f);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
503 if (!NILP (condition_case_1 (Qerror, x_error_handler_do_enqueue,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
504 frame, x_error_handler_error, Qnil)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
505 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
506 f->being_deleted = 1;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
507 f->visible = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
508 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
509 return 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
510 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
511 #endif /* EXTERNAL_WIDGET */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
512
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
513 stderr_out ("\n%s: ",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
514 (STRINGP (Vinvocation_name)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
515 ? (char *) string_data (XSTRING (Vinvocation_name))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
516 : "xemacs"));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
517 XmuPrintDefaultErrorMessage (disp, event, stderr);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
518 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
519 return 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
520 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
521
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
522 void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
523 expect_x_error (Display *dpy)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
524 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
525 assert (!error_expected);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
526 XSync (dpy, 0); /* handle pending errors before setting flag */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
527 error_expected = 1;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
528 error_occurred = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
529 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
530
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
531 int
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
532 x_error_occurred_p (Display *dpy)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
533 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
534 int val;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
535 XSync (dpy, 0); /* handle pending errors before setting flag */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
536 val = error_occurred;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
537 error_expected = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
538 error_occurred = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
539 return val;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
540 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
541
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
542 int
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
543 signal_if_x_error (Display *dpy, int resumable_p)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
544 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
545 char buf[1024];
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
546 Lisp_Object data;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
547 if (! x_error_occurred_p (dpy))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
548 return 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
549 data = Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
550 sprintf (buf, "0x%X", (unsigned int) last_error.resourceid);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
551 data = Fcons (build_string (buf), data);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
552 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
553 char num [32];
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
554 sprintf (num, "%d", last_error.request_code);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
555 XGetErrorDatabaseText (last_error.display, "XRequest", num, "",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
556 buf, sizeof (buf));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
557 if (! *buf)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
558 sprintf (buf, "Request-%d", last_error.request_code);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
559 data = Fcons (build_string (buf), data);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
560 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
561 XGetErrorText (last_error.display, last_error.error_code, buf, sizeof (buf));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
562 data = Fcons (build_string (buf), data);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
563 again:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
564 Fsignal (Qx_error, data);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
565 if (! resumable_p) goto again;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
566 return 1;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
567 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
568
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
569 int
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
570 x_IO_error_handler (Display *disp)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
571 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
572 /* This function can GC */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
573 Lisp_Object dev;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
574 struct device *d = get_device_from_display (disp);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
575 XSETDEVICE (dev, d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
576
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
577 if (NILP (find_nonminibuffer_frame_not_on_device (dev)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
578 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
579 /* We're going down. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
580 stderr_out
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
581 ("\n%s: Fatal I/O Error %d (%s) on display connection \"%s\"\n",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
582 (STRINGP (Vinvocation_name) ?
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
583 (char *) string_data (XSTRING (Vinvocation_name)) : "xemacs"),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
584 errno, strerror (errno), DisplayString (disp));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
585 stderr_out
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
586 (" after %lu requests (%lu known processed) with %d events remaining.\n",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
587 NextRequest (disp) - 1, LastKnownRequestProcessed (disp),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
588 QLength (disp));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
589 /* assert (!_Xdebug); */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
590 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
591 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
592 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
593 warn_when_safe
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
594 (Qx, Qcritical,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
595 "I/O Error %d (%s) on display connection \"%s\"\n"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
596 " after %lu requests (%lu known processed) with "
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
597 "%d events remaining.\n",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
598 errno, strerror (errno), DisplayString (disp),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
599 NextRequest (disp) - 1, LastKnownRequestProcessed (disp),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
600 QLength (disp));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
601 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
602
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
603 enqueue_magic_eval_event (io_error_delete_device, dev);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
604
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
605 return 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
606 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
607
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
608 DEFUN ("x-debug-mode", Fx_debug_mode, Sx_debug_mode, 1, 2, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
609 With a true arg, make the connection to the X server synchronous.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
610 With false, make it asynchronous. Synchronous connections are much slower,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
611 but are useful for debugging. (If you get X errors, make the connection
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
612 synchronous, and use a debugger to set a breakpoint on `x_error_handler'.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
613 Your backtrace of the C stack will now be useful. In asynchronous mode,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
614 the stack above `x_error_handler' isn't helpful because of buffering.)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
615 If DEVICE is not specified, the selected device is assumed.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
616
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
617 Calling this function is the same as calling the C function `XSynchronize',
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
618 or starting the program with the `-sync' command line argument.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
619 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
620 (arg, device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
621 Lisp_Object arg, device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
622 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
623 struct device *d = decode_x_device (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
624
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
625 XSynchronize (DEVICE_X_DISPLAY (d), !NILP (arg));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
626
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
627 if (!NILP (arg))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
628 message ("X connection is synchronous");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
629 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
630 message ("X connection is asynchronous");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
631
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
632 return arg;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
633 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
634
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
635
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
636 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
637 /* X resources */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
638 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
639
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
640 #if 0 /* bah humbug. The whole "widget == resource" stuff is such
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
641 a crock of shit that I'm just going to ignore it all. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
642
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
643 /* If widget is NULL, we are retrieving device or global face data. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
644
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
645 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
646 construct_name_list (Display *display, Widget widget, char *fake_name,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
647 char *fake_class, char *name, char *class)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
648 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
649 char *stack [100][2];
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
650 Widget this;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
651 int count = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
652 char *name_tail, *class_tail;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
653
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
654 if (widget)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
655 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
656 for (this = widget; this; this = XtParent (this))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
657 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
658 stack [count][0] = this->core.name;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
659 stack [count][1] = XtClass (this)->core_class.class_name;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
660 count++;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
661 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
662 count--;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
663 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
664 else if (fake_name && fake_class)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
665 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
666 stack [count][0] = fake_name;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
667 stack [count][1] = fake_class;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
668 count++;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
669 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
670
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
671 /* The root widget is an application shell; resource lookups use the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
672 specified application name and application class in preference to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
673 the name/class of that widget (which is argv[0] / "ApplicationShell").
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
674 Generally the app name and class will be argv[0] / "Emacs" but
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
675 the former can be set via the -name command-line option, and the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
676 latter can be set by changing `x-emacs-application-class' in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
677 lisp/term/x-win.el.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
678 */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
679 XtGetApplicationNameAndClass (display,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
680 &stack [count][0],
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
681 &stack [count][1]);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
682
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
683 name [0] = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
684 class [0] = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
685
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
686 name_tail = name;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
687 class_tail = class;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
688 for (; count >= 0; count--)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
689 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
690 strcat (name_tail, stack [count][0]);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
691 for (; *name_tail; name_tail++)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
692 if (*name_tail == '.') *name_tail = '_';
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
693 strcat (name_tail, ".");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
694 name_tail++;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
695
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
696 strcat (class_tail, stack [count][1]);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
697 for (; *class_tail; class_tail++)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
698 if (*class_tail == '.') *class_tail = '_';
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
699 strcat (class_tail, ".");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
700 class_tail++;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
701 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
702 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
703
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
704 #endif
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
705
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
706 /* Only the characters [-_A-Za-z0-9] are allowed in the individual
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
707 sections of a resource. Convert invalid characters to -. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
708
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
709 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
710 validify_resource_string (char *str)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
711 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
712 while (*str)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
713 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
714 if (!strchr ("ABCDEFGHIJKLMNOPQRSTUVWXYZ"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
715 "abcdefghijklmnopqrstuvwxyz"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
716 "0123456789-_", *str))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
717 *str = '-';
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
718 str++;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
719 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
720 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
721
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
722 /* Given a locale and device specification from x-get-resource or
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
723 x-get-resource-prefix, return the resource prefix and display to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
724 fetch the resource on. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
725
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
726 static void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
727 x_get_resource_prefix (Lisp_Object locale, Lisp_Object device,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
728 Display **display_out, char *name_out,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
729 char *class_out)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
730 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
731 char *appname, *appclass;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
732
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
733 if (NILP (locale))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
734 locale = Qglobal;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
735 if (NILP (Fvalid_specifier_locale_p (locale)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
736 signal_simple_error ("Invalid locale", locale);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
737 if (WINDOWP (locale))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
738 /* #### I can't come up with any coherent way of naming windows.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
739 By relative position? That seems tricky because windows
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
740 can change position, be split, etc. By order of creation?
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
741 That seems less than useful. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
742 signal_simple_error ("Windows currently can't be resourced", locale);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
743
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
744 if (!NILP (device) && !DEVICEP (device))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
745 CHECK_DEVICE (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
746 if (DEVICEP (device) && !DEVICE_X_P (XDEVICE (device)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
747 device = Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
748 if (NILP (device))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
749 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
750 device = DFW_DEVICE (locale);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
751 if (DEVICEP (device) && !DEVICE_X_P (XDEVICE (device)))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
752 device = Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
753 if (NILP (device))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
754 device = Vdefault_x_device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
755 if (NILP (device))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
756 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
757 *display_out = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
758 return;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
759 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
760 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
761
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
762 *display_out = DEVICE_X_DISPLAY (XDEVICE (device));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
763
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
764 XtGetApplicationNameAndClass (*display_out, &appname, &appclass);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
765 strcpy (name_out, appname);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
766 strcpy (class_out, appclass);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
767 validify_resource_string (name_out);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
768 validify_resource_string (class_out);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
769
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
770 if (EQ (locale, Qglobal))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
771 return;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
772 if (BUFFERP (locale))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
773 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
774 strcat (name_out, ".buffer.");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
775 /* we know buffer is live; otherwise we got an error above. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
776 strcat (name_out,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
777 (CONST char *) string_data (XSTRING (Fbuffer_name (locale))));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
778 strcat (class_out, ".EmacsLocaleType.EmacsBuffer");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
779 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
780 else if (FRAMEP (locale))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
781 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
782 strcat (name_out, ".frame.");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
783 /* we know frame is live; otherwise we got an error above. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
784 strcat (name_out,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
785 (CONST char *) string_data (XSTRING (Fframe_name (locale))));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
786 strcat (class_out, ".EmacsLocaleType.EmacsFrame");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
787 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
788 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
789 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
790 assert (DEVICEP (locale));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
791 strcat (name_out, ".device.");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
792 /* we know device is live; otherwise we got an error above. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
793 strcat (name_out,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
794 (CONST char *) string_data (XSTRING (Fdevice_name (locale))));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
795 strcat (class_out, ".EmacsLocaleType.EmacsDevice");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
796 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
797 return;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
798 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
799
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
800 DEFUN ("x-get-resource", Fx_get_resource, Sx_get_resource, 3, 6, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
801 Retrieve an X resource from the resource manager.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
802
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
803 The first arg is the name of the resource to retrieve, such as \"font\".
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
804 The second arg is the class of the resource to retrieve, like \"Font\".
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
805 The third arg should be one of the symbols 'string, 'integer, 'natnum, or
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
806 'boolean, specifying the type of object that the database is searched for.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
807 The fourth arg is the locale to search for the resources on, and can
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
808 currently be a a buffer, a frame, a device, or 'global. If omitted, it
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
809 defaults to 'global.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
810 The fifth arg is the device to search for the resources on. (The resource
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
811 database for a particular device is constructed by combining non-device-
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
812 specific resources such any command-line resources specified and any
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
813 app-defaults files found [or the fallback resources supplied by XEmacs,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
814 if no app-defaults file is found] with device-specific resources such as
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
815 those supplied using xrdb.) If omitted, it defaults to the device of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
816 LOCALE, if a device can be derived (i.e. if LOCALE is a frame or device),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
817 and otherwise defaults to the value of `default-x-device'.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
818 The sixth arg NOERROR, if non-nil, means do not signal an error if a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
819 bogus resource specification was retrieved (e.g. if a non-integer was
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
820 given when an integer was requested). In this case, a warning is issued
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
821 instead.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
822
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
823 The resource names passed to this function are looked up relative to the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
824 locale.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
825
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
826 If you want to search for a subresource, you just need to specify the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
827 resource levels in NAME and CLASS. For example, NAME could be
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
828 \"modeline.attributeFont\", and CLASS \"Face.AttributeFont\".
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
829
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
830 Specifically,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
831
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
832 1) If LOCALE is a buffer, a call
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
833
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
834 (x-get-resource \"foreground\" \"Foreground\" 'string SOME-BUFFER)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
835
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
836 is an interface to a C call something like
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
837
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
838 XrmGetResource (db, \"xemacs.buffer.BUFFER-NAME.foreground\",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
839 \"Emacs.EmacsLocaleType.EmacsBuffer.Foreground\",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
840 \"String\");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
841
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
842 2) If LOCALE is a frame, a call
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
843
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
844 (x-get-resource \"foreground\" \"Foreground\" 'string SOME-FRAME)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
845
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
846 is an interface to a C call something like
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
847
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
848 XrmGetResource (db, \"xemacs.frame.FRAME-NAME.foreground\",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
849 \"Emacs.EmacsLocaleType.EmacsFrame.Foreground\",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
850 \"String\");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
851
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
852 3) If LOCALE is a device, a call
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
853
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
854 (x-get-resource \"foreground\" \"Foreground\" 'string SOME-DEVICE)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
855
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
856 is an interface to a C call something like
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
857
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
858 XrmGetResource (db, \"xemacs.device.DEVICE-NAME.foreground\",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
859 \"Emacs.EmacsLocaleType.EmacsDevice.Foreground\",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
860 \"String\");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
861
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
862 4) If LOCALE is 'global, a call
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
863
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
864 (x-get-resource \"foreground\" \"Foreground\" 'string 'global)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
865
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
866 is an interface to a C call something like
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
867
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
868 XrmGetResource (db, \"xemacs.foreground\",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
869 \"Emacs.Foreground\",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
870 \"String\");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
871
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
872 Note that for 'global, no prefix is added other than that of the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
873 application itself; thus, you can use this locale to retrieve
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
874 arbitrary application resources, if you really want to.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
875
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
876 The returned value of this function is nil if the queried resource is not
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
877 found. If the third arg is `string', a string is returned, and if it is
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
878 `integer', an integer is returned. If the third arg is `boolean', then the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
879 returned value is the list (t) for true, (nil) for false, and is nil to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
880 mean ``unspecified.''
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
881 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
882 (name, class, type, locale, device, no_error)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
883 Lisp_Object name, class, type, locale, device, no_error;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
884 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
885 /* #### fixed limit, could be overflowed */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
886 char name_string[2048], class_string[2048];
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
887 char *raw_result;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
888 XrmDatabase db;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
889 Display *display;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
890 Error_behavior errb = decode_error_behavior_flag (no_error);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
891
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
892 CHECK_STRING (name);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
893 CHECK_STRING (class);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
894 CHECK_SYMBOL (type);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
895
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
896 if (!EQ (type, Qstring) && !EQ (type, Qboolean) &&
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
897 !EQ (type, Qinteger) && !EQ (type, Qnatnum))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
898 return maybe_signal_continuable_error
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
899 (Qwrong_type_argument,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
900 list2 (build_translated_string
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
901 ("should be string, integer, natnum or boolean"),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
902 type),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
903 Qresource, errb);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
904
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
905 x_get_resource_prefix (locale, device, &display, name_string,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
906 class_string);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
907 if (!display)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
908 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
909
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
910 db = XtDatabase (display);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
911
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
912 strcat (name_string, ".");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
913 strcat (name_string, (CONST char *) string_data (XSTRING (name)));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
914 strcat (class_string, ".");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
915 strcat (class_string, (CONST char *) string_data (XSTRING (class)));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
916
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
917 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
918 XrmValue xrm_value;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
919 XrmName namelist[100];
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
920 XrmClass classlist[100];
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
921 XrmName *namerest = namelist;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
922 XrmClass *classrest = classlist;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
923 XrmRepresentation xrm_type;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
924 XrmRepresentation string_quark;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
925 int result;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
926 XrmStringToNameList (name_string, namelist);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
927 XrmStringToClassList (class_string, classlist);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
928 string_quark = XrmStringToQuark ("String");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
929
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
930 /* ensure that they have the same length */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
931 while (namerest[0] && classrest[0])
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
932 namerest++, classrest++;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
933 if (namerest[0] || classrest[0])
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
934 signal_simple_error_2
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
935 ("class list and name list must be the same length", name, class);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
936 result = XrmQGetResource (db, namelist, classlist, &xrm_type, &xrm_value);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
937
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
938 if (result != True || xrm_type != string_quark)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
939 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
940 raw_result = (char *) xrm_value.addr;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
941 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
942
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
943 if (EQ (type, Qstring))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
944 return build_string (raw_result);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
945 else if (EQ (type, Qboolean))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
946 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
947 if (!strcasecmp (raw_result, "off") ||
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
948 !strcasecmp (raw_result, "false") ||
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
949 !strcasecmp (raw_result,"no"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
950 return Fcons (Qnil, Qnil);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
951 else if (!strcasecmp (raw_result, "on") ||
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
952 !strcasecmp (raw_result, "true") ||
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
953 !strcasecmp (raw_result, "yes"))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
954 return Fcons (Qt, Qnil);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
955 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
956 return maybe_continuable_error (Qresource, errb,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
957 "can't convert %s: %s to a Boolean",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
958 name_string, raw_result);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
959 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
960 else if (EQ (type, Qinteger) || EQ (type, Qnatnum))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
961 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
962 int i;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
963 char c;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
964 if (1 != sscanf (raw_result, "%d%c", &i, &c))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
965 return maybe_continuable_error
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
966 (Qresource, errb,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
967 "can't convert %s: %s to an integer",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
968 name_string, raw_result);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
969 else if (EQ (type, Qnatnum) && i < 0)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
970 return maybe_continuable_error
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
971 (Qresource, errb,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
972 "invalid numerical value %d for resource %s",
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
973 i, name_string);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
974 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
975 return make_int (i);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
976 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
977 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
978 abort ();
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
979
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
980 /* Can't get here. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
981 return Qnil; /* shut up compiler */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
982 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
983
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
984 DEFUN ("x-get-resource-prefix", Fx_get_resource_prefix,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
985 Sx_get_resource_prefix, 1, 2, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
986 Return the resource prefix for LOCALE on DEVICE.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
987 The resource prefix is the strings used to prefix resources if
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
988 the LOCALE and DEVICE arguments were passed to `x-get-resource'.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
989 The returned value is a cons of a name prefix and a class prefix.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
990 For example, if LOCALE is a frame, the returned value might be
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
991 \(\"xemacs.frame.FRAME-NAME\" . \"Emacs.EmacsLocaleType.EmacsFrame\").
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
992 If no valid X device for resourcing can be obtained, this function
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
993 returns nil. (In such a case, `x-get-resource' would always return nil.)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
994 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
995 (locale, device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
996 Lisp_Object locale, device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
997 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
998 /* #### fixed limit, could be overflowed */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
999 char name[1024], class[1024];
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1000 Display *display;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1001
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1002 x_get_resource_prefix (locale, device, &display, name, class);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1003 if (!display)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1004 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1005 return Fcons (build_string (name), build_string (class));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1006 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1007
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1008 DEFUN ("x-put-resource", Fx_put_resource, Sx_put_resource, 1, 2, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1009 Add a resource to the resource database for DEVICE.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1010 RESOURCE-LINE specifies the resource to add and should be a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1011 standard resource specification.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1012 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1013 (resource_line, device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1014 Lisp_Object resource_line, device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1015 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1016 struct device *d = decode_device (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1017 char *str, *colon_pos;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1018
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1019 CHECK_STRING (resource_line);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1020 str = (char *) string_data (XSTRING (resource_line));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1021 if (!(colon_pos = strchr (str, ':')) || strchr (str, '\n'))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1022 invalid:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1023 signal_simple_error ("Invalid resource line", resource_line);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1024 if (strspn (str,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1025 /* Only the following chars are allowed before the colon */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1026 " \t.*?abcdefghijklmnopqrstuvwxyz"
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1027 "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789_-") != colon_pos - str)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1028 goto invalid;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1029
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1030 if (DEVICE_X_P (d))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1031 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1032 XrmDatabase db = XtDatabase (DEVICE_X_DISPLAY (d));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1033 XrmPutLineResource (&db, str);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1034 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1035
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1036 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1037 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1038
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1039
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1040 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1041 /* display information functions */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1042 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1043
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1044 DEFUN ("default-x-device", Fdefault_x_device, Sdefault_x_device, 0, 0, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1045 Return the default X device for resourcing.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1046 This is the first-created X device that still exists.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1047 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1048 ()
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1049 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1050 return Vdefault_x_device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1051 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1052
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1053 DEFUN ("x-display-visual-class", Fx_display_visual_class,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1054 Sx_display_visual_class, 0, 1, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1055 Return the visual class of the X display `device' is on.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1056 The returned value will be one of the symbols `static-gray', `gray-scale',
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1057 `static-color', `pseudo-color', `true-color', or `direct-color'.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1058 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1059 (device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1060 Lisp_Object device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1061 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1062 switch (DefaultVisualOfScreen
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1063 (DefaultScreenOfDisplay (get_x_display (device)))->class)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1064 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1065 case StaticGray: return (intern ("static-gray"));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1066 case GrayScale: return (intern ("gray-scale"));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1067 case StaticColor: return (intern ("static-color"));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1068 case PseudoColor: return (intern ("pseudo-color"));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1069 case TrueColor: return (intern ("true-color"));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1070 case DirectColor: return (intern ("direct-color"));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1071 default:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1072 error ("display has an unknown visual class");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1073 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1074
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1075 return Qnil; /* suppress compiler warning */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1076 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1077
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1078 static int
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1079 x_device_pixel_width (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1080 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1081 Display *dpy = DEVICE_X_DISPLAY (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1082
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1083 return DisplayWidth (dpy, DefaultScreen (dpy));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1084 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1085
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1086 static int
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1087 x_device_pixel_height (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1088 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1089 Display *dpy = DEVICE_X_DISPLAY (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1090
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1091 return DisplayHeight (dpy, DefaultScreen (dpy));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1092 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1093
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1094 static int
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1095 x_device_mm_width (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1096 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1097 Display *dpy = DEVICE_X_DISPLAY (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1098
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1099 return DisplayWidthMM (dpy, DefaultScreen (dpy));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1100 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1101
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1102 static int
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1103 x_device_mm_height (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1104 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1105 Display *dpy = DEVICE_X_DISPLAY (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1106
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1107 return DisplayHeightMM (dpy, DefaultScreen (dpy));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1108 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1109
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1110 static int
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1111 x_device_bitplanes (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1112 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1113 Display *dpy = DEVICE_X_DISPLAY (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1114
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1115 return DisplayPlanes (dpy, DefaultScreen (dpy));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1116 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1117
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1118 static int
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1119 x_device_color_cells (struct device *d)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1120 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1121 Display *dpy = DEVICE_X_DISPLAY (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1122
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1123 return DisplayCells (dpy, DefaultScreen (dpy));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1124 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1125
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1126 DEFUN ("x-server-vendor", Fx_server_vendor, Sx_server_vendor, 0, 1, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1127 Return the vendor ID string of the X server `device' on.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1128 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1129 (device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1130 Lisp_Object device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1131 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1132 Display *dpy = get_x_display (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1133 char *vendor = ServerVendor (dpy);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1134
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1135 if (vendor)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1136 return (build_string (vendor));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1137 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1138 return (build_string (""));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1139 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1140
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1141 DEFUN ("x-server-version", Fx_server_version, Sx_server_version, 0, 1, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1142 Return the version numbers of the X server `device' is on.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1143 The returned value is a list of three integers: the major and minor
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1144 version numbers of the X Protocol in use, and the vendor-specific release
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1145 number. See also `x-server-vendor'.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1146 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1147 (device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1148 Lisp_Object device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1149 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1150 Display *dpy = get_x_display (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1151
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1152 return list3 (make_int (ProtocolVersion (dpy)),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1153 make_int (ProtocolRevision (dpy)),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1154 make_int (VendorRelease (dpy)));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1155 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1156
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1157 DEFUN ("x-valid-keysym-name-p", Fx_valid_keysym_name_p, Sx_valid_keysym_name_p,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1158 1, 1, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1159 Return true if KEYSYM names a keysym that the X library knows about.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1160 Valid keysyms are listed in the files /usr/include/X11/keysymdef.h and in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1161 /usr/lib/X11/XKeysymDB, or whatever the equivalents are on your system.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1162 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1163 (keysym)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1164 Lisp_Object keysym;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1165 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1166 CONST char *keysym_ext;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1167
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1168 CHECK_STRING (keysym);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1169 GET_C_STRING_CTEXT_DATA_ALLOCA (keysym, keysym_ext);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1170 if (XStringToKeysym (keysym_ext))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1171 return Qt;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1172 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1173 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1174
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1175 DEFUN ("x-keysym-on-keyboard-p", Fx_keysym_on_keyboard_p, Sx_keysym_on_keyboard_p,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1176 1, 2, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1177 Return true if KEYSYM names a key on the keyboard of DEVICE.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1178 More precisely, return true if pressing a physical key
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1179 on the keyboard of DEVICE without any modifier keys generates KEYSYM.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1180 Valid keysyms are listed in the files /usr/include/X11/keysymdef.h and in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1181 /usr/lib/X11/XKeysymDB, or whatever the equivalents are on your system.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1182 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1183 (keysym, device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1184 Lisp_Object keysym, device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1185 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1186 struct device *d = decode_device(device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1187 CONST char *keysym_string;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1188 KeySym keysym_KeySym;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1189 KeySym *keysym_ptr, *keysym_last;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1190 int code, min_code, max_code, keysyms_per_code;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1191
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1192 if (!DEVICE_X_P (d))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1193 signal_simple_error ("Not an X device", device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1194 CHECK_STRING (keysym);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1195 GET_C_STRING_CTEXT_DATA_ALLOCA (keysym, keysym_string);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1196 keysym_KeySym = XStringToKeysym (keysym_string);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1197 if (!keysym_KeySym) /* Invalid keysym */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1198 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1199
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1200 XDisplayKeycodes (DEVICE_X_DISPLAY (d), &min_code, &max_code);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1201 keysyms_per_code = DEVICE_X_DATA (d)->x_keysym_map_keysyms_per_code;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1202 keysym_ptr = DEVICE_X_DATA (d)->x_keysym_map;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1203 keysym_last = keysym_ptr + (max_code - min_code) * keysyms_per_code;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1204 for ( ; keysym_ptr <= keysym_last; keysym_ptr += keysyms_per_code)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1205 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1206 if (keysym_KeySym == *keysym_ptr)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1207 return Qt;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1208 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1209
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1210 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1211 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1212
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1213
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1214 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1215 /* grabs and ungrabs */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1216 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1217
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1218 DEFUN ("x-grab-pointer", Fx_grab_pointer, Sx_grab_pointer, 0, 3, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1219 Grab the pointer and restrict it to its current window.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1220 If optional DEVICE argument is nil, the default device will be used.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1221 If optional CURSOR argument is non-nil, change the pointer shape to that
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1222 until `x-ungrab-pointer' is called (it should be an object returned by the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1223 `make-cursor-glyph' function).
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1224 If the second optional argument IGNORE-KEYBOARD is non-nil, ignore all
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1225 keyboard events during the grab.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1226 Returns t if the grab is successful, nil otherwise.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1227 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1228 (device, cursor, ignore_keyboard)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1229 Lisp_Object device, cursor, ignore_keyboard;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1230 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1231 Window w;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1232 int pointer_mode, result;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1233 struct device *d = decode_x_device (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1234
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1235 if (!NILP (cursor))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1236 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1237 CHECK_POINTER_GLYPH (cursor);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1238 cursor = glyph_image_instance (cursor, device, ERROR_ME, 0);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1239 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1240
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1241 if (!NILP (ignore_keyboard))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1242 pointer_mode = GrabModeSync;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1243 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1244 pointer_mode = GrabModeAsync;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1245
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1246 w = XtWindow (FRAME_X_TEXT_WIDGET (device_selected_frame (d)));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1247
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1248 /* #### Possibly this needs to gcpro the cursor somehow, but it doesn't
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1249 seem to cause a problem if XFreeCursor is called on a cursor in use
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1250 in a grab; I suppose the X server counts the grab as a reference
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1251 and doesn't free it until it exits? */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1252 result = XGrabPointer (DEVICE_X_DISPLAY (d), w,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1253 False,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1254 ButtonMotionMask | ButtonPressMask
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1255 | ButtonReleaseMask | PointerMotionHintMask,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1256 GrabModeAsync, /* Keep pointer events flowing */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1257 pointer_mode, /* Stall keyboard events */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1258 w, /* Stay in this window */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1259 (NILP (cursor) ? 0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1260 : XIMAGE_INSTANCE_X_CURSOR (cursor)),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1261 CurrentTime);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1262 return ((result == GrabSuccess) ? Qt : Qnil);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1263 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1264
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1265 DEFUN ("x-ungrab-pointer", Fx_ungrab_pointer, Sx_ungrab_pointer, 0, 1, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1266 Release a pointer grab made with `x-grab-pointer'.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1267 If optional first arg DEVICE is nil the default device is used.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1268 If it is t the pointer will be released on all X devices.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1269 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1270 (device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1271 Lisp_Object device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1272 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1273 if (!EQ (device, Qt))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1274 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1275 Display *dpy = get_x_display (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1276 XUngrabPointer (dpy, CurrentTime);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1277 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1278 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1279 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1280 Lisp_Object devcons, concons;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1281
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1282 DEVICE_LOOP_NO_BREAK (devcons, concons)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1283 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1284 struct device *d = XDEVICE (XCAR (devcons));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1285
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1286 if (DEVICE_X_P (d))
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1287 XUngrabPointer (DEVICE_X_DISPLAY (d), CurrentTime);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1288 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1289 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1290
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1291 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1292 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1293
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1294 DEFUN ("x-grab-keyboard", Fx_grab_keyboard, Sx_grab_keyboard, 0, 1, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1295 Grab the keyboard on the given device (defaulting to the selected one).
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1296 So long as the keyboard is grabbed, all keyboard events will be delivered
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1297 to emacs -- it is not possible for other X clients to eavesdrop on them.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1298 Ungrab the keyboard with `x-ungrab-keyboard' (use an unwind-protect).
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1299 Returns t if the grab was successful; nil otherwise.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1300 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1301 (device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1302 Lisp_Object device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1303 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1304 struct device *d = decode_x_device (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1305 Window w = XtWindow (FRAME_X_TEXT_WIDGET (device_selected_frame (d)));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1306 Display *dpy = DEVICE_X_DISPLAY (d);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1307 Status status;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1308 XSync (dpy, False);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1309 status = XGrabKeyboard (dpy, w, True,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1310 /* I don't really understand sync-vs-async
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1311 grabs, but this is what xterm does. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1312 GrabModeAsync, GrabModeAsync,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1313 /* Use the timestamp of the last user action
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1314 read by emacs proper; xterm uses CurrentTime
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1315 but there's a comment that says "wrong"...
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1316 (Despite the name this is the time of the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1317 last key or mouse event.) */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1318 DEVICE_X_MOUSE_TIMESTAMP (d));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1319 if (status == GrabSuccess)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1320 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1321 /* The XUngrabKeyboard should generate a FocusIn back to this
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1322 window but it doesn't unless we explicitly set focus to the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1323 window first (which should already have it. The net result
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1324 is that without this call when x-ungrab-keyboard is called
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1325 the selected frame ends up not having focus. */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1326 XSetInputFocus (dpy, w, RevertToParent, DEVICE_X_MOUSE_TIMESTAMP (d));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1327 return Qt;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1328 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1329 else
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1330 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1331 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1332
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1333 DEFUN ("x-ungrab-keyboard", Fx_ungrab_keyboard, Sx_ungrab_keyboard, 0, 1, 0 /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1334 Release a keyboard grab made with `x-grab-keyboard'.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1335 */ )
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1336 (device)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1337 Lisp_Object device;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1338 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1339 Display *dpy = get_x_display (device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1340 XUngrabKeyboard (dpy, CurrentTime);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1341 return Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1342 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1343
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1344
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1345 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1346 /* initialization */
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1347 /************************************************************************/
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1348
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1349 void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1350 syms_of_device_x (void)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1351 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1352 defsubr (&Sx_debug_mode);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1353 defsubr (&Sx_get_resource);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1354 defsubr (&Sx_get_resource_prefix);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1355 defsubr (&Sx_put_resource);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1356
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1357 defsubr (&Sdefault_x_device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1358 defsubr (&Sx_display_visual_class);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1359 defsubr (&Sx_server_vendor);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1360 defsubr (&Sx_server_version);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1361 defsubr (&Sx_valid_keysym_name_p);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1362 defsubr (&Sx_keysym_on_keyboard_p);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1363
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1364 defsubr (&Sx_grab_pointer);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1365 defsubr (&Sx_ungrab_pointer);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1366 defsubr (&Sx_grab_keyboard);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1367 defsubr (&Sx_ungrab_keyboard);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1368
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1369 defsymbol (&Qx_error, "x-error");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1370 defsymbol (&Qinit_pre_x_win, "init-pre-x-win");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1371 defsymbol (&Qinit_post_x_win, "init-post-x-win");
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1372 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1373
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1374 void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1375 console_type_create_device_x (void)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1376 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1377 CONSOLE_HAS_METHOD (x, init_device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1378 CONSOLE_HAS_METHOD (x, finish_init_device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1379 CONSOLE_HAS_METHOD (x, mark_device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1380 CONSOLE_HAS_METHOD (x, delete_device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1381 CONSOLE_HAS_METHOD (x, device_pixel_width);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1382 CONSOLE_HAS_METHOD (x, device_pixel_height);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1383 CONSOLE_HAS_METHOD (x, device_mm_width);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1384 CONSOLE_HAS_METHOD (x, device_mm_height);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1385 CONSOLE_HAS_METHOD (x, device_bitplanes);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1386 CONSOLE_HAS_METHOD (x, device_color_cells);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1387 }
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1388
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1389 void
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1390 vars_of_device_x (void)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1391 {
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1392 DEFVAR_LISP ("x-emacs-application-class", &Vx_emacs_application_class /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1393 The X application class of the XEmacs process.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1394 This controls, among other things, the name of the `app-defaults' file
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1395 that XEmacs will use. For changes to this variable to take effect, they
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1396 must be made before the connection to the X server is initialized, that is,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1397 this variable may only be changed before emacs is dumped, or by setting it
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1398 in the file lisp/term/x-win.el.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1399 */ );
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1400 Vx_emacs_application_class = Fpurecopy (build_string ("Emacs"));
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1401
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1402 DEFVAR_LISP ("x-initial-argv-list", &Vx_initial_argv_list /*
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1403 You don't want to know.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1404 This is used during startup to communicate the remaining arguments in
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1405 `command-line-args-left' to the C code, which passes the args to
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1406 the X initialization code, which removes some args, and then the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1407 args are placed back into `x-initial-arg-list' and thence into
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1408 `command-line-args-left'. Perhaps `command-line-args-left' should
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1409 just reside in C.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1410 */ );
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1411 Vx_initial_argv_list = Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1412
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1413 Fprovide (Qx);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1414
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1415 staticpro (&Vdefault_x_device);
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1416 Vdefault_x_device = Qnil;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1417
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1418 error_expected = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1419 error_occurred = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1420
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1421 in_resource_setting = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1422 in_specifier_change_function = 0;
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1423 }