annotate src/msw-proc.c @ 213:78f53ef88e17 r20-4b5

Import from CVS: tag r20-4b5
author cvs
date Mon, 13 Aug 2007 10:06:47 +0200
parents
children d44af0c54775
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
213
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
1 /* mswindows specific event-handling.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
2 Copyright (C) 1997 Jonathan Harris.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
3
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
4 This file is part of XEmacs.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
5
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
6 XEmacs is free software; you can redistribute it and/or modify it
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
7 under the terms of the GNU General Public License as published by the
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
8 Free Software Foundation; either version 2, or (at your option) any
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
9 later version.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
10
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
11 XEmacs is distributed in the hope that it will be useful, but WITHOUT
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
14 for more details.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
15
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
17 along with XEmacs; see the file COPYING. If not, write to
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
19 Boston, MA 02111-1307, USA. */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
20
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
21 /* Synched up with: Not in FSF. */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
22
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
23 /* Authorship:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
24
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
25 Jonathan Harris, November 1997 for 20.4.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
26 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
27
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
28 /*
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
29 * Comment:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
30 *
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
31 * Windows user-input type events are stored in a per-thread message queue
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
32 * and retrieved using GetMessage(). It is not possible to wait on this
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
33 * queue and on other events (eg process input) simultaneously. Also, the
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
34 * main event-handling code in windows (the "windows procedure") is called
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
35 * asynchronously when windows has certain other types of events ("nonqueued
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
36 * messages") to deliver. The documentation doesn't appear to specify the
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
37 * context in which the windows procedure is called, but I assume that the
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
38 * thread that created the window is temporarily highjacked for this purpose.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
39 *
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
40 * We spawn off a single thread to deal with both kinds of messages. The
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
41 * thread turns the windows events into emacs_events and stuffs them in a
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
42 * queue which XEmacs reads at its leisure. This file contains the code for
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
43 * the thread. This scheme also helps to prevent weird synchronisation and
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
44 * deadlock problems that might occur if the windows procedure was called
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
45 * when XEmacs was already in the middle of processing an event.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
46 *
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
47 * Unfortunately, only the thread that created a window can retrieve messages
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
48 * destined for that window ("GetMessage does not retrieve messages for
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
49 * windows that belong to other threads..."). This means that our message-
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
50 * processing thread also has to do all window creation. We handle this
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
51 * bogosity by getting the main XEmacs thread to send special user-defined
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
52 * messages to the message-processing thread to instruct it to create windows.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
53 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
54
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
55
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
56 #include <config.h>
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
57 #include "lisp.h"
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
58
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
59 #include "console-msw.h"
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
60 #include "device.h"
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
61 #include "frame.h"
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
62 #include "events.h"
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
63 #include "event-msw.h"
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
64
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
65 #define MSWINDOWS_FRAME_STYLE WS_CLIPCHILDREN|WS_CLIPSIBLINGS|WS_TILEDWINDOW
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
66 #define MSWINDOWS_POPUP_STYLE WS_CLIPCHILDREN|WS_CLIPSIBLINGS|WS_CAPTION|WS_POPUP
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
67
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
68 static LRESULT WINAPI mswindows_wnd_proc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
69 static Lisp_Object mswindows_find_console (HWND hwnd);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
70 static Lisp_Object mswindows_find_frame (HWND hwnd);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
71 static Lisp_Object mswindows_key_to_emacs_keysym(int mswindows_key);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
72
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
73 /*
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
74 * Entry point for the "windows" message-processing thread
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
75 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
76 DWORD mswindows_win_thread()
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
77 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
78 WNDCLASS wc;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
79 MSG msg;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
80 mswindows_waitable_info_type info;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
81
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
82 /* Register the main window class */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
83 wc.style = CS_OWNDC; /* One DC per window */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
84 wc.lpfnWndProc = (WNDPROC) mswindows_wnd_proc;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
85 wc.cbClsExtra = 0;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
86 wc.cbWndExtra = 0; /* ? */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
87 wc.hInstance = NULL; /* ? */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
88 wc.hIcon = LoadIcon (NULL, XEMACS_CLASS);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
89 wc.hCursor = LoadCursor (NULL, IDC_ARROW);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
90 wc.hbrBackground = NULL; /* GetStockObject (WHITE_BRUSH); */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
91 wc.lpszMenuName = NULL; /* XXX FIXME? Add a menu? */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
92 wc.lpszClassName = XEMACS_CLASS;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
93 RegisterClass(&wc); /* XXX FIXME: Should use RegisterClassEx */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
94
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
95 info.type = mswindows_waitable_type_dispatch;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
96 mswindows_add_waitable(&info);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
97
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
98 /* Ensure our message queue is created XXX FIXME: Is this necessary? */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
99 PeekMessage (&msg, NULL, 0, 0, PM_NOREMOVE);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
100
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
101 /* Notify the main thread that we're ready */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
102 assert(PostThreadMessage (mswindows_main_thread_id, WM_XEMACS_ACK, 0, 0));
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
103
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
104 /* Main windows loop */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
105 while (1)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
106 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
107 GetMessage (&msg, NULL, 0, 0);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
108
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
109 /*
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
110 * Process things that don't have an associated window, so wouldn't
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
111 * get sent to mswindows_wnd_proc
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
112 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
113
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
114 /* Request from main thread */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
115 if (msg.message>=WM_XEMACS_BASE && msg.message<=WM_XEMACS_END)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
116 mswindows_handle_request(&msg);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
117
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
118 /* Timeout */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
119 else if (msg.message == WM_TIMER)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
120 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
121 Lisp_Object emacs_event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
122 struct Lisp_Event *event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
123
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
124 KillTimer(NULL, msg.wParam);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
125 EnterCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
126 emacs_event = Fmake_event (Qnil, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
127 event = XEVENT(emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
128
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
129 event->channel = Qnil;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
130 event->timestamp = msg.time;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
131 event->event_type = timeout_event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
132 event->event.timeout.interval_id = msg.wParam;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
133 mswindows_enqueue_dispatch_event (emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
134 LeaveCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
135 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
136 else
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
137 /* Pass on to mswindows_wnd_proc */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
138 DispatchMessage (&msg);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
139 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
140 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
141
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
142 /*
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
143 * The windows procedure for the window class XEMACS_CLASS
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
144 * Stuffs messages in the mswindows event queue
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
145 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
146 static LRESULT WINAPI mswindows_wnd_proc(HWND hwnd, UINT message, WPARAM wParam,
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
147 LPARAM lParam)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
148 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
149 /* Note: Remember to initialise these before use */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
150 Lisp_Object emacs_event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
151 struct Lisp_Event *event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
152
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
153 static int mods = 0;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
154 MSG msg = { hwnd, message, wParam, lParam, 0, {0,0} };
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
155 msg.time = GetMessageTime();
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
156
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
157 #if 0 /* XXX */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
158 stderr_out("Message %04x, wParam=%04x, lParam=%08lx\n", message, wParam, lParam);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
159 #endif
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
160 switch (message)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
161 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
162 case WM_KEYDOWN:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
163 case WM_SYSKEYDOWN:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
164 switch(wParam)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
165 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
166 case VK_SHIFT:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
167 mods |= MOD_SHIFT;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
168 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
169 case VK_CONTROL:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
170 mods |= MOD_CONTROL;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
171 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
172 case VK_MENU:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
173 mods |= MOD_META;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
174 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
175 default:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
176 /* Handle those keys that TranslateMessage won't generate a WM_CHAR for */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
177 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
178 Lisp_Object keysym;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
179 if (!NILP (keysym = mswindows_key_to_emacs_keysym(wParam)))
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
180 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
181 EnterCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
182 emacs_event = Fmake_event (Qnil, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
183 event = XEVENT(emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
184
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
185 event->channel = mswindows_find_console(hwnd);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
186 event->timestamp = msg.time;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
187 event->event_type = key_press_event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
188 event->event.key.keysym = keysym;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
189 event->event.key.modifiers = mods;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
190 mswindows_enqueue_dispatch_event (emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
191 LeaveCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
192 return (0);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
193 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
194 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
195 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
196 TranslateMessage (&msg); /* Maybe generates WM_[SYS]CHAR in message queue */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
197 goto defproc;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
198
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
199 case WM_KEYUP:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
200 case WM_SYSKEYUP:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
201 switch(wParam)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
202 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
203 case VK_SHIFT:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
204 mods &= ~MOD_SHIFT;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
205 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
206 case VK_CONTROL:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
207 mods &= ~MOD_CONTROL;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
208 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
209 case VK_MENU:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
210 mods &= ~MOD_META;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
211 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
212 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
213 TranslateMessage (&msg);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
214 goto defproc;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
215
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
216 case WM_CHAR:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
217 case WM_SYSCHAR:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
218 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
219 EnterCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
220 emacs_event = Fmake_event (Qnil, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
221 event = XEVENT(emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
222
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
223 event->channel = mswindows_find_console(hwnd);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
224 event->timestamp = msg.time;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
225 event->event_type = key_press_event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
226 event->event.key.modifiers = mods;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
227 event->event.key.modifiers = lParam & 0x20000000 ? MOD_META : 0; /* redundant? */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
228 if (wParam<' ') /* Control char not handled under WM_KEYDOWN */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
229 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
230 event->event.key.keysym = make_char(wParam+'a'-1);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
231 event->event.key.modifiers |= MOD_CONTROL; /* redundant? */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
232 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
233 else
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
234 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
235 /* Assumes that emacs keysym == ASCII code */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
236 event->event.key.keysym = make_char(wParam);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
237 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
238 mswindows_enqueue_dispatch_event (emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
239 LeaveCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
240 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
241 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
242
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
243 case WM_LBUTTONDOWN:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
244 case WM_MBUTTONDOWN:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
245 case WM_RBUTTONDOWN:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
246 case WM_LBUTTONUP:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
247 case WM_MBUTTONUP:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
248 case WM_RBUTTONUP:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
249 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
250 /* XXX FIXME: Do middle button emulation */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
251 EnterCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
252 emacs_event = Fmake_event (Qnil, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
253 event = XEVENT(emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
254
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
255 event->channel = mswindows_find_frame(hwnd);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
256 event->timestamp = msg.time;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
257 event->event_type =
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
258 (message==WM_LBUTTONDOWN || message==WM_MBUTTONDOWN ||
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
259 message==WM_RBUTTONDOWN) ?
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
260 button_press_event : button_release_event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
261 #if 0
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
262 ((wParam & MK_CONTROL) ? MOD_CONTROL : 0) |
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
263 ((wParam & MK_SHIFT) ? MOD_SHIFT : 0);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
264 #endif
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
265 event->event.button.button =
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
266 (message==WM_LBUTTONDOWN || message==WM_LBUTTONUP) ? 1 :
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
267 ((message==WM_RBUTTONDOWN || message==WM_RBUTTONUP) ? 3 : 2);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
268 event->event.button.x = LOWORD(lParam);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
269 event->event.button.y = HIWORD(lParam);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
270 event->event.button.modifiers = mods;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
271
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
272 mswindows_enqueue_dispatch_event (emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
273 LeaveCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
274 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
275 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
276
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
277 case WM_MOUSEMOVE:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
278 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
279 EnterCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
280 emacs_event = Fmake_event (Qnil, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
281 event = XEVENT(emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
282
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
283 event->channel = mswindows_find_frame(hwnd);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
284 event->timestamp = msg.time;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
285 event->event_type = pointer_motion_event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
286 event->event.motion.x = LOWORD(lParam);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
287 event->event.motion.y = HIWORD(lParam);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
288 event->event.motion.modifiers = mods;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
289
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
290 mswindows_enqueue_dispatch_event (emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
291 LeaveCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
292 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
293 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
294
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
295 case WM_PAINT:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
296 if (GetUpdateRect(hwnd, NULL, FALSE))
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
297 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
298 PAINTSTRUCT paintStruct;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
299
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
300 EnterCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
301 emacs_event = Fmake_event (Qnil, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
302 event = XEVENT(emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
303
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
304 event->channel = mswindows_find_frame(hwnd);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
305 event->timestamp = msg.time;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
306 event->event_type = magic_event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
307 BeginPaint (hwnd, &paintStruct);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
308 EVENT_MSWINDOWS_MAGIC_TYPE(event) = message;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
309 EVENT_MSWINDOWS_MAGIC_DATA(event) = paintStruct.rcPaint;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
310 EndPaint (hwnd, &paintStruct);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
311
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
312 mswindows_enqueue_dispatch_event (emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
313 LeaveCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
314 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
315 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
316
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
317 case WM_SIZE:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
318 /* We only care about this message if our size has really changed */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
319 if (wParam==SIZE_RESTORED || wParam==SIZE_MAXIMIZED || wParam==SIZE_MINIMIZED)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
320 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
321 RECT rect;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
322 EnterCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
323 emacs_event = Fmake_event (Qnil, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
324 event = XEVENT(emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
325
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
326 event->channel = mswindows_find_frame(hwnd);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
327 event->timestamp = msg.time;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
328 event->event_type = magic_event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
329 if (wParam==SIZE_MINIMIZED)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
330 rect.left = rect.top = rect.right = rect.bottom = -1;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
331 else
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
332 GetClientRect(hwnd, &rect);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
333 EVENT_MSWINDOWS_MAGIC_TYPE(event) = message;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
334 EVENT_MSWINDOWS_MAGIC_DATA(event) = rect;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
335
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
336 mswindows_enqueue_dispatch_event (emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
337 LeaveCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
338 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
339 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
340
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
341 case WM_SETFOCUS:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
342 case WM_KILLFOCUS:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
343 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
344 EnterCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
345 emacs_event = Fmake_event (Qnil, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
346 event = XEVENT(emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
347
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
348 event->channel = mswindows_find_frame(hwnd);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
349 event->timestamp = msg.time;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
350 event->event_type = magic_event;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
351 EVENT_MSWINDOWS_MAGIC_TYPE(event) = message;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
352
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
353 mswindows_enqueue_dispatch_event (emacs_event);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
354 LeaveCriticalSection (&mswindows_dispatch_crit);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
355 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
356 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
357
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
358 case WM_QUIT:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
359 /* XXX FIXME: Should do something here! */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
360 defproc:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
361 default:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
362 return DefWindowProc (hwnd, message, wParam, lParam);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
363 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
364 return (0);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
365 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
366
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
367
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
368 /*
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
369 * Make a request to the message-processing thread to do things that
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
370 * can't be done in the main thread.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
371 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
372 LPARAM
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
373 mswindows_make_request(UINT message, WPARAM wParam, mswindows_request_type *request)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
374 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
375 MSG msg;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
376 assert(PostThreadMessage (mswindows_win_thread_id, message, wParam,
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
377 (LPARAM) request));
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
378 GetMessage (&msg, NULL, WM_XEMACS_ACK, WM_XEMACS_ACK);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
379 return (msg.lParam);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
380 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
381
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
382
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
383 /*
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
384 * Handle a request from the main thread to do things that have to be
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
385 * done in the message-processing thread.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
386 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
387 static void
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
388 mswindows_handle_request (MSG *msg)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
389 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
390 mswindows_request_type *request = (mswindows_request_type *) msg->lParam;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
391
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
392 switch (msg->message)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
393 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
394 case WM_XEMACS_CREATEWINDOW:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
395 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
396 struct frame *f = request->thing1;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
397 Lisp_Object *props = request->thing2;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
398 Lisp_Object name, height, width, popup, top, left;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
399 RECT rect;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
400 DWORD style;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
401 HWND hwnd;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
402
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
403 name = Fplist_get (*props, Qname, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
404 height = Fplist_get (*props, Qheight, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
405 width = Fplist_get (*props, Qwidth, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
406 popup = Fplist_get (*props, Qpopup, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
407 top = Fplist_get (*props, Qtop, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
408 left = Fplist_get (*props, Qleft, Qnil);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
409
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
410 style = (NILP(popup)) ? MSWINDOWS_FRAME_STYLE : MSWINDOWS_POPUP_STYLE;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
411
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
412 rect.left = rect.top = 0;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
413 rect.right = INTP(width) ? XINT(width) : 640;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
414 rect.bottom = INTP(height) ? XINT(height) : 480;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
415 #ifdef HAVE_MENUBARS
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
416 AdjustWindowRect(&rect, style, TRUE);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
417 #else
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
418 AdjustWindowRect(&rect, style, FALSE);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
419 #endif
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
420
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
421 hwnd = CreateWindow (XEMACS_CLASS,
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
422 STRINGP(f->name) ? XSTRING_DATA(f->name) :
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
423 (STRINGP(name) ? XSTRING_DATA(name) : XEMACS_CLASS),
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
424 style,
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
425 INTP(left) ? XINT(left) : CW_USEDEFAULT,
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
426 INTP(top) ? XINT(top) : CW_USEDEFAULT,
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
427 rect.right-rect.left, rect.bottom-rect.top,
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
428 NULL, NULL, NULL, NULL);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
429 assert(PostThreadMessage (mswindows_main_thread_id, WM_XEMACS_ACK, 0, (LPARAM) hwnd));
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
430 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
431 return;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
432
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
433 case WM_XEMACS_SETTIMER:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
434 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
435 UINT id;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
436 id=SetTimer (NULL, 0, (UINT) request->thing1, NULL);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
437 assert(PostThreadMessage (mswindows_main_thread_id, WM_XEMACS_ACK, 0, id));
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
438 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
439 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
440
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
441 case WM_XEMACS_KILLTIMER:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
442 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
443 KillTimer (NULL, (UINT) request->thing1);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
444 assert(PostThreadMessage (mswindows_main_thread_id, WM_XEMACS_ACK, 0, 0));
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
445 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
446 break;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
447
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
448 default:
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
449 assert(0);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
450 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
451 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
452
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
453
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
454 /*
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
455 * Translate a mswindows virtual key to a keysym.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
456 * Only returns non-Qnil for keys that don't generate WM_CHAR messages
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
457 * or whose ASCII codes (like space) xemacs doesn't like.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
458 * Virtual key values are defined in winresrc.h
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
459 * XXX I'm not sure that KEYSYM("name") is the best thing to use here.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
460 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
461 Lisp_Object mswindows_key_to_emacs_keysym(int mswindows_key)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
462 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
463 switch (mswindows_key)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
464 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
465 /* First the predefined ones */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
466 case VK_BACK: return QKbackspace;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
467 case VK_TAB: return QKtab;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
468 case '\n': return QKlinefeed; /* No VK_LINEFEED in winresrc.h */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
469 case VK_RETURN: return QKreturn;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
470 case VK_ESCAPE: return QKescape;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
471 case VK_SPACE: return QKspace;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
472 case VK_DELETE: return QKdelete;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
473
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
474 /* The rest */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
475 case VK_PRIOR: return KEYSYM ("prior");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
476 case VK_NEXT: return KEYSYM ("next");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
477 case VK_END: return KEYSYM ("end");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
478 case VK_HOME: return KEYSYM ("home");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
479 case VK_LEFT: return KEYSYM ("left");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
480 case VK_UP: return KEYSYM ("up");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
481 case VK_RIGHT: return KEYSYM ("right");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
482 case VK_DOWN: return KEYSYM ("down");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
483 case VK_INSERT: return KEYSYM ("insert");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
484 case VK_HELP: return KEYSYM ("help");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
485 case VK_F1: return KEYSYM ("F1");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
486 case VK_F2: return KEYSYM ("F2");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
487 case VK_F3: return KEYSYM ("F3");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
488 case VK_F4: return KEYSYM ("F4");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
489 case VK_F5: return KEYSYM ("F5");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
490 case VK_F6: return KEYSYM ("F6");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
491 case VK_F7: return KEYSYM ("F7");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
492 case VK_F8: return KEYSYM ("F8");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
493 case VK_F9: return KEYSYM ("F9");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
494 case VK_F10: return KEYSYM ("F10");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
495 case VK_F11: return KEYSYM ("F11");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
496 case VK_F12: return KEYSYM ("F12");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
497 case VK_F13: return KEYSYM ("F13");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
498 case VK_F14: return KEYSYM ("F14");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
499 case VK_F15: return KEYSYM ("F15");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
500 case VK_F16: return KEYSYM ("F16");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
501 case VK_F17: return KEYSYM ("F17");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
502 case VK_F18: return KEYSYM ("F18");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
503 case VK_F19: return KEYSYM ("F19");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
504 case VK_F20: return KEYSYM ("F20");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
505 case VK_F21: return KEYSYM ("F21");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
506 case VK_F22: return KEYSYM ("F22");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
507 case VK_F23: return KEYSYM ("F23");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
508 case VK_F24: return KEYSYM ("F24");
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
509 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
510 return Qnil;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
511 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
512
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
513
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
514 /*
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
515 * Find the console that matches the supplied mswindows window handle
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
516 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
517 static Lisp_Object
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
518 mswindows_find_console (HWND hwnd)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
519 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
520 Lisp_Object concons;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
521
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
522 CONSOLE_LOOP (concons)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
523 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
524 Lisp_Object console = XCAR (concons);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
525 /* We only support one console so this must be it */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
526 return console;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
527 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
528
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
529 return Qnil;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
530 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
531
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
532 /*
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
533 * Find the frame that matches the supplied mswindows window handle
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
534 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
535 static Lisp_Object
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
536 mswindows_find_frame (HWND hwnd)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
537 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
538 Lisp_Object frmcons, devcons, concons;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
539
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
540 FRAME_LOOP_NO_BREAK (frmcons, devcons, concons)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
541 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
542 struct frame *f;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
543 Lisp_Object frame = XCAR (frmcons);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
544 f = XFRAME (frame);
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
545 if (FRAME_TYPE_P(f, mswindows)) /* Might be a stream-type frame */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
546 if (FRAME_MSWINDOWS_HANDLE(f)==hwnd)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
547 return frame;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
548 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
549 assert(0); /* XXX Can't happen! we only get messages for our windows */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
550 return Qnil;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
551 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
552
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
553 /*
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
554 * Random helper functions for debugging.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
555 * Intended for use in the MSVC "Watch" window which doesn't like
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
556 * the aborts that the error_check_foo() functions can make.
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
557 */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
558 struct lrecord_header *DHEADER(Lisp_Object obj)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
559 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
560 return LRECORDP(obj) ? XRECORD_LHEADER(obj) : NULL;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
561 /* (lrecord_header*)(obj & 0xfffffff) */
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
562 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
563
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
564 struct Lisp_Event *DEVENT(Lisp_Object obj)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
565 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
566 return (EVENTP (obj)) ? XEVENT(obj) : NULL;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
567 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
568
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
569 struct Lisp_Cons *DCONS(Lisp_Object obj)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
570 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
571 return (CONSP (obj)) ? XCONS(obj) : NULL;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
572 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
573
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
574 Lisp_Object DCAR(Lisp_Object obj)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
575 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
576 return (CONSP (obj)) ? XCAR(obj) : 0;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
577 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
578
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
579 Lisp_Object DCDR(Lisp_Object obj)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
580 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
581 return (CONSP (obj)) ? XCDR(obj) : 0;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
582 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
583
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
584 char *DSTRING(Lisp_Object obj)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
585 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
586 return (STRINGP (obj)) ? XSTRING_DATA(obj) : NULL;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
587 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
588
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
589 struct Lisp_Vector *DVECTOR(Lisp_Object obj)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
590 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
591 return (VECTORP (obj)) ? XVECTOR(obj) : NULL;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
592 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
593
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
594 struct Lisp_Symbol *DSYMBOL(Lisp_Object obj)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
595 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
596 return (SYMBOLP (obj)) ? XSYMBOL(obj) : NULL;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
597 }
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
598
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
599 char *DSYMNAME(Lisp_Object obj)
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
600 {
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
601 return (SYMBOLP (obj)) ? XSYMBOL(obj)->name->_data : NULL;
78f53ef88e17 Import from CVS: tag r20-4b5
cvs
parents:
diff changeset
602 }