Skip to content

Latest commit

 

History

History
214 lines (176 loc) · 5.85 KB

SDL_syswm.h

File metadata and controls

214 lines (176 loc) · 5.85 KB
 
Apr 26, 2001
Apr 26, 2001
1
2
/*
SDL - Simple DirectMedia Layer
Feb 1, 2006
Feb 1, 2006
3
Copyright (C) 1997-2006 Sam Lantinga
Apr 26, 2001
Apr 26, 2001
4
5
This library is free software; you can redistribute it and/or
Feb 1, 2006
Feb 1, 2006
6
modify it under the terms of the GNU Lesser General Public
Apr 26, 2001
Apr 26, 2001
7
License as published by the Free Software Foundation; either
Feb 1, 2006
Feb 1, 2006
8
version 2.1 of the License, or (at your option) any later version.
Apr 26, 2001
Apr 26, 2001
9
10
11
12
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Feb 1, 2006
Feb 1, 2006
13
Lesser General Public License for more details.
Apr 26, 2001
Apr 26, 2001
14
Feb 1, 2006
Feb 1, 2006
15
16
17
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
Apr 26, 2001
Apr 26, 2001
18
19
Sam Lantinga
Dec 14, 2001
Dec 14, 2001
20
slouken@libsdl.org
Apr 26, 2001
Apr 26, 2001
21
22
23
24
25
26
27
*/
/* Include file for SDL custom system window manager hooks */
#ifndef _SDL_syswm_h
#define _SDL_syswm_h
Feb 10, 2006
Feb 10, 2006
28
#include "SDL_stdinc.h"
Feb 10, 2006
Feb 10, 2006
29
#include "SDL_error.h"
Apr 26, 2001
Apr 26, 2001
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#include "SDL_version.h"
#include "begin_code.h"
/* Set up for C function definitions, even when using C++ */
#ifdef __cplusplus
extern "C" {
#endif
/* Your application has access to a special type of event 'SDL_SYSWMEVENT',
which contains window-manager specific information and arrives whenever
an unhandled window event occurs. This event is ignored by default, but
you can enable it with SDL_EventState()
*/
#ifdef SDL_PROTOTYPES_ONLY
struct SDL_SysWMinfo;
typedef struct SDL_SysWMinfo SDL_SysWMinfo;
#else
Feb 16, 2006
Feb 16, 2006
48
/* This is the structure for custom window manager events */
Apr 13, 2006
Apr 13, 2006
49
#if defined(SDL_VIDEO_DRIVER_X11)
Sep 8, 2005
Sep 8, 2005
50
#if defined(__APPLE__) && defined(__MACH__)
Mar 9, 2006
Mar 9, 2006
51
/* conflicts with Quickdraw.h */
Sep 8, 2005
Sep 8, 2005
52
53
54
#define Cursor X11Cursor
#endif
Apr 26, 2001
Apr 26, 2001
55
56
57
#include <X11/Xlib.h>
#include <X11/Xatom.h>
Sep 8, 2005
Sep 8, 2005
58
#if defined(__APPLE__) && defined(__MACH__)
Mar 9, 2006
Mar 9, 2006
59
/* matches the re-define above */
Sep 8, 2005
Sep 8, 2005
60
61
62
#undef Cursor
#endif
Apr 26, 2001
Apr 26, 2001
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
/* These are the various supported subsystems under UNIX */
typedef enum {
SDL_SYSWM_X11
} SDL_SYSWM_TYPE;
/* The UNIX custom event structure */
struct SDL_SysWMmsg {
SDL_version version;
SDL_SYSWM_TYPE subsystem;
union {
XEvent xevent;
} event;
};
/* The UNIX custom window manager information structure.
When this structure is returned, it holds information about which
low level system it is using, and will be one of SDL_SYSWM_TYPE.
*/
Jul 18, 2004
Jul 18, 2004
81
typedef struct SDL_SysWMinfo {
Apr 26, 2001
Apr 26, 2001
82
83
84
85
86
87
88
SDL_version version;
SDL_SYSWM_TYPE subsystem;
union {
struct {
Display *display; /* The X11 display */
Window window; /* The X11 display window */
/* These locking functions should be called around
Sep 24, 2006
Sep 24, 2006
89
90
any X11 functions using the display variable,
but not the gfxdisplay variable.
Apr 26, 2001
Apr 26, 2001
91
92
93
94
95
96
97
98
99
They lock the event thread, so should not be
called around event functions or from event filters.
*/
void (*lock_func)(void);
void (*unlock_func)(void);
/* Introduced in SDL 1.0.2 */
Window fswindow; /* The X11 fullscreen window */
Window wmwindow; /* The X11 managed input window */
Sep 24, 2006
Sep 24, 2006
100
101
102
/* Introduced in SDL 1.2.12 */
Display *gfxdisplay; /* The X11 display to which rendering is done */
Apr 26, 2001
Apr 26, 2001
103
104
105
106
} x11;
} info;
} SDL_SysWMinfo;
Apr 13, 2006
Apr 13, 2006
107
#elif defined(SDL_VIDEO_DRIVER_NANOX)
May 11, 2001
May 11, 2001
108
109
110
111
112
113
114
115
116
#include <microwin/nano-X.h>
/* The generic custom event structure */
struct SDL_SysWMmsg {
SDL_version version;
int data;
};
/* The windows custom window manager information structure */
Jul 18, 2004
Jul 18, 2004
117
typedef struct SDL_SysWMinfo {
May 11, 2001
May 11, 2001
118
119
120
121
SDL_version version ;
GR_WINDOW_ID window ; /* The display window */
} SDL_SysWMinfo;
May 3, 2006
May 3, 2006
122
#elif defined(SDL_VIDEO_DRIVER_WINDIB) || defined(SDL_VIDEO_DRIVER_DDRAW) || defined(SDL_VIDEO_DRIVER_GAPI)
Feb 25, 2006
Feb 25, 2006
123
124
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
Apr 26, 2001
Apr 26, 2001
125
126
127
128
129
130
131
132
133
134
135
/* The windows custom event structure */
struct SDL_SysWMmsg {
SDL_version version;
HWND hwnd; /* The window for the message */
UINT msg; /* The type of message */
WPARAM wParam; /* WORD message parameter */
LPARAM lParam; /* LONG message parameter */
};
/* The windows custom window manager information structure */
Jul 18, 2004
Jul 18, 2004
136
typedef struct SDL_SysWMinfo {
Apr 26, 2001
Apr 26, 2001
137
138
SDL_version version;
HWND window; /* The Win32 display window */
Aug 17, 2002
Aug 17, 2002
139
HGLRC hglrc; /* The OpenGL context, if any */
Apr 26, 2001
Apr 26, 2001
140
141
} SDL_SysWMinfo;
Apr 13, 2006
Apr 13, 2006
142
#elif defined(SDL_VIDEO_DRIVER_RISCOS)
May 29, 2003
May 29, 2003
143
144
145
146
147
148
149
150
/* RISC OS custom event structure */
struct SDL_SysWMmsg {
SDL_version version;
int eventCode; /* The window for the message */
int pollBlock[64];
};
Feb 12, 2005
Feb 12, 2005
151
/* The RISC OS custom window manager information structure */
Jul 18, 2004
Jul 18, 2004
152
typedef struct SDL_SysWMinfo {
May 29, 2003
May 29, 2003
153
154
SDL_version version;
int wimpVersion; /* Wimp version running under */
Feb 12, 2005
Feb 12, 2005
155
156
int taskHandle; /* The RISC OS task handle */
int window; /* The RISC OS display window */
May 29, 2003
May 29, 2003
157
158
} SDL_SysWMinfo;
Apr 13, 2006
Apr 13, 2006
159
#elif defined(SDL_VIDEO_DRIVER_PHOTON)
Mar 4, 2004
Mar 4, 2004
160
161
162
163
164
165
166
167
168
169
#include <sys/neutrino.h>
#include <Ph.h>
/* The QNX custom event structure */
struct SDL_SysWMmsg {
SDL_version version;
int data;
};
/* The QNX custom window manager information structure */
Jul 18, 2004
Jul 18, 2004
170
typedef struct SDL_SysWMinfo {
Mar 4, 2004
Mar 4, 2004
171
172
173
174
SDL_version version;
int data;
} SDL_SysWMinfo;
Apr 26, 2001
Apr 26, 2001
175
176
177
178
179
180
181
182
183
#else
/* The generic custom event structure */
struct SDL_SysWMmsg {
SDL_version version;
int data;
};
/* The generic custom window manager information structure */
Jul 18, 2004
Jul 18, 2004
184
typedef struct SDL_SysWMinfo {
Apr 26, 2001
Apr 26, 2001
185
186
187
188
SDL_version version;
int data;
} SDL_SysWMinfo;
Feb 16, 2006
Feb 16, 2006
189
#endif /* video driver type */
Apr 26, 2001
Apr 26, 2001
190
191
192
193
194
195
196
197
198
#endif /* SDL_PROTOTYPES_ONLY */
/* Function prototypes */
/*
* This function gives you custom hooks into the window manager information.
* It fills the structure pointed to by 'info' with custom information and
* returns 1 if the function is implemented. If it's not implemented, or
* the version member of the 'info' structure is invalid, it returns 0.
Nov 30, 2004
Nov 30, 2004
199
200
201
202
203
*
* You typically use this function like this:
* SDL_SysWMInfo info;
* SDL_VERSION(&info.version);
* if ( SDL_GetWMInfo(&info) ) { ... }
Apr 26, 2001
Apr 26, 2001
204
*/
Apr 11, 2002
Apr 11, 2002
205
extern DECLSPEC int SDLCALL SDL_GetWMInfo(SDL_SysWMinfo *info);
Apr 26, 2001
Apr 26, 2001
206
207
208
209
210
211
212
213
214
/* Ends C function definitions when using C++ */
#ifdef __cplusplus
}
#endif
#include "close_code.h"
#endif /* _SDL_syswm_h */