Skip to content
This repository has been archived by the owner on Feb 11, 2021. It is now read-only.

Latest commit

 

History

History
1805 lines (1576 loc) · 43.1 KB

SDL_video.c

File metadata and controls

1805 lines (1576 loc) · 43.1 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
*/
Feb 21, 2006
Feb 21, 2006
22
#include "SDL_config.h"
Apr 26, 2001
Apr 26, 2001
23
24
25
26
27
28
29
30
/* The high-level video driver subsystem */
#include "SDL.h"
#include "SDL_sysvideo.h"
#include "SDL_blit.h"
#include "SDL_pixels_c.h"
#include "SDL_cursor_c.h"
Feb 16, 2006
Feb 16, 2006
31
32
#include "../events/SDL_sysevents.h"
#include "../events/SDL_events_c.h"
Apr 26, 2001
Apr 26, 2001
33
34
35
/* Available video drivers */
static VideoBootStrap *bootstrap[] = {
Feb 16, 2006
Feb 16, 2006
36
#if SDL_VIDEO_DRIVER_QUARTZ
May 28, 2006
May 28, 2006
37
&QZ_bootstrap,
Sep 8, 2005
Sep 8, 2005
38
#endif
Feb 16, 2006
Feb 16, 2006
39
#if SDL_VIDEO_DRIVER_X11
May 28, 2006
May 28, 2006
40
&X11_bootstrap,
Apr 26, 2001
Apr 26, 2001
41
#endif
Feb 16, 2006
Feb 16, 2006
42
#if SDL_VIDEO_DRIVER_DGA
May 28, 2006
May 28, 2006
43
&DGA_bootstrap,
Apr 26, 2001
Apr 26, 2001
44
#endif
Feb 16, 2006
Feb 16, 2006
45
#if SDL_VIDEO_DRIVER_NANOX
May 28, 2006
May 28, 2006
46
&NX_bootstrap,
May 11, 2001
May 11, 2001
47
#endif
Feb 16, 2006
Feb 16, 2006
48
#if SDL_VIDEO_DRIVER_IPOD
May 28, 2006
May 28, 2006
49
&iPod_bootstrap,
Sep 8, 2005
Sep 8, 2005
50
#endif
Feb 16, 2006
Feb 16, 2006
51
#if SDL_VIDEO_DRIVER_QTOPIA
May 28, 2006
May 28, 2006
52
&Qtopia_bootstrap,
Jan 20, 2003
Jan 20, 2003
53
#endif
Feb 16, 2006
Feb 16, 2006
54
#if SDL_VIDEO_DRIVER_WSCONS
May 28, 2006
May 28, 2006
55
&WSCONS_bootstrap,
Nov 22, 2005
Nov 22, 2005
56
#endif
Feb 16, 2006
Feb 16, 2006
57
#if SDL_VIDEO_DRIVER_FBCON
May 28, 2006
May 28, 2006
58
&FBCON_bootstrap,
Apr 26, 2001
Apr 26, 2001
59
#endif
Feb 16, 2006
Feb 16, 2006
60
#if SDL_VIDEO_DRIVER_DIRECTFB
May 28, 2006
May 28, 2006
61
&DirectFB_bootstrap,
Sep 4, 2001
Sep 4, 2001
62
#endif
Feb 16, 2006
Feb 16, 2006
63
#if SDL_VIDEO_DRIVER_PS2GS
May 28, 2006
May 28, 2006
64
&PS2GS_bootstrap,
Apr 26, 2001
Apr 26, 2001
65
#endif
Feb 16, 2006
Feb 16, 2006
66
#if SDL_VIDEO_DRIVER_GGI
May 28, 2006
May 28, 2006
67
&GGI_bootstrap,
Apr 26, 2001
Apr 26, 2001
68
#endif
Feb 16, 2006
Feb 16, 2006
69
#if SDL_VIDEO_DRIVER_VGL
May 28, 2006
May 28, 2006
70
&VGL_bootstrap,
Jun 19, 2001
Jun 19, 2001
71
#endif
Feb 16, 2006
Feb 16, 2006
72
#if SDL_VIDEO_DRIVER_SVGALIB
May 28, 2006
May 28, 2006
73
&SVGALIB_bootstrap,
Apr 26, 2001
Apr 26, 2001
74
#endif
Feb 16, 2006
Feb 16, 2006
75
#if SDL_VIDEO_DRIVER_GAPI
May 28, 2006
May 28, 2006
76
&GAPI_bootstrap,
Jan 19, 2006
Jan 19, 2006
77
#endif
Feb 16, 2006
Feb 16, 2006
78
#if SDL_VIDEO_DRIVER_WINDIB
May 28, 2006
May 28, 2006
79
&WINDIB_bootstrap,
Apr 26, 2001
Apr 26, 2001
80
#endif
Feb 16, 2006
Feb 16, 2006
81
#if SDL_VIDEO_DRIVER_DDRAW
May 28, 2006
May 28, 2006
82
&DIRECTX_bootstrap,
Jan 1, 2006
Jan 1, 2006
83
#endif
Feb 16, 2006
Feb 16, 2006
84
#if SDL_VIDEO_DRIVER_BWINDOW
May 28, 2006
May 28, 2006
85
&BWINDOW_bootstrap,
Apr 26, 2001
Apr 26, 2001
86
#endif
Feb 16, 2006
Feb 16, 2006
87
#if SDL_VIDEO_DRIVER_TOOLBOX
May 28, 2006
May 28, 2006
88
&TOOLBOX_bootstrap,
Apr 26, 2001
Apr 26, 2001
89
#endif
Feb 16, 2006
Feb 16, 2006
90
#if SDL_VIDEO_DRIVER_DRAWSPROCKET
May 28, 2006
May 28, 2006
91
&DSp_bootstrap,
Apr 26, 2001
Apr 26, 2001
92
#endif
Feb 16, 2006
Feb 16, 2006
93
#if SDL_VIDEO_DRIVER_CYBERGRAPHICS
May 28, 2006
May 28, 2006
94
&CGX_bootstrap,
Apr 26, 2001
Apr 26, 2001
95
#endif
Feb 16, 2006
Feb 16, 2006
96
#if SDL_VIDEO_DRIVER_PHOTON
May 28, 2006
May 28, 2006
97
&ph_bootstrap,
Sep 11, 2001
Sep 11, 2001
98
#endif
Feb 16, 2006
Feb 16, 2006
99
#if SDL_VIDEO_DRIVER_EPOC
May 28, 2006
May 28, 2006
100
&EPOC_bootstrap,
Sep 11, 2001
Sep 11, 2001
101
#endif
Feb 16, 2006
Feb 16, 2006
102
#if SDL_VIDEO_DRIVER_XBIOS
May 28, 2006
May 28, 2006
103
&XBIOS_bootstrap,
Feb 17, 2002
Feb 17, 2002
104
#endif
Feb 16, 2006
Feb 16, 2006
105
#if SDL_VIDEO_DRIVER_GEM
May 28, 2006
May 28, 2006
106
&GEM_bootstrap,
May 19, 2002
May 19, 2002
107
#endif
Feb 16, 2006
Feb 16, 2006
108
#if SDL_VIDEO_DRIVER_PICOGUI
May 28, 2006
May 28, 2006
109
&PG_bootstrap,
Oct 5, 2002
Oct 5, 2002
110
#endif
Feb 16, 2006
Feb 16, 2006
111
#if SDL_VIDEO_DRIVER_DC
May 28, 2006
May 28, 2006
112
&DC_bootstrap,
Apr 15, 2003
Apr 15, 2003
113
#endif
Feb 16, 2006
Feb 16, 2006
114
#if SDL_VIDEO_DRIVER_RISCOS
May 28, 2006
May 28, 2006
115
&RISCOS_bootstrap,
May 29, 2003
May 29, 2003
116
#endif
Feb 16, 2006
Feb 16, 2006
117
#if SDL_VIDEO_DRIVER_OS2FS
May 28, 2006
May 28, 2006
118
&OS2FSLib_bootstrap,
Nov 23, 2005
Nov 23, 2005
119
#endif
Feb 16, 2006
Feb 16, 2006
120
#if SDL_VIDEO_DRIVER_AALIB
May 28, 2006
May 28, 2006
121
&AALIB_bootstrap,
Feb 16, 2006
Feb 16, 2006
122
123
#endif
#if SDL_VIDEO_DRIVER_DUMMY
May 28, 2006
May 28, 2006
124
&DUMMY_bootstrap,
May 1, 2006
May 1, 2006
125
126
#endif
#if SDL_VIDEO_DRIVER_GLSDL
May 28, 2006
May 28, 2006
127
&glSDL_bootstrap,
Apr 26, 2001
Apr 26, 2001
128
#endif
May 28, 2006
May 28, 2006
129
NULL
Apr 26, 2001
Apr 26, 2001
130
};
Sep 11, 2001
Sep 11, 2001
131
May 28, 2006
May 28, 2006
132
static SDL_VideoDevice *_this = NULL;
Apr 26, 2001
Apr 26, 2001
133
134
/* Various local functions */
May 29, 2006
May 29, 2006
135
136
int SDL_VideoInit(const char *driver_name, Uint32 flags);
void SDL_VideoQuit(void);
Apr 26, 2001
Apr 26, 2001
137
May 28, 2006
May 28, 2006
138
static int
May 29, 2006
May 29, 2006
139
cmpmodes(const void *A, const void *B)
May 28, 2006
May 28, 2006
140
141
142
143
144
145
146
147
148
149
{
SDL_DisplayMode a = *(const SDL_DisplayMode *) A;
SDL_DisplayMode b = *(const SDL_DisplayMode *) B;
if (a.w != b.w) {
return b.w - a.w;
}
if (a.h != b.h) {
return b.h - a.h;
}
May 29, 2006
May 29, 2006
150
151
if (SDL_BITSPERPIXEL(a.format) != SDL_BITSPERPIXEL(b.format)) {
return SDL_BITSPERPIXEL(b.format) - SDL_BITSPERPIXEL(a.format);
May 28, 2006
May 28, 2006
152
153
154
155
156
157
}
if (a.refresh_rate != b.refresh_rate) {
return b.refresh_rate - a.refresh_rate;
}
return 0;
}
Apr 26, 2001
Apr 26, 2001
158
May 28, 2006
May 28, 2006
159
int
May 29, 2006
May 29, 2006
160
SDL_GetNumVideoDrivers(void)
May 20, 2006
May 20, 2006
161
{
May 29, 2006
May 29, 2006
162
return SDL_arraysize(bootstrap) - 1;
May 20, 2006
May 20, 2006
163
164
}
May 28, 2006
May 28, 2006
165
const char *
May 29, 2006
May 29, 2006
166
SDL_GetVideoDriver(int index)
May 20, 2006
May 20, 2006
167
{
May 29, 2006
May 29, 2006
168
if (index >= 0 && index < SDL_GetNumVideoDrivers()) {
May 28, 2006
May 28, 2006
169
170
171
return bootstrap[index]->name;
}
return NULL;
May 20, 2006
May 20, 2006
172
}
Apr 26, 2001
Apr 26, 2001
173
174
175
176
/*
* Initialize the video and event subsystems -- determine native pixel format
*/
May 28, 2006
May 28, 2006
177
int
May 29, 2006
May 29, 2006
178
SDL_VideoInit(const char *driver_name, Uint32 flags)
Apr 26, 2001
Apr 26, 2001
179
{
May 28, 2006
May 28, 2006
180
181
182
183
184
SDL_VideoDevice *video;
int index;
int i;
int bpp;
Uint32 Rmask, Gmask, Bmask, Amask;
Apr 26, 2001
Apr 26, 2001
185
May 28, 2006
May 28, 2006
186
/* Toggle the event thread flags, based on OS requirements */
Apr 26, 2001
Apr 26, 2001
187
#if defined(MUST_THREAD_EVENTS)
May 28, 2006
May 28, 2006
188
flags |= SDL_INIT_EVENTTHREAD;
Apr 26, 2001
Apr 26, 2001
189
#elif defined(CANT_THREAD_EVENTS)
May 28, 2006
May 28, 2006
190
if ((flags & SDL_INIT_EVENTTHREAD) == SDL_INIT_EVENTTHREAD) {
May 29, 2006
May 29, 2006
191
SDL_SetError("OS doesn't support threaded events");
May 28, 2006
May 28, 2006
192
193
return -1;
}
Apr 26, 2001
Apr 26, 2001
194
195
#endif
May 28, 2006
May 28, 2006
196
197
/* Check to make sure we don't overwrite '_this' */
if (_this != NULL) {
May 29, 2006
May 29, 2006
198
SDL_VideoQuit();
May 28, 2006
May 28, 2006
199
200
201
202
203
204
205
}
/* Select the proper video driver */
index = 0;
video = NULL;
if (driver_name != NULL) {
for (i = 0; bootstrap[i]; ++i) {
May 29, 2006
May 29, 2006
206
207
208
209
if (SDL_strncmp(bootstrap[i]->name, driver_name,
SDL_strlen(bootstrap[i]->name)) == 0) {
if (bootstrap[i]->available()) {
video = bootstrap[i]->create(index);
May 28, 2006
May 28, 2006
210
211
212
213
214
215
}
break;
}
}
} else {
for (i = 0; bootstrap[i]; ++i) {
May 29, 2006
May 29, 2006
216
217
if (bootstrap[i]->available()) {
video = bootstrap[i]->create(index);
May 28, 2006
May 28, 2006
218
219
220
221
222
223
224
225
if (video != NULL) {
break;
}
}
}
}
if (video == NULL) {
if (driver_name) {
May 29, 2006
May 29, 2006
226
SDL_SetError("%s not available", driver_name);
May 28, 2006
May 28, 2006
227
} else {
May 29, 2006
May 29, 2006
228
SDL_SetError("No available video device");
May 28, 2006
May 28, 2006
229
230
231
232
233
}
return -1;
}
_this = video;
_this->name = bootstrap[i]->name;
Jun 7, 2006
Jun 7, 2006
234
_this->next_object_id = 1;
May 28, 2006
May 28, 2006
235
May 29, 2006
May 29, 2006
236
May 28, 2006
May 28, 2006
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
/* Set some very sane GL defaults */
_this->gl_config.driver_loaded = 0;
_this->gl_config.dll_handle = NULL;
_this->gl_config.red_size = 3;
_this->gl_config.green_size = 3;
_this->gl_config.blue_size = 2;
_this->gl_config.alpha_size = 0;
_this->gl_config.buffer_size = 0;
_this->gl_config.depth_size = 16;
_this->gl_config.stencil_size = 0;
_this->gl_config.double_buffer = 1;
_this->gl_config.accum_red_size = 0;
_this->gl_config.accum_green_size = 0;
_this->gl_config.accum_blue_size = 0;
_this->gl_config.accum_alpha_size = 0;
_this->gl_config.stereo = 0;
_this->gl_config.multisamplebuffers = 0;
_this->gl_config.multisamplesamples = 0;
_this->gl_config.accelerated = -1; /* not known, don't set */
_this->gl_config.swap_control = -1; /* not known, don't set */
/* Initialize the video subsystem */
May 29, 2006
May 29, 2006
259
260
if (_this->VideoInit(_this) < 0) {
SDL_VideoQuit();
May 28, 2006
May 28, 2006
261
262
263
264
265
return -1;
}
/* Make sure some displays were added */
if (_this->num_displays == 0) {
May 29, 2006
May 29, 2006
266
267
SDL_SetError("The video driver did not add any displays");
SDL_VideoQuit();
May 28, 2006
May 28, 2006
268
269
270
271
272
return (-1);
}
/* Sort the video modes */
for (i = 0; i < _this->num_displays; ++i) {
May 29, 2006
May 29, 2006
273
274
275
SDL_qsort(_this->displays[i].display_modes,
_this->displays[i].num_display_modes,
sizeof(SDL_DisplayMode), cmpmodes);
May 28, 2006
May 28, 2006
276
277
278
}
/* Start the event loop */
May 29, 2006
May 29, 2006
279
280
if (SDL_StartEventLoop(flags) < 0) {
SDL_VideoQuit();
May 28, 2006
May 28, 2006
281
282
return -1;
}
May 29, 2006
May 29, 2006
283
SDL_CursorInit(flags & SDL_INIT_EVENTTHREAD);
May 28, 2006
May 28, 2006
284
285
286
287
/* We're ready to go! */
return 0;
}
Apr 26, 2001
Apr 26, 2001
288
May 28, 2006
May 28, 2006
289
const char *
May 29, 2006
May 29, 2006
290
SDL_GetCurrentVideoDriver()
May 28, 2006
May 28, 2006
291
292
293
294
295
296
{
if (!_this) {
return NULL;
}
return _this->name;
}
Apr 26, 2001
Apr 26, 2001
297
May 28, 2006
May 28, 2006
298
SDL_VideoDevice *
May 29, 2006
May 29, 2006
299
SDL_GetVideoDevice()
May 28, 2006
May 28, 2006
300
301
{
return _this;
Apr 26, 2001
Apr 26, 2001
302
303
}
May 28, 2006
May 28, 2006
304
void
May 29, 2006
May 29, 2006
305
SDL_AddBasicVideoDisplay(const SDL_DisplayMode * desktop_mode)
Apr 26, 2001
Apr 26, 2001
306
{
May 28, 2006
May 28, 2006
307
308
SDL_VideoDisplay display;
May 29, 2006
May 29, 2006
309
SDL_zero(display);
May 28, 2006
May 28, 2006
310
311
312
313
if (desktop_mode) {
display.desktop_mode = *desktop_mode;
}
display.current_mode = display.desktop_mode;
Apr 26, 2001
Apr 26, 2001
314
May 29, 2006
May 29, 2006
315
SDL_AddVideoDisplay(&display);
Apr 26, 2001
Apr 26, 2001
316
317
}
May 28, 2006
May 28, 2006
318
void
May 29, 2006
May 29, 2006
319
SDL_AddVideoDisplay(const SDL_VideoDisplay * display)
Apr 26, 2001
Apr 26, 2001
320
{
May 28, 2006
May 28, 2006
321
322
323
SDL_VideoDisplay *displays;
displays =
May 29, 2006
May 29, 2006
324
325
SDL_realloc(_this->displays,
(_this->num_displays + 1) * sizeof(*displays));
May 28, 2006
May 28, 2006
326
327
328
329
330
331
if (displays) {
displays[_this->num_displays] = *display;
_this->displays = displays;
_this->num_displays++;
}
}
Apr 26, 2001
Apr 26, 2001
332
May 28, 2006
May 28, 2006
333
int
May 29, 2006
May 29, 2006
334
SDL_GetNumVideoDisplays(void)
May 28, 2006
May 28, 2006
335
336
337
338
339
{
if (!_this) {
return 0;
}
return _this->num_displays;
Apr 26, 2001
Apr 26, 2001
340
341
}
May 28, 2006
May 28, 2006
342
int
May 29, 2006
May 29, 2006
343
SDL_SelectVideoDisplay(int index)
Apr 26, 2001
Apr 26, 2001
344
{
May 28, 2006
May 28, 2006
345
if (!_this) {
May 29, 2006
May 29, 2006
346
SDL_SetError("Video subsystem has not been initialized");
May 28, 2006
May 28, 2006
347
348
349
350
return (-1);
}
if (index >= 0) {
if (index >= _this->num_displays) {
May 29, 2006
May 29, 2006
351
352
SDL_SetError("index must be in the range 0 - %d",
_this->num_displays - 1);
May 28, 2006
May 28, 2006
353
354
355
356
357
return -1;
}
_this->current_display = index;
}
return _this->current_display;
Apr 26, 2001
Apr 26, 2001
358
359
}
May 28, 2006
May 28, 2006
360
void
Jun 7, 2006
Jun 7, 2006
361
SDL_AddDisplayMode(int displayIndex, const SDL_DisplayMode * mode)
May 28, 2006
May 28, 2006
362
{
Jun 7, 2006
Jun 7, 2006
363
SDL_VideoDisplay *display = &_this->displays[displayIndex];
May 28, 2006
May 28, 2006
364
365
366
367
SDL_DisplayMode *modes;
int i, nmodes;
/* Make sure we don't already have the mode in the list */
Jun 7, 2006
Jun 7, 2006
368
369
modes = display->display_modes;
nmodes = display->num_display_modes;
May 28, 2006
May 28, 2006
370
for (i = 0; i < nmodes; ++i) {
May 29, 2006
May 29, 2006
371
if (SDL_memcmp(mode, &modes[i], sizeof(*mode)) == 0) {
May 28, 2006
May 28, 2006
372
373
374
375
376
return;
}
}
/* Go ahead and add the new mode */
May 29, 2006
May 29, 2006
377
modes = SDL_realloc(modes, (nmodes + 1) * sizeof(*mode));
May 28, 2006
May 28, 2006
378
if (modes) {
Jun 7, 2006
Jun 7, 2006
379
display->display_modes = modes;
May 28, 2006
May 28, 2006
380
modes[nmodes] = *mode;
Jun 7, 2006
Jun 7, 2006
381
display->num_display_modes++;
May 28, 2006
May 28, 2006
382
383
}
}
Apr 26, 2001
Apr 26, 2001
384
May 28, 2006
May 28, 2006
385
int
May 29, 2006
May 29, 2006
386
SDL_GetNumDisplayModes()
May 28, 2006
May 28, 2006
387
388
389
390
391
392
{
if (_this) {
return SDL_CurrentDisplay.num_display_modes;
}
return 0;
}
Feb 24, 2004
Feb 24, 2004
393
May 28, 2006
May 28, 2006
394
const SDL_DisplayMode *
May 29, 2006
May 29, 2006
395
SDL_GetDisplayMode(int index)
May 28, 2006
May 28, 2006
396
{
May 29, 2006
May 29, 2006
397
398
if (index < 0 || index >= SDL_GetNumDisplayModes()) {
SDL_SetError("index must be in the range of 0 - %d",
Jun 7, 2006
Jun 7, 2006
399
SDL_GetNumDisplayModes() - 1);
May 28, 2006
May 28, 2006
400
401
402
403
return NULL;
}
return &SDL_CurrentDisplay.display_modes[index];
}
Feb 24, 2004
Feb 24, 2004
404
May 28, 2006
May 28, 2006
405
const SDL_DisplayMode *
May 29, 2006
May 29, 2006
406
SDL_GetDesktopDisplayMode(void)
Apr 26, 2001
Apr 26, 2001
407
{
May 28, 2006
May 28, 2006
408
409
410
411
if (_this) {
return &SDL_CurrentDisplay.desktop_mode;
}
return NULL;
Apr 26, 2001
Apr 26, 2001
412
413
}
May 28, 2006
May 28, 2006
414
const SDL_DisplayMode *
May 29, 2006
May 29, 2006
415
SDL_GetCurrentDisplayMode(void)
Apr 26, 2001
Apr 26, 2001
416
{
May 28, 2006
May 28, 2006
417
418
419
420
if (_this) {
return &SDL_CurrentDisplay.current_mode;
}
return NULL;
Apr 26, 2001
Apr 26, 2001
421
422
}
May 28, 2006
May 28, 2006
423
SDL_DisplayMode *
May 29, 2006
May 29, 2006
424
425
SDL_GetClosestDisplayMode(const SDL_DisplayMode * mode,
SDL_DisplayMode * closest)
Apr 26, 2001
Apr 26, 2001
426
{
May 28, 2006
May 28, 2006
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
Uint32 target_format;
int target_refresh_rate;
int i;
SDL_DisplayMode *current, *match;
if (!_this || !mode || !closest) {
return NULL;
}
/* Default to the desktop format */
if (mode->format) {
target_format = mode->format;
} else {
target_format = SDL_CurrentDisplay.desktop_mode.format;
}
/* Default to the desktop refresh rate */
if (mode->refresh_rate) {
target_refresh_rate = mode->refresh_rate;
} else {
target_refresh_rate = SDL_CurrentDisplay.desktop_mode.refresh_rate;
}
match = NULL;
for (i = 0; i < SDL_CurrentDisplay.num_display_modes; ++i) {
current = &SDL_CurrentDisplay.display_modes[i];
if ((current->w && current->h) &&
(current->w < mode->w || current->h < mode->h)) {
/* Out of sorted modes large enough here */
break;
}
if (!match || current->w < match->w || current->h < match->h) {
match = current;
continue;
}
if (current->format != match->format) {
/* Sorted highest depth to lowest */
if (current->format == target_format ||
May 29, 2006
May 29, 2006
466
467
468
469
(SDL_BITSPERPIXEL(current->format) >=
SDL_BITSPERPIXEL(target_format)
&& SDL_PIXELTYPE(current->format) ==
SDL_PIXELTYPE(target_format))) {
May 28, 2006
May 28, 2006
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
match = current;
}
continue;
}
if (current->refresh_rate != match->refresh_rate) {
/* Sorted highest refresh to lowest */
if (current->refresh_rate >= target_refresh_rate) {
match = current;
}
}
}
if (match) {
if (match->format) {
closest->format = match->format;
} else {
closest->format = mode->format;
}
if (match->w && match->h) {
closest->w = match->w;
closest->h = match->h;
} else {
closest->w = mode->w;
closest->h = mode->h;
}
if (match->refresh_rate) {
closest->refresh_rate = match->refresh_rate;
} else {
closest->refresh_rate = mode->refresh_rate;
}
return closest;
}
return NULL;
Apr 26, 2001
Apr 26, 2001
502
503
}
May 28, 2006
May 28, 2006
504
int
May 29, 2006
May 29, 2006
505
SDL_SetDisplayMode(const SDL_DisplayMode * mode)
Apr 26, 2001
Apr 26, 2001
506
{
May 29, 2006
May 29, 2006
507
SDL_VideoDisplay *display;
May 28, 2006
May 28, 2006
508
SDL_DisplayMode display_mode;
May 29, 2006
May 29, 2006
509
int i;
May 28, 2006
May 28, 2006
510
511
if (!_this) {
May 29, 2006
May 29, 2006
512
SDL_SetError("Video subsystem has not been initialized");
May 28, 2006
May 28, 2006
513
514
515
516
517
return -1;
}
/* Make sure there's an actual display mode to set */
if (!mode) {
May 29, 2006
May 29, 2006
518
SDL_SetError("No mode passed to SDL_SetDisplayMode");
May 28, 2006
May 28, 2006
519
520
return -1;
}
May 29, 2006
May 29, 2006
521
display = &SDL_CurrentDisplay;
May 28, 2006
May 28, 2006
522
523
524
525
display_mode = *mode;
/* Default to the current mode */
if (!display_mode.format) {
May 29, 2006
May 29, 2006
526
display_mode.format = display->current_mode.format;
May 28, 2006
May 28, 2006
527
528
}
if (!display_mode.w) {
May 29, 2006
May 29, 2006
529
display_mode.w = display->current_mode.w;
May 28, 2006
May 28, 2006
530
531
}
if (!display_mode.h) {
May 29, 2006
May 29, 2006
532
display_mode.h = display->current_mode.h;
May 28, 2006
May 28, 2006
533
534
}
if (!display_mode.refresh_rate) {
May 29, 2006
May 29, 2006
535
display_mode.refresh_rate = display->current_mode.refresh_rate;
May 28, 2006
May 28, 2006
536
537
538
}
/* Get a good video mode, the closest one possible */
May 29, 2006
May 29, 2006
539
540
541
if (!SDL_GetClosestDisplayMode(&display_mode, &display_mode)) {
SDL_SetError("No video mode large enough for %dx%d",
display_mode.w, display_mode.h);
May 28, 2006
May 28, 2006
542
543
544
545
546
return -1;
}
/* See if there's anything left to do */
if (SDL_memcmp
May 29, 2006
May 29, 2006
547
548
(&display_mode, SDL_GetCurrentDisplayMode(),
sizeof(display_mode)) == 0) {
May 28, 2006
May 28, 2006
549
550
551
return 0;
}
May 29, 2006
May 29, 2006
552
return _this->SetDisplayMode(_this, &display_mode);
Apr 26, 2001
Apr 26, 2001
553
554
}
May 28, 2006
May 28, 2006
555
SDL_WindowID
May 29, 2006
May 29, 2006
556
SDL_CreateWindow(const char *title, int x, int y, int w, int h, Uint32 flags)
May 28, 2006
May 28, 2006
557
558
559
560
561
562
563
564
565
566
567
568
569
570
{
const Uint32 allowed_flags = (SDL_WINDOW_FULLSCREEN |
SDL_WINDOW_BORDERLESS |
SDL_WINDOW_SHOWN |
SDL_WINDOW_OPENGL |
SDL_WINDOW_RESIZABLE |
SDL_WINDOW_MAXIMIZED |
SDL_WINDOW_MINIMIZED |
SDL_WINDOW_INPUT_GRABBED);
SDL_Window window;
int num_windows;
SDL_Window *windows;
if (!_this) {
May 29, 2006
May 29, 2006
571
SDL_SetError("Video subsystem has not been initialized");
May 28, 2006
May 28, 2006
572
573
574
return 0;
}
May 29, 2006
May 29, 2006
575
SDL_zero(window);
Jun 7, 2006
Jun 7, 2006
576
window.id = _this->next_object_id++;
May 29, 2006
May 29, 2006
577
window.title = title ? SDL_strdup(title) : NULL;
May 28, 2006
May 28, 2006
578
579
580
581
582
583
window.x = x;
window.y = y;
window.w = w;
window.h = h;
window.flags = (flags & allowed_flags);
May 29, 2006
May 29, 2006
584
if (_this->CreateWindow && _this->CreateWindow(_this, &window) < 0) {
May 29, 2006
May 29, 2006
585
if (window.title) {
May 29, 2006
May 29, 2006
586
SDL_free(window.title);
May 29, 2006
May 29, 2006
587
}
May 28, 2006
May 28, 2006
588
589
590
591
592
return 0;
}
num_windows = SDL_CurrentDisplay.num_windows;
windows =
May 29, 2006
May 29, 2006
593
594
SDL_realloc(SDL_CurrentDisplay.windows,
(num_windows + 1) * sizeof(*windows));
May 28, 2006
May 28, 2006
595
596
if (!windows) {
if (_this->DestroyWindow) {
May 29, 2006
May 29, 2006
597
_this->DestroyWindow(_this, &window);
May 28, 2006
May 28, 2006
598
}
May 29, 2006
May 29, 2006
599
if (window.title) {
May 29, 2006
May 29, 2006
600
SDL_free(window.title);
May 29, 2006
May 29, 2006
601
}
May 28, 2006
May 28, 2006
602
603
604
605
606
607
608
609
return 0;
}
windows[num_windows] = window;
SDL_CurrentDisplay.windows = windows;
SDL_CurrentDisplay.num_windows++;
return window.id;
}
Jul 18, 2004
Jul 18, 2004
610
May 28, 2006
May 28, 2006
611
SDL_WindowID
May 29, 2006
May 29, 2006
612
SDL_CreateWindowFrom(void *data)
Apr 26, 2001
Apr 26, 2001
613
{
May 28, 2006
May 28, 2006
614
615
616
617
618
SDL_Window window;
int num_windows;
SDL_Window *windows;
if (!_this) {
May 29, 2006
May 29, 2006
619
SDL_SetError("Video subsystem has not been initialized");
May 28, 2006
May 28, 2006
620
621
622
return (0);
}
May 29, 2006
May 29, 2006
623
SDL_zero(window);
Jun 7, 2006
Jun 7, 2006
624
window.id = _this->next_object_id++;
May 28, 2006
May 28, 2006
625
626
if (!_this->CreateWindowFrom ||
May 29, 2006
May 29, 2006
627
_this->CreateWindowFrom(_this, &window, data) < 0) {
May 28, 2006
May 28, 2006
628
629
630
631
632
return 0;
}
num_windows = SDL_CurrentDisplay.num_windows;
windows =
May 29, 2006
May 29, 2006
633
634
SDL_realloc(SDL_CurrentDisplay.windows,
(num_windows + 1) * sizeof(*windows));
May 28, 2006
May 28, 2006
635
636
if (!windows) {
if (_this->DestroyWindow) {
May 29, 2006
May 29, 2006
637
_this->DestroyWindow(_this, &window);
May 28, 2006
May 28, 2006
638
}
May 29, 2006
May 29, 2006
639
if (window.title) {
May 29, 2006
May 29, 2006
640
SDL_free(window.title);
May 29, 2006
May 29, 2006
641
}
May 28, 2006
May 28, 2006
642
643
644
645
646
647
648
649
return 0;
}
windows[num_windows] = window;
SDL_CurrentDisplay.windows = windows;
SDL_CurrentDisplay.num_windows++;
return window.id;
}
Nov 4, 2001
Nov 4, 2001
650
May 28, 2006
May 28, 2006
651
static __inline__ SDL_Window *
May 29, 2006
May 29, 2006
652
SDL_GetWindowFromID(SDL_WindowID windowID)
May 28, 2006
May 28, 2006
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
{
int i, j;
if (!_this) {
return NULL;
}
for (i = 0; i < _this->num_displays; ++i) {
SDL_VideoDisplay *display = &_this->displays[i];
for (j = 0; j < display->num_windows; ++j) {
SDL_Window *window = &display->windows[j];
if (window->id == windowID) {
return window;
}
}
}
return NULL;
Apr 26, 2001
Apr 26, 2001
670
671
}
May 28, 2006
May 28, 2006
672
Uint32
May 29, 2006
May 29, 2006
673
SDL_GetWindowFlags(SDL_WindowID windowID)
Apr 26, 2001
Apr 26, 2001
674
{
May 29, 2006
May 29, 2006
675
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
676
677
678
679
680
if (!window) {
return 0;
}
return window->flags;
Apr 26, 2001
Apr 26, 2001
681
682
}
May 28, 2006
May 28, 2006
683
void
May 29, 2006
May 29, 2006
684
SDL_SetWindowTitle(SDL_WindowID windowID, const char *title)
Apr 26, 2001
Apr 26, 2001
685
{
May 29, 2006
May 29, 2006
686
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
687
688
689
690
691
if (!window) {
return;
}
if (window->title) {
May 29, 2006
May 29, 2006
692
SDL_free(window->title);
May 28, 2006
May 28, 2006
693
}
May 29, 2006
May 29, 2006
694
window->title = SDL_strdup(title);
May 28, 2006
May 28, 2006
695
696
if (_this->SetWindowTitle) {
May 29, 2006
May 29, 2006
697
_this->SetWindowTitle(_this, window);
May 28, 2006
May 28, 2006
698
}
Apr 26, 2001
Apr 26, 2001
699
}
May 28, 2006
May 28, 2006
700
701
const char *
May 29, 2006
May 29, 2006
702
SDL_GetWindowTitle(SDL_WindowID windowID)
Apr 26, 2001
Apr 26, 2001
703
{
May 29, 2006
May 29, 2006
704
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
705
706
707
708
709
if (!window) {
return NULL;
}
return window->title;
Apr 26, 2001
Apr 26, 2001
710
711
}
May 28, 2006
May 28, 2006
712
void
May 29, 2006
May 29, 2006
713
SDL_SetWindowData(SDL_WindowID windowID, void *userdata)
Apr 26, 2001
Apr 26, 2001
714
{
May 29, 2006
May 29, 2006
715
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
716
717
718
719
720
if (!window) {
return;
}
window->userdata = userdata;
Apr 26, 2001
Apr 26, 2001
721
722
}
May 28, 2006
May 28, 2006
723
void *
May 29, 2006
May 29, 2006
724
SDL_GetWindowData(SDL_WindowID windowID)
Apr 26, 2001
Apr 26, 2001
725
{
May 29, 2006
May 29, 2006
726
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
727
728
729
730
731
if (!window) {
return NULL;
}
return window->userdata;
Apr 26, 2001
Apr 26, 2001
732
733
}
May 28, 2006
May 28, 2006
734
void
May 29, 2006
May 29, 2006
735
SDL_SetWindowPosition(SDL_WindowID windowID, int x, int y)
Apr 26, 2001
Apr 26, 2001
736
{
May 29, 2006
May 29, 2006
737
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
738
739
740
741
742
743
744
745
746
if (!window) {
return;
}
window->x = x;
window->y = y;
if (_this->SetWindowPosition) {
May 29, 2006
May 29, 2006
747
_this->SetWindowPosition(_this, window);
May 28, 2006
May 28, 2006
748
}
Apr 26, 2001
Apr 26, 2001
749
750
}
May 28, 2006
May 28, 2006
751
void
May 29, 2006
May 29, 2006
752
SDL_GetWindowPosition(SDL_WindowID windowID, int *x, int *y)
Apr 26, 2001
Apr 26, 2001
753
{
May 29, 2006
May 29, 2006
754
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
755
756
757
758
759
760
761
762
763
764
if (!window) {
return;
}
if (x) {
*x = window->x;
}
if (y) {
*y = window->y;
}
Apr 26, 2001
Apr 26, 2001
765
766
}
May 28, 2006
May 28, 2006
767
void
May 29, 2006
May 29, 2006
768
SDL_SetWindowSize(SDL_WindowID windowID, int w, int h)
Apr 26, 2001
Apr 26, 2001
769
{
May 29, 2006
May 29, 2006
770
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
771
772
773
774
775
776
777
778
779
if (!window) {
return;
}
window->w = w;
window->h = h;
if (_this->SetWindowSize) {
May 29, 2006
May 29, 2006
780
_this->SetWindowSize(_this, window);
May 28, 2006
May 28, 2006
781
}
Apr 26, 2001
Apr 26, 2001
782
783
}
May 28, 2006
May 28, 2006
784
void
May 29, 2006
May 29, 2006
785
SDL_GetWindowSize(SDL_WindowID windowID, int *w, int *h)
Apr 26, 2001
Apr 26, 2001
786
{
May 29, 2006
May 29, 2006
787
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
788
789
790
791
792
793
794
795
796
797
if (!window) {
return;
}
if (w) {
*w = window->w;
}
if (h) {
*h = window->h;
}
Apr 26, 2001
Apr 26, 2001
798
799
}
May 28, 2006
May 28, 2006
800
void
May 29, 2006
May 29, 2006
801
SDL_ShowWindow(SDL_WindowID windowID)
Apr 26, 2001
Apr 26, 2001
802
{
May 29, 2006
May 29, 2006
803
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
804
805
806
807
808
809
810
811
if (!window || (window->flags & SDL_WINDOW_SHOWN)) {
return;
}
window->flags |= SDL_WINDOW_SHOWN;
if (_this->ShowWindow) {
May 29, 2006
May 29, 2006
812
_this->ShowWindow(_this, window);
May 28, 2006
May 28, 2006
813
}
Apr 26, 2001
Apr 26, 2001
814
815
}
May 28, 2006
May 28, 2006
816
void
May 29, 2006
May 29, 2006
817
SDL_HideWindow(SDL_WindowID windowID)
Apr 26, 2001
Apr 26, 2001
818
{
May 29, 2006
May 29, 2006
819
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
820
821
822
823
824
825
826
827
if (!window || !(window->flags & SDL_WINDOW_SHOWN)) {
return;
}
window->flags &= ~SDL_WINDOW_SHOWN;
if (_this->HideWindow) {
May 29, 2006
May 29, 2006
828
_this->HideWindow(_this, window);
May 28, 2006
May 28, 2006
829
}
Apr 26, 2001
Apr 26, 2001
830
831
}
May 28, 2006
May 28, 2006
832
void
May 29, 2006
May 29, 2006
833
SDL_RaiseWindow(SDL_WindowID windowID)
Apr 26, 2001
Apr 26, 2001
834
{
May 29, 2006
May 29, 2006
835
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
836
837
838
839
840
841
if (!window) {
return;
}
if (_this->RaiseWindow) {
May 29, 2006
May 29, 2006
842
_this->RaiseWindow(_this, window);
May 28, 2006
May 28, 2006
843
}
Apr 26, 2001
Apr 26, 2001
844
845
}
May 28, 2006
May 28, 2006
846
void
May 29, 2006
May 29, 2006
847
SDL_MaximizeWindow(SDL_WindowID windowID)
Apr 26, 2001
Apr 26, 2001
848
{
May 29, 2006
May 29, 2006
849
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
850
851
852
853
854
855
856
857
if (!window || (window->flags & SDL_WINDOW_MAXIMIZED)) {
return;
}
window->flags |= SDL_WINDOW_MAXIMIZED;
if (_this->MaximizeWindow) {
May 29, 2006
May 29, 2006
858
_this->MaximizeWindow(_this, window);
May 28, 2006
May 28, 2006
859
}
Apr 26, 2001
Apr 26, 2001
860
861
}
May 28, 2006
May 28, 2006
862
void
May 29, 2006
May 29, 2006
863
SDL_MinimizeWindow(SDL_WindowID windowID)
Apr 26, 2001
Apr 26, 2001
864
{
May 29, 2006
May 29, 2006
865
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
866
867
868
869
870
871
872
873
if (!window || (window->flags & SDL_WINDOW_MINIMIZED)) {
return;
}
window->flags |= SDL_WINDOW_MINIMIZED;
if (_this->MinimizeWindow) {
May 29, 2006
May 29, 2006
874
_this->MinimizeWindow(_this, window);
May 28, 2006
May 28, 2006
875
}
Apr 26, 2001
Apr 26, 2001
876
877
}
May 28, 2006
May 28, 2006
878
void
May 29, 2006
May 29, 2006
879
SDL_RestoreWindow(SDL_WindowID windowID)
Apr 26, 2001
Apr 26, 2001
880
{
May 29, 2006
May 29, 2006
881
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
882
883
884
885
886
887
888
889
890
if (!window
|| (window->flags & (SDL_WINDOW_MAXIMIZED | SDL_WINDOW_MINIMIZED))) {
return;
}
window->flags &= ~(SDL_WINDOW_MAXIMIZED | SDL_WINDOW_MINIMIZED);
if (_this->RestoreWindow) {
May 29, 2006
May 29, 2006
891
_this->RestoreWindow(_this, window);
May 28, 2006
May 28, 2006
892
}
Apr 26, 2001
Apr 26, 2001
893
}
May 28, 2006
May 28, 2006
894
895
void
May 29, 2006
May 29, 2006
896
SDL_SetWindowGrab(SDL_WindowID windowID, int mode)
Apr 26, 2001
Apr 26, 2001
897
{
May 29, 2006
May 29, 2006
898
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
899
900
901
902
903
904
905
906
907
908
909
910
if (!window || (!!mode == !!(window->flags & SDL_WINDOW_INPUT_GRABBED))) {
return;
}
if (mode) {
window->flags |= SDL_WINDOW_INPUT_GRABBED;
} else {
window->flags &= ~SDL_WINDOW_INPUT_GRABBED;
}
if (_this->SetWindowGrab) {
May 29, 2006
May 29, 2006
911
_this->SetWindowGrab(_this, window);
May 28, 2006
May 28, 2006
912
}
Apr 26, 2001
Apr 26, 2001
913
914
}
May 28, 2006
May 28, 2006
915
int
May 29, 2006
May 29, 2006
916
SDL_GetWindowGrab(SDL_WindowID windowID)
Apr 26, 2001
Apr 26, 2001
917
{
May 29, 2006
May 29, 2006
918
SDL_Window *window = SDL_GetWindowFromID(windowID);
May 28, 2006
May 28, 2006
919
920
921
922
923
924
925
926
927
if (!window) {
return 0;
}
return ((window->flags & SDL_WINDOW_INPUT_GRABBED) != 0);
}
void
May 29, 2006
May 29, 2006
928
SDL_DestroyWindow(SDL_WindowID windowID)
May 28, 2006
May 28, 2006
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
{
int i, j;
if (!_this) {
return;
}
for (i = 0; i < _this->num_displays; ++i) {
SDL_VideoDisplay *display = &_this->displays[i];
for (j = 0; j < display->num_windows; ++j) {
SDL_Window *window = &display->windows[j];
if (window->id != windowID) {
continue;
}
if (window->flags & SDL_WINDOW_INPUT_GRABBED) {
window->flags &= ~SDL_WINDOW_INPUT_GRABBED;
May 29, 2006
May 29, 2006
945
_this->SetWindowGrab(_this, window);
May 28, 2006
May 28, 2006
946
}
Jun 7, 2006
Jun 7, 2006
947
948
if (window->renderer) {
SDL_DestroyRenderer(window->id);
May 28, 2006
May 28, 2006
949
950
}
if (_this->DestroyWindow) {
May 29, 2006
May 29, 2006
951
_this->DestroyWindow(_this, window);
May 28, 2006
May 28, 2006
952
953
}
if (window->title) {
May 29, 2006
May 29, 2006
954
SDL_free(window->title);
May 28, 2006
May 28, 2006
955
956
}
if (window->gamma) {
May 29, 2006
May 29, 2006
957
SDL_free(window->gamma);
May 28, 2006
May 28, 2006
958
959
}
if (j != display->num_windows - 1) {
May 29, 2006
May 29, 2006
960
961
962
SDL_memcpy(&display->windows[i],
&display->windows[i + 1],
(display->num_windows - i - 1) * sizeof(*window));
May 28, 2006
May 28, 2006
963
964
965
966
967
968
969
}
--display->num_windows;
return;
}
}
}
Jun 7, 2006
Jun 7, 2006
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
void
SDL_AddRenderDriver(int displayIndex, const SDL_RenderDriver * driver)
{
SDL_VideoDisplay *display = &_this->displays[displayIndex];
SDL_RenderDriver *render_drivers;
render_drivers =
SDL_realloc(display->render_drivers,
(display->num_render_drivers +
1) * sizeof(*render_drivers));
if (render_drivers) {
render_drivers[display->num_render_drivers] = *driver;
display->render_drivers = render_drivers;
display->num_render_drivers++;
}
}
int
SDL_GetNumRenderers(void)
{
if (_this) {
return SDL_CurrentDisplay.num_render_drivers;
}
return 0;
}
int
SDL_GetRendererInfo(int index, SDL_RendererInfo * info)
{
if (index < 0 || index >= SDL_GetNumRenderers()) {
SDL_SetError("index must be in the range of 0 - %d",