SDL: Upgrade to 1.3
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@1927 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
2485e01b63
commit
c981d64ee4
|
@ -0,0 +1,151 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL.h
|
||||||
|
*
|
||||||
|
* Main include header for the SDL library
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* \mainpage Simple DirectMedia Layer (SDL)
|
||||||
|
|
||||||
|
http://www.libsdl.org/
|
||||||
|
|
||||||
|
* \section intro_sec Introduction
|
||||||
|
|
||||||
|
This is the Simple DirectMedia Layer, a general API that provides low
|
||||||
|
level access to audio, keyboard, mouse, joystick, 3D hardware via OpenGL,
|
||||||
|
and 2D framebuffer across multiple platforms.
|
||||||
|
|
||||||
|
The current version supports Linux, Windows, Windows CE, BeOS, MacOS,
|
||||||
|
Mac OS X, FreeBSD, NetBSD, OpenBSD, BSD/OS, Solaris, IRIX, and QNX.
|
||||||
|
The code contains support for Dreamcast, Atari, AIX, OSF/Tru64,
|
||||||
|
RISC OS, SymbianOS, and OS/2, but these are not officially supported.
|
||||||
|
|
||||||
|
SDL is written in C, but works with C++ natively, and has bindings to
|
||||||
|
several other languages, including Ada, C#, Eiffel, Erlang, Euphoria,
|
||||||
|
Guile, Haskell, Java, Lisp, Lua, ML, Objective C, Pascal, Perl, PHP,
|
||||||
|
Pike, Pliant, Python, Ruby, and Smalltalk.
|
||||||
|
|
||||||
|
This library is distributed under GNU LGPL version 2, which can be
|
||||||
|
found in the file "COPYING". This license allows you to use SDL
|
||||||
|
freely in commercial programs as long as you link with the dynamic
|
||||||
|
library.
|
||||||
|
|
||||||
|
The best way to learn how to use SDL is to check out the header files in
|
||||||
|
the "include" subdirectory and the programs in the "test" subdirectory.
|
||||||
|
The header files and test programs are well commented and always up to date.
|
||||||
|
More documentation is available in HTML format in "docs/index.html", and
|
||||||
|
a documentation wiki is available online at:
|
||||||
|
http://www.libsdl.org/cgi/docwiki.cgi
|
||||||
|
|
||||||
|
The test programs in the "test" subdirectory are in the public domain.
|
||||||
|
|
||||||
|
Frequently asked questions are answered online:
|
||||||
|
http://www.libsdl.org/faq.php
|
||||||
|
|
||||||
|
If you need help with the library, or just want to discuss SDL related
|
||||||
|
issues, you can join the developers mailing list:
|
||||||
|
http://www.libsdl.org/mailing-list.php
|
||||||
|
|
||||||
|
Enjoy!
|
||||||
|
Sam Lantinga (slouken@libsdl.org)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_H
|
||||||
|
#define _SDL_H
|
||||||
|
|
||||||
|
#include "SDL_main.h"
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_audio.h"
|
||||||
|
#include "SDL_cdrom.h"
|
||||||
|
#include "SDL_cpuinfo.h"
|
||||||
|
#include "SDL_endian.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
#include "SDL_events.h"
|
||||||
|
#include "SDL_loadso.h"
|
||||||
|
#include "SDL_mutex.h"
|
||||||
|
#include "SDL_rwops.h"
|
||||||
|
#include "SDL_thread.h"
|
||||||
|
#include "SDL_timer.h"
|
||||||
|
#include "SDL_video.h"
|
||||||
|
#include "SDL_version.h"
|
||||||
|
#include "SDL_compat.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* As of version 0.5, SDL is loaded dynamically into the application */
|
||||||
|
|
||||||
|
/* These are the flags which may be passed to SDL_Init() -- you should
|
||||||
|
specify the subsystems which you will be using in your application.
|
||||||
|
*/
|
||||||
|
#define SDL_INIT_TIMER 0x00000001
|
||||||
|
#define SDL_INIT_AUDIO 0x00000010
|
||||||
|
#define SDL_INIT_VIDEO 0x00000020
|
||||||
|
#define SDL_INIT_CDROM 0x00000100
|
||||||
|
#define SDL_INIT_JOYSTICK 0x00000200
|
||||||
|
#define SDL_INIT_HAPTIC 0x00001000
|
||||||
|
#define SDL_INIT_NOPARACHUTE 0x00100000 /* Don't catch fatal signals */
|
||||||
|
#define SDL_INIT_EVENTTHREAD 0x01000000 /* Not supported on all OS's */
|
||||||
|
#define SDL_INIT_EVERYTHING 0x0000FFFF
|
||||||
|
|
||||||
|
/* This function loads the SDL dynamically linked library and initializes
|
||||||
|
* the subsystems specified by 'flags' (and those satisfying dependencies)
|
||||||
|
* Unless the SDL_INIT_NOPARACHUTE flag is set, it will install cleanup
|
||||||
|
* signal handlers for some commonly ignored fatal signals (like SIGSEGV)
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_Init(Uint32 flags);
|
||||||
|
|
||||||
|
/* This function initializes specific SDL subsystems */
|
||||||
|
extern DECLSPEC int SDLCALL SDL_InitSubSystem(Uint32 flags);
|
||||||
|
|
||||||
|
/* This function cleans up specific SDL subsystems */
|
||||||
|
extern DECLSPEC void SDLCALL SDL_QuitSubSystem(Uint32 flags);
|
||||||
|
|
||||||
|
/* This function returns mask of the specified subsystems which have
|
||||||
|
been initialized.
|
||||||
|
If 'flags' is 0, it returns a mask of all initialized subsystems.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint32 SDLCALL SDL_WasInit(Uint32 flags);
|
||||||
|
|
||||||
|
/* This function cleans up all initialized subsystems and unloads the
|
||||||
|
* dynamically linked library. You should call it upon all exit conditions.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_Quit(void);
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_H */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,423 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_audio.h
|
||||||
|
*
|
||||||
|
* Access to the raw audio mixing buffer for the SDL library
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_audio_h
|
||||||
|
#define _SDL_audio_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
#include "SDL_endian.h"
|
||||||
|
#include "SDL_mutex.h"
|
||||||
|
#include "SDL_thread.h"
|
||||||
|
#include "SDL_rwops.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef Uint16 SDL_AudioFormat;
|
||||||
|
|
||||||
|
/* The calculated values in this structure are calculated by SDL_OpenAudio() */
|
||||||
|
typedef struct SDL_AudioSpec
|
||||||
|
{
|
||||||
|
int freq; /* DSP frequency -- samples per second */
|
||||||
|
SDL_AudioFormat format; /* Audio data format */
|
||||||
|
Uint8 channels; /* Number of channels: 1 mono, 2 stereo */
|
||||||
|
Uint8 silence; /* Audio buffer silence value (calculated) */
|
||||||
|
Uint16 samples; /* Audio buffer size in samples (power of 2) */
|
||||||
|
Uint16 padding; /* Necessary for some compile environments */
|
||||||
|
Uint32 size; /* Audio buffer size in bytes (calculated) */
|
||||||
|
/* This function is called when the audio device needs more data.
|
||||||
|
'stream' is a pointer to the audio data buffer
|
||||||
|
'len' is the length of that buffer in bytes.
|
||||||
|
Once the callback returns, the buffer will no longer be valid.
|
||||||
|
Stereo samples are stored in a LRLRLR ordering.
|
||||||
|
*/
|
||||||
|
void (SDLCALL * callback) (void *userdata, Uint8 * stream, int len);
|
||||||
|
void *userdata;
|
||||||
|
} SDL_AudioSpec;
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
These are what the 16 bits in SDL_AudioFormat currently mean...
|
||||||
|
(Unspecified bits are always zero.)
|
||||||
|
|
||||||
|
++-----------------------sample is signed if set
|
||||||
|
||
|
||||||
|
|| ++-----------sample is bigendian if set
|
||||||
|
|| ||
|
||||||
|
|| || ++---sample is float if set
|
||||||
|
|| || ||
|
||||||
|
|| || || +---sample bit size---+
|
||||||
|
|| || || | |
|
||||||
|
15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00
|
||||||
|
|
||||||
|
There are macros in SDL 1.3 and later to query these bits.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define SDL_AUDIO_MASK_BITSIZE (0xFF)
|
||||||
|
#define SDL_AUDIO_MASK_DATATYPE (1<<8)
|
||||||
|
#define SDL_AUDIO_MASK_ENDIAN (1<<12)
|
||||||
|
#define SDL_AUDIO_MASK_SIGNED (1<<15)
|
||||||
|
#define SDL_AUDIO_BITSIZE(x) (x & SDL_AUDIO_MASK_BITSIZE)
|
||||||
|
#define SDL_AUDIO_ISFLOAT(x) (x & SDL_AUDIO_MASK_DATATYPE)
|
||||||
|
#define SDL_AUDIO_ISBIGENDIAN(x) (x & SDL_AUDIO_MASK_ENDIAN)
|
||||||
|
#define SDL_AUDIO_ISSIGNED(x) (x & SDL_AUDIO_MASK_SIGNED)
|
||||||
|
#define SDL_AUDIO_ISINT(x) (!SDL_AUDIO_ISFLOAT(x))
|
||||||
|
#define SDL_AUDIO_ISLITTLEENDIAN(x) (!SDL_AUDIO_ISBIGENDIAN(x))
|
||||||
|
#define SDL_AUDIO_ISUNSIGNED(x) (!SDL_AUDIO_ISSIGNED(x))
|
||||||
|
|
||||||
|
/* Audio format flags (defaults to LSB byte order) */
|
||||||
|
#define AUDIO_U8 0x0008 /* Unsigned 8-bit samples */
|
||||||
|
#define AUDIO_S8 0x8008 /* Signed 8-bit samples */
|
||||||
|
#define AUDIO_U16LSB 0x0010 /* Unsigned 16-bit samples */
|
||||||
|
#define AUDIO_S16LSB 0x8010 /* Signed 16-bit samples */
|
||||||
|
#define AUDIO_U16MSB 0x1010 /* As above, but big-endian byte order */
|
||||||
|
#define AUDIO_S16MSB 0x9010 /* As above, but big-endian byte order */
|
||||||
|
#define AUDIO_U16 AUDIO_U16LSB
|
||||||
|
#define AUDIO_S16 AUDIO_S16LSB
|
||||||
|
|
||||||
|
/* int32 support new to SDL 1.3 */
|
||||||
|
#define AUDIO_S32LSB 0x8020 /* 32-bit integer samples */
|
||||||
|
#define AUDIO_S32MSB 0x9020 /* As above, but big-endian byte order */
|
||||||
|
#define AUDIO_S32 AUDIO_S32LSB
|
||||||
|
|
||||||
|
/* float32 support new to SDL 1.3 */
|
||||||
|
#define AUDIO_F32LSB 0x8120 /* 32-bit floating point samples */
|
||||||
|
#define AUDIO_F32MSB 0x9120 /* As above, but big-endian byte order */
|
||||||
|
#define AUDIO_F32 AUDIO_F32LSB
|
||||||
|
|
||||||
|
/* Native audio byte ordering */
|
||||||
|
#if SDL_BYTEORDER == SDL_LIL_ENDIAN
|
||||||
|
#define AUDIO_U16SYS AUDIO_U16LSB
|
||||||
|
#define AUDIO_S16SYS AUDIO_S16LSB
|
||||||
|
#define AUDIO_S32SYS AUDIO_S32LSB
|
||||||
|
#define AUDIO_F32SYS AUDIO_F32LSB
|
||||||
|
#else
|
||||||
|
#define AUDIO_U16SYS AUDIO_U16MSB
|
||||||
|
#define AUDIO_S16SYS AUDIO_S16MSB
|
||||||
|
#define AUDIO_S32SYS AUDIO_S32MSB
|
||||||
|
#define AUDIO_F32SYS AUDIO_F32MSB
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Which audio format changes are allowed when opening a device */
|
||||||
|
#define SDL_AUDIO_ALLOW_FREQUENCY_CHANGE 0x00000001
|
||||||
|
#define SDL_AUDIO_ALLOW_FORMAT_CHANGE 0x00000002
|
||||||
|
#define SDL_AUDIO_ALLOW_CHANNELS_CHANGE 0x00000004
|
||||||
|
#define SDL_AUDIO_ALLOW_ANY_CHANGE (SDL_AUDIO_ALLOW_FREQUENCY_CHANGE|SDL_AUDIO_ALLOW_FORMAT_CHANGE|SDL_AUDIO_ALLOW_CHANNELS_CHANGE)
|
||||||
|
|
||||||
|
/* A structure to hold a set of audio conversion filters and buffers */
|
||||||
|
struct SDL_AudioCVT;
|
||||||
|
typedef void (SDLCALL * SDL_AudioFilter) (struct SDL_AudioCVT * cvt,
|
||||||
|
SDL_AudioFormat format);
|
||||||
|
|
||||||
|
typedef struct SDL_AudioCVT
|
||||||
|
{
|
||||||
|
int needed; /* Set to 1 if conversion possible */
|
||||||
|
SDL_AudioFormat src_format; /* Source audio format */
|
||||||
|
SDL_AudioFormat dst_format; /* Target audio format */
|
||||||
|
double rate_incr; /* Rate conversion increment */
|
||||||
|
Uint8 *buf; /* Buffer to hold entire audio data */
|
||||||
|
int len; /* Length of original audio buffer */
|
||||||
|
int len_cvt; /* Length of converted audio buffer */
|
||||||
|
int len_mult; /* buffer must be len*len_mult big */
|
||||||
|
double len_ratio; /* Given len, final size is len*len_ratio */
|
||||||
|
SDL_AudioFilter filters[10]; /* Filter list */
|
||||||
|
int filter_index; /* Current audio conversion function */
|
||||||
|
} SDL_AudioCVT;
|
||||||
|
|
||||||
|
|
||||||
|
/* Function prototypes */
|
||||||
|
|
||||||
|
/* These functions return the list of built in audio drivers, in the
|
||||||
|
* order that they are normally initialized by default.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetNumAudioDrivers(void);
|
||||||
|
extern DECLSPEC const char *SDLCALL SDL_GetAudioDriver(int index);
|
||||||
|
|
||||||
|
/* These functions are used internally, and should not be used unless you
|
||||||
|
* have a specific need to specify the audio driver you want to use.
|
||||||
|
* You should normally use SDL_Init() or SDL_InitSubSystem().
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_AudioInit(const char *driver_name);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_AudioQuit(void);
|
||||||
|
|
||||||
|
/* This function returns the name of the current audio driver, or NULL
|
||||||
|
* if no driver has been initialized.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC const char *SDLCALL SDL_GetCurrentAudioDriver(void);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function opens the audio device with the desired parameters, and
|
||||||
|
* returns 0 if successful, placing the actual hardware parameters in the
|
||||||
|
* structure pointed to by 'obtained'. If 'obtained' is NULL, the audio
|
||||||
|
* data passed to the callback function will be guaranteed to be in the
|
||||||
|
* requested format, and will be automatically converted to the hardware
|
||||||
|
* audio format if necessary. This function returns -1 if it failed
|
||||||
|
* to open the audio device, or couldn't set up the audio thread.
|
||||||
|
*
|
||||||
|
* When filling in the desired audio spec structure,
|
||||||
|
* 'desired->freq' should be the desired audio frequency in samples-per-second.
|
||||||
|
* 'desired->format' should be the desired audio format.
|
||||||
|
* 'desired->samples' is the desired size of the audio buffer, in samples.
|
||||||
|
* This number should be a power of two, and may be adjusted by the audio
|
||||||
|
* driver to a value more suitable for the hardware. Good values seem to
|
||||||
|
* range between 512 and 8096 inclusive, depending on the application and
|
||||||
|
* CPU speed. Smaller values yield faster response time, but can lead
|
||||||
|
* to underflow if the application is doing heavy processing and cannot
|
||||||
|
* fill the audio buffer in time. A stereo sample consists of both right
|
||||||
|
* and left channels in LR ordering.
|
||||||
|
* Note that the number of samples is directly related to time by the
|
||||||
|
* following formula: ms = (samples*1000)/freq
|
||||||
|
* 'desired->size' is the size in bytes of the audio buffer, and is
|
||||||
|
* calculated by SDL_OpenAudio().
|
||||||
|
* 'desired->silence' is the value used to set the buffer to silence,
|
||||||
|
* and is calculated by SDL_OpenAudio().
|
||||||
|
* 'desired->callback' should be set to a function that will be called
|
||||||
|
* when the audio device is ready for more data. It is passed a pointer
|
||||||
|
* to the audio buffer, and the length in bytes of the audio buffer.
|
||||||
|
* This function usually runs in a separate thread, and so you should
|
||||||
|
* protect data structures that it accesses by calling SDL_LockAudio()
|
||||||
|
* and SDL_UnlockAudio() in your code.
|
||||||
|
* 'desired->userdata' is passed as the first parameter to your callback
|
||||||
|
* function.
|
||||||
|
*
|
||||||
|
* The audio device starts out playing silence when it's opened, and should
|
||||||
|
* be enabled for playing by calling SDL_PauseAudio(0) when you are ready
|
||||||
|
* for your audio callback function to be called. Since the audio driver
|
||||||
|
* may modify the requested size of the audio buffer, you should allocate
|
||||||
|
* any local mixing buffers after you open the audio device.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_OpenAudio(SDL_AudioSpec * desired,
|
||||||
|
SDL_AudioSpec * obtained);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* SDL Audio Device IDs.
|
||||||
|
* A successful call to SDL_OpenAudio() is always device id 1, and legacy
|
||||||
|
* SDL audio APIs assume you want this device ID. SDL_OpenAudioDevice() calls
|
||||||
|
* always returns devices >= 2 on success. The legacy calls are good both
|
||||||
|
* for backwards compatibility and when you don't care about multiple,
|
||||||
|
* specific, or capture devices.
|
||||||
|
*/
|
||||||
|
typedef Uint32 SDL_AudioDeviceID;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the number of available devices exposed by the current driver.
|
||||||
|
* Only valid after a successfully initializing the audio subsystem.
|
||||||
|
* Returns -1 if an explicit list of devices can't be determined; this is
|
||||||
|
* not an error. For example, if SDL is set up to talk to a remote audio
|
||||||
|
* server, it can't list every one available on the Internet, but it will
|
||||||
|
* still allow a specific host to be specified to SDL_OpenAudioDevice().
|
||||||
|
* In many common cases, when this function returns a value <= 0, it can still
|
||||||
|
* successfully open the default device (NULL for first argument of
|
||||||
|
* SDL_OpenAudioDevice()).
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetNumAudioDevices(int iscapture);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the human-readable name of a specific audio device.
|
||||||
|
* Must be a value between 0 and (number of audio devices-1).
|
||||||
|
* Only valid after a successfully initializing the audio subsystem.
|
||||||
|
* The values returned by this function reflect the latest call to
|
||||||
|
* SDL_GetNumAudioDevices(); recall that function to redetect available
|
||||||
|
* hardware.
|
||||||
|
*
|
||||||
|
* The string returned by this function is UTF-8 encoded, read-only, and
|
||||||
|
* managed internally. You are not to free it. If you need to keep the
|
||||||
|
* string for any length of time, you should make your own copy of it, as it
|
||||||
|
* will be invalid next time any of several other SDL functions is called.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC const char *SDLCALL SDL_GetAudioDeviceName(int index,
|
||||||
|
int iscapture);
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Open a specific audio device. Passing in a device name of NULL requests
|
||||||
|
* the most reasonable default (and is equivalent to calling SDL_OpenAudio()).
|
||||||
|
* The device name is a UTF-8 string reported by SDL_GetAudioDevice(), but
|
||||||
|
* some drivers allow arbitrary and driver-specific strings, such as a
|
||||||
|
* hostname/IP address for a remote audio server, or a filename in the
|
||||||
|
* diskaudio driver.
|
||||||
|
* Returns 0 on error, a valid device ID that is >= 2 on success.
|
||||||
|
* SDL_OpenAudio(), unlike this function, always acts on device ID 1.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_AudioDeviceID SDLCALL SDL_OpenAudioDevice(const char
|
||||||
|
*device,
|
||||||
|
int iscapture,
|
||||||
|
const
|
||||||
|
SDL_AudioSpec *
|
||||||
|
desired,
|
||||||
|
SDL_AudioSpec *
|
||||||
|
obtained,
|
||||||
|
int
|
||||||
|
allowed_changes);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the current audio state:
|
||||||
|
*/
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
SDL_AUDIO_STOPPED = 0,
|
||||||
|
SDL_AUDIO_PLAYING,
|
||||||
|
SDL_AUDIO_PAUSED
|
||||||
|
} SDL_audiostatus;
|
||||||
|
extern DECLSPEC SDL_audiostatus SDLCALL SDL_GetAudioStatus(void);
|
||||||
|
|
||||||
|
extern DECLSPEC SDL_audiostatus SDLCALL
|
||||||
|
SDL_GetAudioDeviceStatus(SDL_AudioDeviceID dev);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function pauses and unpauses the audio callback processing.
|
||||||
|
* It should be called with a parameter of 0 after opening the audio
|
||||||
|
* device to start playing sound. This is so you can safely initialize
|
||||||
|
* data for your callback function after opening the audio device.
|
||||||
|
* Silence will be written to the audio device during the pause.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_PauseAudio(int pause_on);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_PauseAudioDevice(SDL_AudioDeviceID dev,
|
||||||
|
int pause_on);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function loads a WAVE from the data source, automatically freeing
|
||||||
|
* that source if 'freesrc' is non-zero. For example, to load a WAVE file,
|
||||||
|
* you could do:
|
||||||
|
* SDL_LoadWAV_RW(SDL_RWFromFile("sample.wav", "rb"), 1, ...);
|
||||||
|
*
|
||||||
|
* If this function succeeds, it returns the given SDL_AudioSpec,
|
||||||
|
* filled with the audio data format of the wave data, and sets
|
||||||
|
* 'audio_buf' to a malloc()'d buffer containing the audio data,
|
||||||
|
* and sets 'audio_len' to the length of that audio buffer, in bytes.
|
||||||
|
* You need to free the audio buffer with SDL_FreeWAV() when you are
|
||||||
|
* done with it.
|
||||||
|
*
|
||||||
|
* This function returns NULL and sets the SDL error message if the
|
||||||
|
* wave file cannot be opened, uses an unknown data format, or is
|
||||||
|
* corrupt. Currently raw and MS-ADPCM WAVE files are supported.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_AudioSpec *SDLCALL SDL_LoadWAV_RW(SDL_RWops * src,
|
||||||
|
int freesrc,
|
||||||
|
SDL_AudioSpec * spec,
|
||||||
|
Uint8 ** audio_buf,
|
||||||
|
Uint32 * audio_len);
|
||||||
|
|
||||||
|
/* Compatibility convenience function -- loads a WAV from a file */
|
||||||
|
#define SDL_LoadWAV(file, spec, audio_buf, audio_len) \
|
||||||
|
SDL_LoadWAV_RW(SDL_RWFromFile(file, "rb"),1, spec,audio_buf,audio_len)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function frees data previously allocated with SDL_LoadWAV_RW()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_FreeWAV(Uint8 * audio_buf);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function takes a source format and rate and a destination format
|
||||||
|
* and rate, and initializes the 'cvt' structure with information needed
|
||||||
|
* by SDL_ConvertAudio() to convert a buffer of audio data from one format
|
||||||
|
* to the other.
|
||||||
|
* Returns -1 if the format conversion is not supported, 0 if there's
|
||||||
|
* no conversion needed, or 1 if the audio filter is set up.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_BuildAudioCVT(SDL_AudioCVT * cvt,
|
||||||
|
SDL_AudioFormat src_format,
|
||||||
|
Uint8 src_channels,
|
||||||
|
int src_rate,
|
||||||
|
SDL_AudioFormat dst_format,
|
||||||
|
Uint8 dst_channels,
|
||||||
|
int dst_rate);
|
||||||
|
|
||||||
|
/* Once you have initialized the 'cvt' structure using SDL_BuildAudioCVT(),
|
||||||
|
* created an audio buffer cvt->buf, and filled it with cvt->len bytes of
|
||||||
|
* audio data in the source format, this function will convert it in-place
|
||||||
|
* to the desired format.
|
||||||
|
* The data conversion may expand the size of the audio data, so the buffer
|
||||||
|
* cvt->buf should be allocated after the cvt structure is initialized by
|
||||||
|
* SDL_BuildAudioCVT(), and should be cvt->len*cvt->len_mult bytes long.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_ConvertAudio(SDL_AudioCVT * cvt);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This takes two audio buffers of the playing audio format and mixes
|
||||||
|
* them, performing addition, volume adjustment, and overflow clipping.
|
||||||
|
* The volume ranges from 0 - 128, and should be set to SDL_MIX_MAXVOLUME
|
||||||
|
* for full audio volume. Note this does not change hardware volume.
|
||||||
|
* This is provided for convenience -- you can mix your own audio data.
|
||||||
|
*/
|
||||||
|
#define SDL_MIX_MAXVOLUME 128
|
||||||
|
extern DECLSPEC void SDLCALL SDL_MixAudio(Uint8 * dst, const Uint8 * src,
|
||||||
|
Uint32 len, int volume);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This works like SDL_MixAudio, but you specify the audio format instead of
|
||||||
|
* using the format of audio device 1. Thus it can be used when no audio
|
||||||
|
* device is open at all.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_MixAudioFormat(Uint8 * dst,
|
||||||
|
const Uint8 * src,
|
||||||
|
SDL_AudioFormat format,
|
||||||
|
Uint32 len, int volume);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The lock manipulated by these functions protects the callback function.
|
||||||
|
* During a LockAudio/UnlockAudio pair, you can be guaranteed that the
|
||||||
|
* callback function is not running. Do not call these from the callback
|
||||||
|
* function or you will cause deadlock.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_LockAudio(void);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_LockAudioDevice(SDL_AudioDeviceID dev);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_UnlockAudio(void);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_UnlockAudioDevice(SDL_AudioDeviceID dev);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function shuts down audio processing and closes the audio device.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_CloseAudio(void);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_CloseAudioDevice(SDL_AudioDeviceID dev);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Returns 1 if audio device is still functioning, zero if not, -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_AudioDeviceConnected(SDL_AudioDeviceID dev);
|
||||||
|
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_audio_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,186 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_cdrom.h
|
||||||
|
*
|
||||||
|
* This is the CD-audio control API for Simple DirectMedia Layer
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_cdrom_h
|
||||||
|
#define _SDL_cdrom_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* In order to use these functions, SDL_Init() must have been called
|
||||||
|
with the SDL_INIT_CDROM flag. This causes SDL to scan the system
|
||||||
|
for CD-ROM drives, and load appropriate drivers.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* The maximum number of CD-ROM tracks on a disk */
|
||||||
|
#define SDL_MAX_TRACKS 99
|
||||||
|
|
||||||
|
/* The types of CD-ROM track possible */
|
||||||
|
#define SDL_AUDIO_TRACK 0x00
|
||||||
|
#define SDL_DATA_TRACK 0x04
|
||||||
|
|
||||||
|
/* The possible states which a CD-ROM drive can be in. */
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
CD_TRAYEMPTY,
|
||||||
|
CD_STOPPED,
|
||||||
|
CD_PLAYING,
|
||||||
|
CD_PAUSED,
|
||||||
|
CD_ERROR = -1
|
||||||
|
} CDstatus;
|
||||||
|
|
||||||
|
/* Given a status, returns true if there's a disk in the drive */
|
||||||
|
#define CD_INDRIVE(status) ((int)(status) > 0)
|
||||||
|
|
||||||
|
typedef struct SDL_CDtrack
|
||||||
|
{
|
||||||
|
Uint8 id; /* Track number */
|
||||||
|
Uint8 type; /* Data or audio track */
|
||||||
|
Uint16 unused;
|
||||||
|
Uint32 length; /* Length, in frames, of this track */
|
||||||
|
Uint32 offset; /* Offset, in frames, from start of disk */
|
||||||
|
} SDL_CDtrack;
|
||||||
|
|
||||||
|
/* This structure is only current as of the last call to SDL_CDStatus() */
|
||||||
|
typedef struct SDL_CD
|
||||||
|
{
|
||||||
|
int id; /* Private drive identifier */
|
||||||
|
CDstatus status; /* Current drive status */
|
||||||
|
|
||||||
|
/* The rest of this structure is only valid if there's a CD in drive */
|
||||||
|
int numtracks; /* Number of tracks on disk */
|
||||||
|
int cur_track; /* Current track position */
|
||||||
|
int cur_frame; /* Current frame offset within current track */
|
||||||
|
SDL_CDtrack track[SDL_MAX_TRACKS + 1];
|
||||||
|
} SDL_CD;
|
||||||
|
|
||||||
|
/* Conversion functions from frames to Minute/Second/Frames and vice versa */
|
||||||
|
#define CD_FPS 75
|
||||||
|
#define FRAMES_TO_MSF(f, M,S,F) { \
|
||||||
|
int value = f; \
|
||||||
|
*(F) = value%CD_FPS; \
|
||||||
|
value /= CD_FPS; \
|
||||||
|
*(S) = value%60; \
|
||||||
|
value /= 60; \
|
||||||
|
*(M) = value; \
|
||||||
|
}
|
||||||
|
#define MSF_TO_FRAMES(M, S, F) ((M)*60*CD_FPS+(S)*CD_FPS+(F))
|
||||||
|
|
||||||
|
/* CD-audio API functions: */
|
||||||
|
|
||||||
|
/* Returns the number of CD-ROM drives on the system, or -1 if
|
||||||
|
SDL_Init() has not been called with the SDL_INIT_CDROM flag.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CDNumDrives(void);
|
||||||
|
|
||||||
|
/* Returns a human-readable, system-dependent identifier for the CD-ROM.
|
||||||
|
Example:
|
||||||
|
"/dev/cdrom"
|
||||||
|
"E:"
|
||||||
|
"/dev/disk/ide/1/master"
|
||||||
|
*/
|
||||||
|
extern DECLSPEC const char *SDLCALL SDL_CDName(int drive);
|
||||||
|
|
||||||
|
/* Opens a CD-ROM drive for access. It returns a drive handle on success,
|
||||||
|
or NULL if the drive was invalid or busy. This newly opened CD-ROM
|
||||||
|
becomes the default CD used when other CD functions are passed a NULL
|
||||||
|
CD-ROM handle.
|
||||||
|
Drives are numbered starting with 0. Drive 0 is the system default CD-ROM.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_CD *SDLCALL SDL_CDOpen(int drive);
|
||||||
|
|
||||||
|
/* This function returns the current status of the given drive.
|
||||||
|
If the drive has a CD in it, the table of contents of the CD and current
|
||||||
|
play position of the CD will be stored in the SDL_CD structure.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC CDstatus SDLCALL SDL_CDStatus(SDL_CD * cdrom);
|
||||||
|
|
||||||
|
/* Play the given CD starting at 'start_track' and 'start_frame' for 'ntracks'
|
||||||
|
tracks and 'nframes' frames. If both 'ntrack' and 'nframe' are 0, play
|
||||||
|
until the end of the CD. This function will skip data tracks.
|
||||||
|
This function should only be called after calling SDL_CDStatus() to
|
||||||
|
get track information about the CD.
|
||||||
|
For example:
|
||||||
|
// Play entire CD:
|
||||||
|
if ( CD_INDRIVE(SDL_CDStatus(cdrom)) )
|
||||||
|
SDL_CDPlayTracks(cdrom, 0, 0, 0, 0);
|
||||||
|
// Play last track:
|
||||||
|
if ( CD_INDRIVE(SDL_CDStatus(cdrom)) ) {
|
||||||
|
SDL_CDPlayTracks(cdrom, cdrom->numtracks-1, 0, 0, 0);
|
||||||
|
}
|
||||||
|
// Play first and second track and 10 seconds of third track:
|
||||||
|
if ( CD_INDRIVE(SDL_CDStatus(cdrom)) )
|
||||||
|
SDL_CDPlayTracks(cdrom, 0, 0, 2, 10);
|
||||||
|
|
||||||
|
This function returns 0, or -1 if there was an error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CDPlayTracks(SDL_CD * cdrom,
|
||||||
|
int start_track,
|
||||||
|
int start_frame, int ntracks,
|
||||||
|
int nframes);
|
||||||
|
|
||||||
|
/* Play the given CD starting at 'start' frame for 'length' frames.
|
||||||
|
It returns 0, or -1 if there was an error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CDPlay(SDL_CD * cdrom, int start, int length);
|
||||||
|
|
||||||
|
/* Pause play -- returns 0, or -1 on error */
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CDPause(SDL_CD * cdrom);
|
||||||
|
|
||||||
|
/* Resume play -- returns 0, or -1 on error */
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CDResume(SDL_CD * cdrom);
|
||||||
|
|
||||||
|
/* Stop play -- returns 0, or -1 on error */
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CDStop(SDL_CD * cdrom);
|
||||||
|
|
||||||
|
/* Eject CD-ROM -- returns 0, or -1 on error */
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CDEject(SDL_CD * cdrom);
|
||||||
|
|
||||||
|
/* Closes the handle for the CD-ROM drive */
|
||||||
|
extern DECLSPEC void SDLCALL SDL_CDClose(SDL_CD * cdrom);
|
||||||
|
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_video_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,290 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This file contains functions for backwards compatibility with SDL 1.2 */
|
||||||
|
|
||||||
|
#ifndef _SDL_compat_h
|
||||||
|
#define _SDL_compat_h
|
||||||
|
|
||||||
|
#include "SDL_video.h"
|
||||||
|
#include "SDL_version.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define SDL_SWSURFACE 0x00000000 /* Not used */
|
||||||
|
#define SDL_SRCALPHA 0x00010000
|
||||||
|
#define SDL_SRCCOLORKEY 0x00020000
|
||||||
|
#define SDL_ANYFORMAT 0x00100000
|
||||||
|
#define SDL_HWPALETTE 0x00200000
|
||||||
|
#define SDL_DOUBLEBUF 0x00400000
|
||||||
|
#define SDL_FULLSCREEN 0x00800000
|
||||||
|
#define SDL_RESIZABLE 0x01000000
|
||||||
|
#define SDL_NOFRAME 0x02000000
|
||||||
|
#define SDL_OPENGL 0x04000000
|
||||||
|
#define SDL_HWSURFACE 0x08000001 /* Not used */
|
||||||
|
#define SDL_ASYNCBLIT 0x08000000 /* Not used */
|
||||||
|
#define SDL_RLEACCELOK 0x08000000 /* Not used */
|
||||||
|
#define SDL_HWACCEL 0x08000000 /* Not used */
|
||||||
|
|
||||||
|
#define SDL_APPMOUSEFOCUS 0x01
|
||||||
|
#define SDL_APPINPUTFOCUS 0x02
|
||||||
|
#define SDL_APPACTIVE 0x04
|
||||||
|
|
||||||
|
#define SDL_LOGPAL 0x01
|
||||||
|
#define SDL_PHYSPAL 0x02
|
||||||
|
|
||||||
|
#define SDL_ACTIVEEVENT SDL_EVENT_RESERVED1
|
||||||
|
#define SDL_VIDEORESIZE SDL_EVENT_RESERVED2
|
||||||
|
#define SDL_VIDEOEXPOSE SDL_EVENT_RESERVED3
|
||||||
|
#define SDL_ACTIVEEVENTMASK SDL_EVENTMASK(SDL_ACTIVEEVENT)
|
||||||
|
#define SDL_VIDEORESIZEMASK SDL_EVENTMASK(SDL_VIDEORESIZE)
|
||||||
|
#define SDL_VIDEOEXPOSEMASK SDL_EVENTMASK(SDL_VIDEOEXPOSE)
|
||||||
|
|
||||||
|
#define SDL_BUTTON_WHEELUP 4
|
||||||
|
#define SDL_BUTTON_WHEELDOWN 5
|
||||||
|
|
||||||
|
#define SDL_DEFAULT_REPEAT_DELAY 500
|
||||||
|
#define SDL_DEFAULT_REPEAT_INTERVAL 30
|
||||||
|
|
||||||
|
typedef struct SDL_VideoInfo
|
||||||
|
{
|
||||||
|
Uint32 hw_available:1;
|
||||||
|
Uint32 wm_available:1;
|
||||||
|
Uint32 UnusedBits1:6;
|
||||||
|
Uint32 UnusedBits2:1;
|
||||||
|
Uint32 blit_hw:1;
|
||||||
|
Uint32 blit_hw_CC:1;
|
||||||
|
Uint32 blit_hw_A:1;
|
||||||
|
Uint32 blit_sw:1;
|
||||||
|
Uint32 blit_sw_CC:1;
|
||||||
|
Uint32 blit_sw_A:1;
|
||||||
|
Uint32 blit_fill:1;
|
||||||
|
Uint32 UnusedBits3:16;
|
||||||
|
Uint32 video_mem;
|
||||||
|
|
||||||
|
SDL_PixelFormat *vfmt;
|
||||||
|
|
||||||
|
int current_w;
|
||||||
|
int current_h;
|
||||||
|
} SDL_VideoInfo;
|
||||||
|
|
||||||
|
/* The most common video overlay formats.
|
||||||
|
For an explanation of these pixel formats, see:
|
||||||
|
http://www.webartz.com/fourcc/indexyuv.htm
|
||||||
|
|
||||||
|
For information on the relationship between color spaces, see:
|
||||||
|
http://www.neuro.sfc.keio.ac.jp/~aly/polygon/info/color-space-faq.html
|
||||||
|
*/
|
||||||
|
#define SDL_YV12_OVERLAY 0x32315659 /* Planar mode: Y + V + U (3 planes) */
|
||||||
|
#define SDL_IYUV_OVERLAY 0x56555949 /* Planar mode: Y + U + V (3 planes) */
|
||||||
|
#define SDL_YUY2_OVERLAY 0x32595559 /* Packed mode: Y0+U0+Y1+V0 (1 plane) */
|
||||||
|
#define SDL_UYVY_OVERLAY 0x59565955 /* Packed mode: U0+Y0+V0+Y1 (1 plane) */
|
||||||
|
#define SDL_YVYU_OVERLAY 0x55595659 /* Packed mode: Y0+V0+Y1+U0 (1 plane) */
|
||||||
|
|
||||||
|
/* The YUV hardware video overlay */
|
||||||
|
typedef struct SDL_Overlay
|
||||||
|
{
|
||||||
|
Uint32 format; /* Read-only */
|
||||||
|
int w, h; /* Read-only */
|
||||||
|
int planes; /* Read-only */
|
||||||
|
Uint16 *pitches; /* Read-only */
|
||||||
|
Uint8 **pixels; /* Read-write */
|
||||||
|
|
||||||
|
/* Hardware-specific surface info */
|
||||||
|
struct private_yuvhwfuncs *hwfuncs;
|
||||||
|
struct private_yuvhwdata *hwdata;
|
||||||
|
|
||||||
|
/* Special flags */
|
||||||
|
Uint32 hw_overlay:1; /* Flag: This overlay hardware accelerated? */
|
||||||
|
Uint32 UnusedBits:31;
|
||||||
|
} SDL_Overlay;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
SDL_GRAB_QUERY = -1,
|
||||||
|
SDL_GRAB_OFF = 0,
|
||||||
|
SDL_GRAB_ON = 1
|
||||||
|
} SDL_GrabMode;
|
||||||
|
|
||||||
|
struct SDL_SysWMinfo;
|
||||||
|
|
||||||
|
/* Obsolete or renamed key codes */
|
||||||
|
|
||||||
|
/* These key constants were renamed for clarity or consistency. */
|
||||||
|
#define SDLK_0 '0'
|
||||||
|
#define SDLK_1 '1'
|
||||||
|
#define SDLK_2 '2'
|
||||||
|
#define SDLK_3 '3'
|
||||||
|
#define SDLK_4 '4'
|
||||||
|
#define SDLK_5 '5'
|
||||||
|
#define SDLK_6 '6'
|
||||||
|
#define SDLK_7 '7'
|
||||||
|
#define SDLK_8 '8'
|
||||||
|
#define SDLK_9 '9'
|
||||||
|
#define SDLK_a 'a'
|
||||||
|
#define SDLK_b 'b'
|
||||||
|
#define SDLK_c 'c'
|
||||||
|
#define SDLK_d 'd'
|
||||||
|
#define SDLK_e 'e'
|
||||||
|
#define SDLK_f 'f'
|
||||||
|
#define SDLK_g 'g'
|
||||||
|
#define SDLK_h 'h'
|
||||||
|
#define SDLK_i 'i'
|
||||||
|
#define SDLK_j 'j'
|
||||||
|
#define SDLK_k 'k'
|
||||||
|
#define SDLK_l 'l'
|
||||||
|
#define SDLK_m 'm'
|
||||||
|
#define SDLK_n 'n'
|
||||||
|
#define SDLK_o 'o'
|
||||||
|
#define SDLK_p 'p'
|
||||||
|
#define SDLK_q 'q'
|
||||||
|
#define SDLK_r 'r'
|
||||||
|
#define SDLK_s 's'
|
||||||
|
#define SDLK_t 't'
|
||||||
|
#define SDLK_u 'u'
|
||||||
|
#define SDLK_v 'v'
|
||||||
|
#define SDLK_w 'w'
|
||||||
|
#define SDLK_x 'x'
|
||||||
|
#define SDLK_y 'y'
|
||||||
|
#define SDLK_z 'z'
|
||||||
|
#define SDLK_QUOTE '\''
|
||||||
|
#define SDLK_MINUS '-'
|
||||||
|
#define SDLK_BACKQUOTE '`'
|
||||||
|
#define SDLK_EXCLAIM '!'
|
||||||
|
#define SDLK_QUOTEDBL '"'
|
||||||
|
#define SDLK_HASH '#'
|
||||||
|
#define SDLK_DOLLAR '$'
|
||||||
|
#define SDLK_AMPERSAND '&'
|
||||||
|
#define SDLK_LEFTPAREN '('
|
||||||
|
#define SDLK_RIGHTPAREN ')'
|
||||||
|
#define SDLK_ASTERISK '*'
|
||||||
|
#define SDLK_PLUS '+'
|
||||||
|
#define SDLK_COLON ':'
|
||||||
|
#define SDLK_LESS '<'
|
||||||
|
#define SDLK_GREATER '>'
|
||||||
|
#define SDLK_QUESTION '?'
|
||||||
|
#define SDLK_AT '@'
|
||||||
|
#define SDLK_CARET '^'
|
||||||
|
#define SDLK_UNDERSCORE '_'
|
||||||
|
#define SDLK_KP0 SDLK_KP_0
|
||||||
|
#define SDLK_KP1 SDLK_KP_1
|
||||||
|
#define SDLK_KP2 SDLK_KP_2
|
||||||
|
#define SDLK_KP3 SDLK_KP_3
|
||||||
|
#define SDLK_KP4 SDLK_KP_4
|
||||||
|
#define SDLK_KP5 SDLK_KP_5
|
||||||
|
#define SDLK_KP6 SDLK_KP_6
|
||||||
|
#define SDLK_KP7 SDLK_KP_7
|
||||||
|
#define SDLK_KP8 SDLK_KP_8
|
||||||
|
#define SDLK_KP9 SDLK_KP_9
|
||||||
|
#define SDLK_NUMLOCK SDLK_NUMLOCKCLEAR
|
||||||
|
#define SDLK_SCROLLOCK SDLK_SCROLLLOCK
|
||||||
|
#define SDLK_PRINT SDLK_PRINTSCREEN
|
||||||
|
|
||||||
|
/* The META modifier is equivalent to the GUI modifier from the USB standard */
|
||||||
|
#define KMOD_LMETA KMOD_LGUI
|
||||||
|
#define KMOD_RMETA KMOD_RGUI
|
||||||
|
#define KMOD_META KMOD_GUI
|
||||||
|
|
||||||
|
/* These keys don't appear in the USB specification (or at least not under those names). I'm unsure if the following assignments make sense or if these codes should be defined as actual additional SDLK_ constants. */
|
||||||
|
#define SDLK_LSUPER SDLK_LMETA
|
||||||
|
#define SDLK_RSUPER SDLK_RMETA
|
||||||
|
#define SDLK_COMPOSE SDLK_APPLICATION
|
||||||
|
#define SDLK_BREAK SDLK_STOP
|
||||||
|
#define SDLK_EURO SDLK_2
|
||||||
|
|
||||||
|
|
||||||
|
#define SDL_SetModuleHandle(x)
|
||||||
|
#define SDL_AllocSurface SDL_CreateRGBSurface
|
||||||
|
|
||||||
|
extern DECLSPEC const SDL_version *SDLCALL SDL_Linked_Version(void);
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_AudioDriverName(char *namebuf, int maxlen);
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_VideoDriverName(char *namebuf, int maxlen);
|
||||||
|
extern DECLSPEC const SDL_VideoInfo *SDLCALL SDL_GetVideoInfo(void);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_VideoModeOK(int width,
|
||||||
|
int height,
|
||||||
|
int bpp, Uint32 flags);
|
||||||
|
extern DECLSPEC SDL_Rect **SDLCALL SDL_ListModes(const SDL_PixelFormat *
|
||||||
|
format, Uint32 flags);
|
||||||
|
extern DECLSPEC SDL_Surface *SDLCALL SDL_SetVideoMode(int width, int height,
|
||||||
|
int bpp, Uint32 flags);
|
||||||
|
extern DECLSPEC SDL_Surface *SDLCALL SDL_GetVideoSurface(void);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_UpdateRects(SDL_Surface * screen,
|
||||||
|
int numrects, SDL_Rect * rects);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_UpdateRect(SDL_Surface * screen,
|
||||||
|
Sint32 x,
|
||||||
|
Sint32 y, Uint32 w, Uint32 h);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_Flip(SDL_Surface * screen);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetAlpha(SDL_Surface * surface,
|
||||||
|
Uint32 flag, Uint8 alpha);
|
||||||
|
extern DECLSPEC SDL_Surface *SDLCALL SDL_DisplayFormat(SDL_Surface * surface);
|
||||||
|
extern DECLSPEC SDL_Surface *SDLCALL SDL_DisplayFormatAlpha(SDL_Surface *
|
||||||
|
surface);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_WM_SetCaption(const char *title,
|
||||||
|
const char *icon);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_WM_GetCaption(const char **title,
|
||||||
|
const char **icon);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_WM_SetIcon(SDL_Surface * icon, Uint8 * mask);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_WM_IconifyWindow(void);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_WM_ToggleFullScreen(SDL_Surface * surface);
|
||||||
|
extern DECLSPEC SDL_GrabMode SDLCALL SDL_WM_GrabInput(SDL_GrabMode mode);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetPalette(SDL_Surface * surface,
|
||||||
|
int flags,
|
||||||
|
const SDL_Color * colors,
|
||||||
|
int firstcolor, int ncolors);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetColors(SDL_Surface * surface,
|
||||||
|
const SDL_Color * colors,
|
||||||
|
int firstcolor, int ncolors);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetWMInfo(struct SDL_SysWMinfo *info);
|
||||||
|
extern DECLSPEC Uint8 SDLCALL SDL_GetAppState(void);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_WarpMouse(Uint16 x, Uint16 y);
|
||||||
|
extern DECLSPEC SDL_Overlay *SDLCALL SDL_CreateYUVOverlay(int width,
|
||||||
|
int height,
|
||||||
|
Uint32 format,
|
||||||
|
SDL_Surface *
|
||||||
|
display);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_LockYUVOverlay(SDL_Overlay * overlay);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_UnlockYUVOverlay(SDL_Overlay * overlay);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_DisplayYUVOverlay(SDL_Overlay * overlay,
|
||||||
|
SDL_Rect * dstrect);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_FreeYUVOverlay(SDL_Overlay * overlay);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_GL_SwapBuffers(void);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_EnableKeyRepeat(int delay, int interval);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_GetKeyRepeat(int *delay, int *interval);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_EnableUNICODE(int enable);
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_compat_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,45 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_config_h
|
||||||
|
#define _SDL_config_h
|
||||||
|
|
||||||
|
#include "SDL_platform.h"
|
||||||
|
|
||||||
|
/* Add any platform that doesn't build using the configure system */
|
||||||
|
#if defined(__NINTENDODS__)
|
||||||
|
#include "SDL_config_nintendods.h"
|
||||||
|
#elif defined(__DREAMCAST__)
|
||||||
|
#include "SDL_config_dreamcast.h"
|
||||||
|
#elif defined(__IPHONEOS__)
|
||||||
|
#include "SDL_config_iphoneos.h"
|
||||||
|
#elif defined(__MACOSX__)
|
||||||
|
#include "SDL_config_macosx.h"
|
||||||
|
#elif defined(__WIN32__)
|
||||||
|
#include "SDL_config_win32.h"
|
||||||
|
#elif defined(__OS2__)
|
||||||
|
#include "SDL_config_os2.h"
|
||||||
|
#else
|
||||||
|
#include "SDL_config_minimal.h"
|
||||||
|
#endif /* platform config */
|
||||||
|
|
||||||
|
#endif /* _SDL_config_h */
|
|
@ -0,0 +1,45 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_config_h
|
||||||
|
#define _SDL_config_h
|
||||||
|
|
||||||
|
#include "SDL_platform.h"
|
||||||
|
|
||||||
|
/* Add any platform that doesn't build using the configure system */
|
||||||
|
#if defined(__NINTENDODS__)
|
||||||
|
#include "SDL_config_nintendods.h"
|
||||||
|
#elif defined(__DREAMCAST__)
|
||||||
|
#include "SDL_config_dreamcast.h"
|
||||||
|
#elif defined(__IPHONEOS__)
|
||||||
|
#include "SDL_config_iphoneos.h"
|
||||||
|
#elif defined(__MACOSX__)
|
||||||
|
#include "SDL_config_macosx.h"
|
||||||
|
#elif defined(__WIN32__)
|
||||||
|
#include "SDL_config_win32.h"
|
||||||
|
#elif defined(__OS2__)
|
||||||
|
#include "SDL_config_os2.h"
|
||||||
|
#else
|
||||||
|
#include "SDL_config_minimal.h"
|
||||||
|
#endif /* platform config */
|
||||||
|
|
||||||
|
#endif /* _SDL_config_h */
|
|
@ -0,0 +1,327 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_config_h
|
||||||
|
#define _SDL_config_h
|
||||||
|
|
||||||
|
/* This is a set of defines to configure the SDL features */
|
||||||
|
|
||||||
|
/* General platform specific identifiers */
|
||||||
|
#include "SDL_platform.h"
|
||||||
|
|
||||||
|
/* Make sure that this isn't included by Visual C++ */
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#error You should copy include/SDL_config.h.default to include/SDL_config.h
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* C language features */
|
||||||
|
#undef const
|
||||||
|
#undef inline
|
||||||
|
#undef volatile
|
||||||
|
|
||||||
|
/* C datatypes */
|
||||||
|
#undef size_t
|
||||||
|
#undef int8_t
|
||||||
|
#undef uint8_t
|
||||||
|
#undef int16_t
|
||||||
|
#undef uint16_t
|
||||||
|
#undef int32_t
|
||||||
|
#undef uint32_t
|
||||||
|
#undef int64_t
|
||||||
|
#undef uint64_t
|
||||||
|
#undef uintptr_t
|
||||||
|
#undef SDL_HAS_64BIT_TYPE
|
||||||
|
|
||||||
|
/* Endianness */
|
||||||
|
#undef SDL_BYTEORDER
|
||||||
|
|
||||||
|
/* Comment this if you want to build without any C library requirements */
|
||||||
|
#undef HAVE_LIBC
|
||||||
|
#if HAVE_LIBC
|
||||||
|
|
||||||
|
/* Useful headers */
|
||||||
|
#undef HAVE_ALLOCA_H
|
||||||
|
#undef HAVE_SYS_TYPES_H
|
||||||
|
#undef HAVE_STDIO_H
|
||||||
|
#undef STDC_HEADERS
|
||||||
|
#undef HAVE_STDLIB_H
|
||||||
|
#undef HAVE_STDARG_H
|
||||||
|
#undef HAVE_MALLOC_H
|
||||||
|
#undef HAVE_MEMORY_H
|
||||||
|
#undef HAVE_STRING_H
|
||||||
|
#undef HAVE_STRINGS_H
|
||||||
|
#undef HAVE_INTTYPES_H
|
||||||
|
#undef HAVE_STDINT_H
|
||||||
|
#undef HAVE_CTYPE_H
|
||||||
|
#undef HAVE_MATH_H
|
||||||
|
#undef HAVE_ICONV_H
|
||||||
|
#undef HAVE_SIGNAL_H
|
||||||
|
#undef HAVE_ALTIVEC_H
|
||||||
|
|
||||||
|
/* C library functions */
|
||||||
|
#undef HAVE_MALLOC
|
||||||
|
#undef HAVE_CALLOC
|
||||||
|
#undef HAVE_REALLOC
|
||||||
|
#undef HAVE_FREE
|
||||||
|
#undef HAVE_ALLOCA
|
||||||
|
#ifndef _WIN32 /* Don't use C runtime versions of these on Windows */
|
||||||
|
#undef HAVE_GETENV
|
||||||
|
#undef HAVE_PUTENV
|
||||||
|
#undef HAVE_UNSETENV
|
||||||
|
#endif
|
||||||
|
#undef HAVE_QSORT
|
||||||
|
#undef HAVE_ABS
|
||||||
|
#undef HAVE_BCOPY
|
||||||
|
#undef HAVE_MEMSET
|
||||||
|
#undef HAVE_MEMCPY
|
||||||
|
#undef HAVE_MEMMOVE
|
||||||
|
#undef HAVE_MEMCMP
|
||||||
|
#undef HAVE_STRLEN
|
||||||
|
#undef HAVE_STRLCPY
|
||||||
|
#undef HAVE_STRLCAT
|
||||||
|
#undef HAVE_STRDUP
|
||||||
|
#undef HAVE__STRREV
|
||||||
|
#undef HAVE__STRUPR
|
||||||
|
#undef HAVE__STRLWR
|
||||||
|
#undef HAVE_INDEX
|
||||||
|
#undef HAVE_RINDEX
|
||||||
|
#undef HAVE_STRCHR
|
||||||
|
#undef HAVE_STRRCHR
|
||||||
|
#undef HAVE_STRSTR
|
||||||
|
#undef HAVE_ITOA
|
||||||
|
#undef HAVE__LTOA
|
||||||
|
#undef HAVE__UITOA
|
||||||
|
#undef HAVE__ULTOA
|
||||||
|
#undef HAVE_STRTOL
|
||||||
|
#undef HAVE_STRTOUL
|
||||||
|
#undef HAVE__I64TOA
|
||||||
|
#undef HAVE__UI64TOA
|
||||||
|
#undef HAVE_STRTOLL
|
||||||
|
#undef HAVE_STRTOULL
|
||||||
|
#undef HAVE_STRTOD
|
||||||
|
#undef HAVE_ATOI
|
||||||
|
#undef HAVE_ATOF
|
||||||
|
#undef HAVE_STRCMP
|
||||||
|
#undef HAVE_STRNCMP
|
||||||
|
#undef HAVE__STRICMP
|
||||||
|
#undef HAVE_STRCASECMP
|
||||||
|
#undef HAVE__STRNICMP
|
||||||
|
#undef HAVE_STRNCASECMP
|
||||||
|
#undef HAVE_SSCANF
|
||||||
|
#undef HAVE_SNPRINTF
|
||||||
|
#undef HAVE_VSNPRINTF
|
||||||
|
#undef HAVE_M_PI
|
||||||
|
#undef HAVE_CEIL
|
||||||
|
#undef HAVE_COPYSIGN
|
||||||
|
#undef HAVE_COS
|
||||||
|
#undef HAVE_COSF
|
||||||
|
#undef HAVE_FABS
|
||||||
|
#undef HAVE_FLOOR
|
||||||
|
#undef HAVE_LOG
|
||||||
|
#undef HAVE_POW
|
||||||
|
#undef HAVE_SCALBN
|
||||||
|
#undef HAVE_SIN
|
||||||
|
#undef HAVE_SINF
|
||||||
|
#undef HAVE_SQRT
|
||||||
|
#undef HAVE_SIGACTION
|
||||||
|
#undef HAVE_SETJMP
|
||||||
|
#undef HAVE_NANOSLEEP
|
||||||
|
#undef HAVE_CLOCK_GETTIME
|
||||||
|
#undef HAVE_DLVSYM
|
||||||
|
#undef HAVE_GETPAGESIZE
|
||||||
|
|
||||||
|
#else
|
||||||
|
/* We may need some replacement for stdarg.h here */
|
||||||
|
#include <stdarg.h>
|
||||||
|
#endif /* HAVE_LIBC */
|
||||||
|
|
||||||
|
/* Allow disabling of core subsystems */
|
||||||
|
#undef SDL_AUDIO_DISABLED
|
||||||
|
#undef SDL_CDROM_DISABLED
|
||||||
|
#undef SDL_CPUINFO_DISABLED
|
||||||
|
#undef SDL_EVENTS_DISABLED
|
||||||
|
#undef SDL_FILE_DISABLED
|
||||||
|
#undef SDL_JOYSTICK_DISABLED
|
||||||
|
#undef SDL_HAPTIC_DISABLED
|
||||||
|
#undef SDL_LOADSO_DISABLED
|
||||||
|
#undef SDL_THREADS_DISABLED
|
||||||
|
#undef SDL_TIMERS_DISABLED
|
||||||
|
#undef SDL_VIDEO_DISABLED
|
||||||
|
|
||||||
|
/* Enable various audio drivers */
|
||||||
|
#undef SDL_AUDIO_DRIVER_ALSA
|
||||||
|
#undef SDL_AUDIO_DRIVER_ALSA_DYNAMIC
|
||||||
|
#undef SDL_AUDIO_DRIVER_ARTS
|
||||||
|
#undef SDL_AUDIO_DRIVER_ARTS_DYNAMIC
|
||||||
|
#undef SDL_AUDIO_DRIVER_PULSEAUDIO
|
||||||
|
#undef SDL_AUDIO_DRIVER_PULSEAUDIO_DYNAMIC
|
||||||
|
#undef SDL_AUDIO_DRIVER_BEOSAUDIO
|
||||||
|
#undef SDL_AUDIO_DRIVER_BSD
|
||||||
|
#undef SDL_AUDIO_DRIVER_COREAUDIO
|
||||||
|
#undef SDL_AUDIO_DRIVER_DART
|
||||||
|
#undef SDL_AUDIO_DRIVER_DC
|
||||||
|
#undef SDL_AUDIO_DRIVER_DISK
|
||||||
|
#undef SDL_AUDIO_DRIVER_DUMMY
|
||||||
|
#undef SDL_AUDIO_DRIVER_DMEDIA
|
||||||
|
#undef SDL_AUDIO_DRIVER_DSOUND
|
||||||
|
#undef SDL_AUDIO_DRIVER_ESD
|
||||||
|
#undef SDL_AUDIO_DRIVER_ESD_DYNAMIC
|
||||||
|
#undef SDL_AUDIO_DRIVER_MINT
|
||||||
|
#undef SDL_AUDIO_DRIVER_MMEAUDIO
|
||||||
|
#undef SDL_AUDIO_DRIVER_NAS
|
||||||
|
#undef SDL_AUDIO_DRIVER_NAS_DYNAMIC
|
||||||
|
#undef SDL_AUDIO_DRIVER_NDS
|
||||||
|
#undef SDL_AUDIO_DRIVER_OSS
|
||||||
|
#undef SDL_AUDIO_DRIVER_OSS_SOUNDCARD_H
|
||||||
|
#undef SDL_AUDIO_DRIVER_PAUDIO
|
||||||
|
#undef SDL_AUDIO_DRIVER_QNXNTO
|
||||||
|
#undef SDL_AUDIO_DRIVER_SNDMGR
|
||||||
|
#undef SDL_AUDIO_DRIVER_SUNAUDIO
|
||||||
|
#undef SDL_AUDIO_DRIVER_WINWAVEOUT
|
||||||
|
#undef SDL_AUDIO_DRIVER_FUSIONSOUND
|
||||||
|
#undef SDL_AUDIO_DRIVER_FUSIONSOUND_DYNAMIC
|
||||||
|
|
||||||
|
/* Enable various cdrom drivers */
|
||||||
|
#undef SDL_CDROM_AIX
|
||||||
|
#undef SDL_CDROM_BEOS
|
||||||
|
#undef SDL_CDROM_BSDI
|
||||||
|
#undef SDL_CDROM_DC
|
||||||
|
#undef SDL_CDROM_DUMMY
|
||||||
|
#undef SDL_CDROM_FREEBSD
|
||||||
|
#undef SDL_CDROM_LINUX
|
||||||
|
#undef SDL_CDROM_MACOSX
|
||||||
|
#undef SDL_CDROM_MINT
|
||||||
|
#undef SDL_CDROM_OPENBSD
|
||||||
|
#undef SDL_CDROM_OS2
|
||||||
|
#undef SDL_CDROM_OSF
|
||||||
|
#undef SDL_CDROM_QNX
|
||||||
|
#undef SDL_CDROM_WIN32
|
||||||
|
|
||||||
|
/* Enable various input drivers */
|
||||||
|
#undef SDL_INPUT_LINUXEV
|
||||||
|
#undef SDL_INPUT_TSLIB
|
||||||
|
#undef SDL_JOYSTICK_BEOS
|
||||||
|
#undef SDL_JOYSTICK_DC
|
||||||
|
#undef SDL_JOYSTICK_DINPUT
|
||||||
|
#undef SDL_JOYSTICK_DUMMY
|
||||||
|
#undef SDL_JOYSTICK_IOKIT
|
||||||
|
#undef SDL_JOYSTICK_LINUX
|
||||||
|
#undef SDL_JOYSTICK_MINT
|
||||||
|
#undef SDL_JOYSTICK_NDS
|
||||||
|
#undef SDL_JOYSTICK_OS2
|
||||||
|
#undef SDL_JOYSTICK_RISCOS
|
||||||
|
#undef SDL_JOYSTICK_WINMM
|
||||||
|
#undef SDL_JOYSTICK_USBHID
|
||||||
|
#undef SDL_JOYSTICK_USBHID_MACHINE_JOYSTICK_H
|
||||||
|
#undef SDL_HAPTIC_DUMMY
|
||||||
|
#undef SDL_HAPTIC_LINUX
|
||||||
|
#undef SDL_HAPTIC_IOKIT
|
||||||
|
#undef SDL_HAPTIC_DINPUT
|
||||||
|
|
||||||
|
/* Enable various shared object loading systems */
|
||||||
|
#undef SDL_LOADSO_BEOS
|
||||||
|
#undef SDL_LOADSO_DLCOMPAT
|
||||||
|
#undef SDL_LOADSO_DLOPEN
|
||||||
|
#undef SDL_LOADSO_DUMMY
|
||||||
|
#undef SDL_LOADSO_LDG
|
||||||
|
#undef SDL_LOADSO_OS2
|
||||||
|
#undef SDL_LOADSO_WIN32
|
||||||
|
|
||||||
|
/* Enable various threading systems */
|
||||||
|
#undef SDL_THREAD_BEOS
|
||||||
|
#undef SDL_THREAD_DC
|
||||||
|
#undef SDL_THREAD_NDS
|
||||||
|
#undef SDL_THREAD_OS2
|
||||||
|
#undef SDL_THREAD_PTH
|
||||||
|
#undef SDL_THREAD_PTHREAD
|
||||||
|
#undef SDL_THREAD_PTHREAD_RECURSIVE_MUTEX
|
||||||
|
#undef SDL_THREAD_PTHREAD_RECURSIVE_MUTEX_NP
|
||||||
|
#undef SDL_THREAD_SPROC
|
||||||
|
#undef SDL_THREAD_WIN32
|
||||||
|
|
||||||
|
/* Enable various timer systems */
|
||||||
|
#undef SDL_TIMER_BEOS
|
||||||
|
#undef SDL_TIMER_DC
|
||||||
|
#undef SDL_TIMER_DUMMY
|
||||||
|
#undef SDL_TIMER_MINT
|
||||||
|
#undef SDL_TIMER_NDS
|
||||||
|
#undef SDL_TIMER_OS2
|
||||||
|
#undef SDL_TIMER_RISCOS
|
||||||
|
#undef SDL_TIMER_UNIX
|
||||||
|
#undef SDL_TIMER_WIN32
|
||||||
|
#undef SDL_TIMER_WINCE
|
||||||
|
|
||||||
|
/* Enable various video drivers */
|
||||||
|
#undef SDL_VIDEO_DRIVER_BWINDOW
|
||||||
|
#undef SDL_VIDEO_DRIVER_COCOA
|
||||||
|
#undef SDL_VIDEO_DRIVER_DC
|
||||||
|
#undef SDL_VIDEO_DRIVER_DIRECTFB
|
||||||
|
#undef SDL_VIDEO_DRIVER_DIRECTFB_DYNAMIC
|
||||||
|
#undef SDL_VIDEO_DRIVER_DUMMY
|
||||||
|
#undef SDL_VIDEO_DRIVER_FBCON
|
||||||
|
#undef SDL_VIDEO_DRIVER_GAPI
|
||||||
|
#undef SDL_VIDEO_DRIVER_GEM
|
||||||
|
#undef SDL_VIDEO_DRIVER_IPOD
|
||||||
|
#undef SDL_VIDEO_DRIVER_NANOX
|
||||||
|
#undef SDL_VIDEO_DRIVER_NDS
|
||||||
|
#undef SDL_VIDEO_DRIVER_OS2FS
|
||||||
|
#undef SDL_VIDEO_DRIVER_PHOTON
|
||||||
|
#undef SDL_VIDEO_DRIVER_PS2GS
|
||||||
|
#undef SDL_VIDEO_DRIVER_RISCOS
|
||||||
|
#undef SDL_VIDEO_DRIVER_SVGALIB
|
||||||
|
#undef SDL_VIDEO_DRIVER_VGL
|
||||||
|
#undef SDL_VIDEO_DRIVER_WIN32
|
||||||
|
#undef SDL_VIDEO_DRIVER_WSCONS
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_DYNAMIC
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XEXT
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XRANDR
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XRENDER
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XINPUT
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_DYNAMIC_XSS
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_VIDMODE
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_XINERAMA
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_XRANDR
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_XINPUT
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_SCRNSAVER
|
||||||
|
#undef SDL_VIDEO_DRIVER_X11_XV
|
||||||
|
#undef SDL_VIDEO_DRIVER_XBIOS
|
||||||
|
|
||||||
|
#undef SDL_VIDEO_RENDER_D3D
|
||||||
|
#undef SDL_VIDEO_RENDER_GDI
|
||||||
|
#undef SDL_VIDEO_RENDER_OGL
|
||||||
|
#undef SDL_VIDEO_RENDER_X11
|
||||||
|
|
||||||
|
/* Enable OpenGL support */
|
||||||
|
#undef SDL_VIDEO_OPENGL
|
||||||
|
#undef SDL_VIDEO_OPENGL_BGL
|
||||||
|
#undef SDL_VIDEO_OPENGL_CGL
|
||||||
|
#undef SDL_VIDEO_OPENGL_GLX
|
||||||
|
#undef SDL_VIDEO_OPENGL_WGL
|
||||||
|
#undef SDL_VIDEO_OPENGL_OSMESA
|
||||||
|
#undef SDL_VIDEO_OPENGL_OSMESA_DYNAMIC
|
||||||
|
|
||||||
|
/* Enable assembly routines */
|
||||||
|
#undef SDL_ASSEMBLY_ROUTINES
|
||||||
|
#undef SDL_ALTIVEC_BLITTERS
|
||||||
|
|
||||||
|
#endif /* _SDL_config_h */
|
|
@ -0,0 +1,107 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_config_dreamcast_h
|
||||||
|
#define _SDL_config_dreamcast_h
|
||||||
|
|
||||||
|
#include "SDL_platform.h"
|
||||||
|
|
||||||
|
/* This is a set of defines to configure the SDL features */
|
||||||
|
|
||||||
|
typedef signed char int8_t;
|
||||||
|
typedef unsigned char uint8_t;
|
||||||
|
typedef signed short int16_t;
|
||||||
|
typedef unsigned short uint16_t;
|
||||||
|
typedef signed int int32_t;
|
||||||
|
typedef unsigned int uint32_t;
|
||||||
|
typedef signed long long int64_t;
|
||||||
|
typedef unsigned long long uint64_t;
|
||||||
|
typedef unsigned long uintptr_t;
|
||||||
|
#define SDL_HAS_64BIT_TYPE 1
|
||||||
|
|
||||||
|
/* Useful headers */
|
||||||
|
#define HAVE_SYS_TYPES_H 1
|
||||||
|
#define HAVE_STDIO_H 1
|
||||||
|
#define STDC_HEADERS 1
|
||||||
|
#define HAVE_STRING_H 1
|
||||||
|
#define HAVE_CTYPE_H 1
|
||||||
|
|
||||||
|
/* C library functions */
|
||||||
|
#define HAVE_MALLOC 1
|
||||||
|
#define HAVE_CALLOC 1
|
||||||
|
#define HAVE_REALLOC 1
|
||||||
|
#define HAVE_FREE 1
|
||||||
|
#define HAVE_ALLOCA 1
|
||||||
|
#define HAVE_GETENV 1
|
||||||
|
#define HAVE_PUTENV 1
|
||||||
|
#define HAVE_QSORT 1
|
||||||
|
#define HAVE_ABS 1
|
||||||
|
#define HAVE_BCOPY 1
|
||||||
|
#define HAVE_MEMSET 1
|
||||||
|
#define HAVE_MEMCPY 1
|
||||||
|
#define HAVE_MEMMOVE 1
|
||||||
|
#define HAVE_MEMCMP 1
|
||||||
|
#define HAVE_STRLEN 1
|
||||||
|
#define HAVE_STRDUP 1
|
||||||
|
#define HAVE_INDEX 1
|
||||||
|
#define HAVE_RINDEX 1
|
||||||
|
#define HAVE_STRCHR 1
|
||||||
|
#define HAVE_STRRCHR 1
|
||||||
|
#define HAVE_STRSTR 1
|
||||||
|
#define HAVE_STRTOL 1
|
||||||
|
#define HAVE_STRTOD 1
|
||||||
|
#define HAVE_ATOI 1
|
||||||
|
#define HAVE_ATOF 1
|
||||||
|
#define HAVE_STRCMP 1
|
||||||
|
#define HAVE_STRNCMP 1
|
||||||
|
#define HAVE_STRICMP 1
|
||||||
|
#define HAVE_STRCASECMP 1
|
||||||
|
#define HAVE_SSCANF 1
|
||||||
|
#define HAVE_SNPRINTF 1
|
||||||
|
#define HAVE_VSNPRINTF 1
|
||||||
|
|
||||||
|
/* Enable various audio drivers */
|
||||||
|
#define SDL_AUDIO_DRIVER_DC 1
|
||||||
|
#define SDL_AUDIO_DRIVER_DISK 1
|
||||||
|
#define SDL_AUDIO_DRIVER_DUMMY 1
|
||||||
|
|
||||||
|
/* Enable various cdrom drivers */
|
||||||
|
#define SDL_CDROM_DC 1
|
||||||
|
|
||||||
|
/* Enable various input drivers */
|
||||||
|
#define SDL_JOYSTICK_DC 1
|
||||||
|
#define SDL_HAPTIC_DUMMY 1
|
||||||
|
|
||||||
|
/* Enable various shared object loading systems */
|
||||||
|
#define SDL_LOADSO_DUMMY 1
|
||||||
|
|
||||||
|
/* Enable various threading systems */
|
||||||
|
#define SDL_THREAD_DC 1
|
||||||
|
|
||||||
|
/* Enable various timer systems */
|
||||||
|
#define SDL_TIMER_DC 1
|
||||||
|
|
||||||
|
/* Enable various video drivers */
|
||||||
|
#define SDL_VIDEO_DRIVER_DC 1
|
||||||
|
#define SDL_VIDEO_DRIVER_DUMMY 1
|
||||||
|
|
||||||
|
#endif /* _SDL_config_dreamcast_h */
|
|
@ -0,0 +1,133 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_config_iphoneos_h
|
||||||
|
#define _SDL_config_iphoneos_h
|
||||||
|
|
||||||
|
#include "SDL_platform.h"
|
||||||
|
|
||||||
|
typedef signed char int8_t;
|
||||||
|
typedef unsigned char uint8_t;
|
||||||
|
typedef signed short int16_t;
|
||||||
|
typedef unsigned short uint16_t;
|
||||||
|
typedef signed int int32_t;
|
||||||
|
typedef unsigned int uint32_t;
|
||||||
|
typedef unsigned long uintptr_t;
|
||||||
|
#define SDL_HAS_64BIT_TYPE 1
|
||||||
|
|
||||||
|
#define HAVE_ALLOCA_H 1
|
||||||
|
#define HAVE_SYS_TYPES_H 1
|
||||||
|
#define HAVE_STDIO_H 1
|
||||||
|
#define STDC_HEADERS 1
|
||||||
|
#define HAVE_STRING_H 1
|
||||||
|
#define HAVE_INTTYPES_H 1
|
||||||
|
#define HAVE_STDINT_H 1
|
||||||
|
#define HAVE_CTYPE_H 1
|
||||||
|
#define HAVE_MATH_H 1
|
||||||
|
#define HAVE_SIGNAL_H 1
|
||||||
|
|
||||||
|
/* C library functions */
|
||||||
|
#define HAVE_MALLOC 1
|
||||||
|
#define HAVE_CALLOC 1
|
||||||
|
#define HAVE_REALLOC 1
|
||||||
|
#define HAVE_FREE 1
|
||||||
|
#define HAVE_ALLOCA 1
|
||||||
|
#define HAVE_GETENV 1
|
||||||
|
#define HAVE_PUTENV 1
|
||||||
|
#define HAVE_UNSETENV 1
|
||||||
|
#define HAVE_QSORT 1
|
||||||
|
#define HAVE_ABS 1
|
||||||
|
#define HAVE_BCOPY 1
|
||||||
|
#define HAVE_MEMSET 1
|
||||||
|
#define HAVE_MEMCPY 1
|
||||||
|
#define HAVE_MEMMOVE 1
|
||||||
|
#define HAVE_MEMCMP 1
|
||||||
|
#define HAVE_STRLEN 1
|
||||||
|
#define HAVE_STRLCPY 1
|
||||||
|
#define HAVE_STRLCAT 1
|
||||||
|
#define HAVE_STRDUP 1
|
||||||
|
#define HAVE_STRCHR 1
|
||||||
|
#define HAVE_STRRCHR 1
|
||||||
|
#define HAVE_STRSTR 1
|
||||||
|
#define HAVE_STRTOL 1
|
||||||
|
#define HAVE_STRTOUL 1
|
||||||
|
#define HAVE_STRTOLL 1
|
||||||
|
#define HAVE_STRTOULL 1
|
||||||
|
#define HAVE_STRTOD 1
|
||||||
|
#define HAVE_ATOI 1
|
||||||
|
#define HAVE_ATOF 1
|
||||||
|
#define HAVE_STRCMP 1
|
||||||
|
#define HAVE_STRNCMP 1
|
||||||
|
#define HAVE_STRCASECMP 1
|
||||||
|
#define HAVE_STRNCASECMP 1
|
||||||
|
#define HAVE_SSCANF 1
|
||||||
|
#define HAVE_SNPRINTF 1
|
||||||
|
#define HAVE_VSNPRINTF 1
|
||||||
|
#define HAVE_SIGACTION 1
|
||||||
|
#define HAVE_SETJMP 1
|
||||||
|
#define HAVE_NANOSLEEP 1
|
||||||
|
|
||||||
|
/* enable iPhone version of Core Audio driver */
|
||||||
|
#define SDL_AUDIO_DRIVER_COREAUDIOIPHONE 1
|
||||||
|
/* Enable the dummy audio driver (src/audio/dummy/\*.c) */
|
||||||
|
#define SDL_AUDIO_DRIVER_DUMMY 1
|
||||||
|
|
||||||
|
/* Enable the stub cdrom driver (src/cdrom/dummy/\*.c) */
|
||||||
|
#define SDL_CDROM_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable the stub haptic driver (src/haptic/dummy/\*.c) */
|
||||||
|
#define SDL_HAPTIC_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable Unix style SO loading */
|
||||||
|
/* Technically this works, but it violates the iPhone developer agreement */
|
||||||
|
/* #define SDL_LOADSO_DLOPEN 1 */
|
||||||
|
|
||||||
|
/* Enable the stub shared object loader (src/loadso/dummy/\*.c) */
|
||||||
|
#define SDL_LOADSO_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable various threading systems */
|
||||||
|
#define SDL_THREAD_PTHREAD 1
|
||||||
|
#define SDL_THREAD_PTHREAD_RECURSIVE_MUTEX 1
|
||||||
|
|
||||||
|
/* Enable various timer systems */
|
||||||
|
#define SDL_TIMER_UNIX 1
|
||||||
|
|
||||||
|
/* Supported video drivers */
|
||||||
|
#define SDL_VIDEO_DRIVER_UIKIT 1
|
||||||
|
#define SDL_VIDEO_DRIVER_DUMMY 1
|
||||||
|
|
||||||
|
/* enable OpenGL ES */
|
||||||
|
#define SDL_VIDEO_OPENGL_ES 1
|
||||||
|
#define SDL_VIDEO_RENDER_OGL_ES 1
|
||||||
|
|
||||||
|
/* enable iPhone keyboard support */
|
||||||
|
#define SDL_IPHONE_KEYBOARD 1
|
||||||
|
|
||||||
|
/* Enable emulation of multiple mice through multi-touch */
|
||||||
|
#define SDL_IPHONE_MULTIPLE_MICE 1
|
||||||
|
|
||||||
|
/* Set max recognized G-force from acceleromter
|
||||||
|
See src/joystick/uikit/SDLUIAccelerationDelegate.m for notes on why this is needed
|
||||||
|
*/
|
||||||
|
#define SDL_IPHONE_MAX_GFORCE 5.0
|
||||||
|
|
||||||
|
#endif /* _SDL_config_iphoneos_h */
|
|
@ -0,0 +1,134 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_config_macosx_h
|
||||||
|
#define _SDL_config_macosx_h
|
||||||
|
|
||||||
|
#include "SDL_platform.h"
|
||||||
|
|
||||||
|
/* This gets us MAC_OS_X_VERSION_MIN_REQUIRED... */
|
||||||
|
#include <AvailabilityMacros.h>
|
||||||
|
|
||||||
|
/* This is a set of defines to configure the SDL features */
|
||||||
|
|
||||||
|
#define SDL_HAS_64BIT_TYPE 1
|
||||||
|
|
||||||
|
/* Useful headers */
|
||||||
|
/* If we specified an SDK or have a post-PowerPC chip, then alloca.h exists. */
|
||||||
|
#if ( (MAC_OS_X_VERSION_MIN_REQUIRED >= 1030) || (!defined(__POWERPC__)) )
|
||||||
|
#define HAVE_ALLOCA_H 1
|
||||||
|
#endif
|
||||||
|
#define HAVE_SYS_TYPES_H 1
|
||||||
|
#define HAVE_STDIO_H 1
|
||||||
|
#define STDC_HEADERS 1
|
||||||
|
#define HAVE_STRING_H 1
|
||||||
|
#define HAVE_INTTYPES_H 1
|
||||||
|
#define HAVE_STDINT_H 1
|
||||||
|
#define HAVE_CTYPE_H 1
|
||||||
|
#define HAVE_MATH_H 1
|
||||||
|
#define HAVE_SIGNAL_H 1
|
||||||
|
|
||||||
|
/* C library functions */
|
||||||
|
#define HAVE_MALLOC 1
|
||||||
|
#define HAVE_CALLOC 1
|
||||||
|
#define HAVE_REALLOC 1
|
||||||
|
#define HAVE_FREE 1
|
||||||
|
#define HAVE_ALLOCA 1
|
||||||
|
#define HAVE_GETENV 1
|
||||||
|
#define HAVE_PUTENV 1
|
||||||
|
#define HAVE_UNSETENV 1
|
||||||
|
#define HAVE_QSORT 1
|
||||||
|
#define HAVE_ABS 1
|
||||||
|
#define HAVE_BCOPY 1
|
||||||
|
#define HAVE_MEMSET 1
|
||||||
|
#define HAVE_MEMCPY 1
|
||||||
|
#define HAVE_MEMMOVE 1
|
||||||
|
#define HAVE_MEMCMP 1
|
||||||
|
#define HAVE_STRLEN 1
|
||||||
|
#define HAVE_STRLCPY 1
|
||||||
|
#define HAVE_STRLCAT 1
|
||||||
|
#define HAVE_STRDUP 1
|
||||||
|
#define HAVE_STRCHR 1
|
||||||
|
#define HAVE_STRRCHR 1
|
||||||
|
#define HAVE_STRSTR 1
|
||||||
|
#define HAVE_STRTOL 1
|
||||||
|
#define HAVE_STRTOUL 1
|
||||||
|
#define HAVE_STRTOLL 1
|
||||||
|
#define HAVE_STRTOULL 1
|
||||||
|
#define HAVE_STRTOD 1
|
||||||
|
#define HAVE_ATOI 1
|
||||||
|
#define HAVE_ATOF 1
|
||||||
|
#define HAVE_STRCMP 1
|
||||||
|
#define HAVE_STRNCMP 1
|
||||||
|
#define HAVE_STRCASECMP 1
|
||||||
|
#define HAVE_STRNCASECMP 1
|
||||||
|
#define HAVE_SSCANF 1
|
||||||
|
#define HAVE_SNPRINTF 1
|
||||||
|
#define HAVE_VSNPRINTF 1
|
||||||
|
#define HAVE_SIGACTION 1
|
||||||
|
#define HAVE_SETJMP 1
|
||||||
|
#define HAVE_NANOSLEEP 1
|
||||||
|
|
||||||
|
/* Enable various audio drivers */
|
||||||
|
#define SDL_AUDIO_DRIVER_COREAUDIO 1
|
||||||
|
#define SDL_AUDIO_DRIVER_SNDMGR 1
|
||||||
|
#define SDL_AUDIO_DRIVER_DISK 1
|
||||||
|
#define SDL_AUDIO_DRIVER_DUMMY 1
|
||||||
|
|
||||||
|
/* Enable various cdrom drivers */
|
||||||
|
#define SDL_CDROM_MACOSX 1
|
||||||
|
|
||||||
|
/* Enable various input drivers */
|
||||||
|
#define SDL_JOYSTICK_IOKIT 1
|
||||||
|
#define SDL_HAPTIC_IOKIT 1
|
||||||
|
|
||||||
|
/* Enable various shared object loading systems */
|
||||||
|
#ifdef __ppc__
|
||||||
|
/* For Mac OS X 10.2 compatibility */
|
||||||
|
#define SDL_LOADSO_DLCOMPAT 1
|
||||||
|
#else
|
||||||
|
#define SDL_LOADSO_DLOPEN 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Enable various threading systems */
|
||||||
|
#define SDL_THREAD_PTHREAD 1
|
||||||
|
#define SDL_THREAD_PTHREAD_RECURSIVE_MUTEX 1
|
||||||
|
|
||||||
|
/* Enable various timer systems */
|
||||||
|
#define SDL_TIMER_UNIX 1
|
||||||
|
|
||||||
|
/* Enable various video drivers */
|
||||||
|
#define SDL_VIDEO_DRIVER_COCOA 1
|
||||||
|
#define SDL_VIDEO_DRIVER_DUMMY 1
|
||||||
|
|
||||||
|
/* Enable OpenGL support */
|
||||||
|
#define SDL_VIDEO_OPENGL 1
|
||||||
|
#define SDL_VIDEO_OPENGL_CGL 1
|
||||||
|
#define SDL_VIDEO_RENDER_OGL 1
|
||||||
|
|
||||||
|
/* Enable assembly routines */
|
||||||
|
#define SDL_ASSEMBLY_ROUTINES 1
|
||||||
|
#ifdef __ppc__
|
||||||
|
#define SDL_ALTIVEC_BLITTERS 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _SDL_config_macosx_h */
|
|
@ -0,0 +1,65 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_config_minimal_h
|
||||||
|
#define _SDL_config_minimal_h
|
||||||
|
|
||||||
|
#include "SDL_platform.h"
|
||||||
|
|
||||||
|
/* This is the minimal configuration that can be used to build SDL */
|
||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
typedef signed char int8_t;
|
||||||
|
typedef unsigned char uint8_t;
|
||||||
|
typedef signed short int16_t;
|
||||||
|
typedef unsigned short uint16_t;
|
||||||
|
typedef signed int int32_t;
|
||||||
|
typedef unsigned int uint32_t;
|
||||||
|
typedef unsigned int size_t;
|
||||||
|
typedef unsigned long uintptr_t;
|
||||||
|
|
||||||
|
/* Enable the dummy audio driver (src/audio/dummy/\*.c) */
|
||||||
|
#define SDL_AUDIO_DRIVER_DUMMY 1
|
||||||
|
|
||||||
|
/* Enable the stub cdrom driver (src/cdrom/dummy/\*.c) */
|
||||||
|
#define SDL_CDROM_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable the stub joystick driver (src/joystick/dummy/\*.c) */
|
||||||
|
#define SDL_JOYSTICK_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable the stub haptic driver (src/haptic/dummy/\*.c) */
|
||||||
|
#define SDL_HAPTIC_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable the stub shared object loader (src/loadso/dummy/\*.c) */
|
||||||
|
#define SDL_LOADSO_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable the stub thread support (src/thread/generic/\*.c) */
|
||||||
|
#define SDL_THREADS_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable the stub timer support (src/timer/dummy/\*.c) */
|
||||||
|
#define SDL_TIMERS_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable the dummy video driver (src/video/dummy/\*.c) */
|
||||||
|
#define SDL_VIDEO_DRIVER_DUMMY 1
|
||||||
|
|
||||||
|
#endif /* _SDL_config_minimal_h */
|
|
@ -0,0 +1,119 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_config_nintendods_h
|
||||||
|
#define _SDL_config_nintendods_h
|
||||||
|
|
||||||
|
#include "SDL_platform.h"
|
||||||
|
|
||||||
|
/* This is a set of defines to configure the SDL features */
|
||||||
|
|
||||||
|
typedef signed char int8_t;
|
||||||
|
typedef unsigned char uint8_t;
|
||||||
|
typedef signed short int16_t;
|
||||||
|
typedef unsigned short uint16_t;
|
||||||
|
typedef signed int int32_t;
|
||||||
|
typedef unsigned int uint32_t;
|
||||||
|
typedef signed long long int64_t;
|
||||||
|
typedef unsigned long long uint64_t;
|
||||||
|
|
||||||
|
/* LiF: __PTRDIFF_TYPE__ was causing errors of conflicting typedefs with the
|
||||||
|
<stdint.h> shipping with devkitARM. copied a similar ifdef from it. */
|
||||||
|
#ifndef __PTRDIFF_TYPE__
|
||||||
|
typedef unsigned long uintptr_t;
|
||||||
|
#else
|
||||||
|
typedef unsigned __PTRDIFF_TYPE__ uintptr_t;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#define SDL_HAS_64BIT_TYPE 1
|
||||||
|
|
||||||
|
/* Useful headers */
|
||||||
|
#define HAVE_SYS_TYPES_H 1
|
||||||
|
#define HAVE_STDIO_H 1
|
||||||
|
#define STDC_HEADERS 1
|
||||||
|
#define HAVE_STRING_H 1
|
||||||
|
#define HAVE_CTYPE_H 1
|
||||||
|
|
||||||
|
/* C library functions */
|
||||||
|
#define HAVE_MALLOC 1
|
||||||
|
#define HAVE_CALLOC 1
|
||||||
|
#define HAVE_REALLOC 1
|
||||||
|
#define HAVE_FREE 1
|
||||||
|
#define HAVE_ALLOCA 1
|
||||||
|
#define HAVE_GETENV 1
|
||||||
|
#define HAVE_PUTENV 1
|
||||||
|
#define HAVE_QSORT 1
|
||||||
|
#define HAVE_ABS 1
|
||||||
|
#define HAVE_BCOPY 1
|
||||||
|
#define HAVE_MEMSET 1
|
||||||
|
#define HAVE_MEMCPY 1
|
||||||
|
#define HAVE_MEMMOVE 1
|
||||||
|
#define HAVE_MEMCMP 1
|
||||||
|
#define HAVE_STRLEN 1
|
||||||
|
#define HAVE_STRDUP 1
|
||||||
|
#define HAVE_INDEX 1
|
||||||
|
#define HAVE_RINDEX 1
|
||||||
|
#define HAVE_STRCHR 1
|
||||||
|
#define HAVE_STRRCHR 1
|
||||||
|
#define HAVE_STRSTR 1
|
||||||
|
#define HAVE_STRTOL 1
|
||||||
|
#define HAVE_STRTOD 1
|
||||||
|
#define HAVE_ATOI 1
|
||||||
|
#define HAVE_ATOF 1
|
||||||
|
#define HAVE_STRCMP 1
|
||||||
|
#define HAVE_STRNCMP 1
|
||||||
|
#define HAVE_STRICMP 1
|
||||||
|
#define HAVE_STRCASECMP 1
|
||||||
|
#define HAVE_SSCANF 1
|
||||||
|
#define HAVE_SNPRINTF 1
|
||||||
|
#define HAVE_VSNPRINTF 1
|
||||||
|
|
||||||
|
/* DS isn't that sophisticated */
|
||||||
|
#define LACKS_SYS_MMAN_H 1
|
||||||
|
|
||||||
|
/* Enable various audio drivers */
|
||||||
|
#define SDL_AUDIO_DRIVER_NDS 1
|
||||||
|
/*#define SDL_AUDIO_DRIVER_DUMMY 1 TODO: uncomment this later*/
|
||||||
|
|
||||||
|
/* DS doesn't have optical media */
|
||||||
|
#define SDL_CDROM_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable various input drivers */
|
||||||
|
#define SDL_JOYSTICK_NDS 1
|
||||||
|
/*#define SDL_JOYSTICK_DUMMY 1 TODO: uncomment this later*/
|
||||||
|
|
||||||
|
/* DS has no dynamic linking afaik */
|
||||||
|
#define SDL_LOADSO_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable various threading systems */
|
||||||
|
/*#define SDL_THREAD_NDS 1*/
|
||||||
|
#define SDL_THREADS_DISABLED 1
|
||||||
|
|
||||||
|
/* Enable various timer systems */
|
||||||
|
#define SDL_TIMER_NDS 1
|
||||||
|
|
||||||
|
/* Enable various video drivers */
|
||||||
|
#define SDL_VIDEO_DRIVER_NDS 1
|
||||||
|
/*#define SDL_VIDEO_DRIVER_DUMMY 1 TODO: uncomment this later*/
|
||||||
|
|
||||||
|
#endif /* _SDL_config_nintendods_h */
|
|
@ -0,0 +1,142 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_config_os2_h
|
||||||
|
#define _SDL_config_os2_h
|
||||||
|
|
||||||
|
#include "SDL_platform.h"
|
||||||
|
|
||||||
|
/* This is a set of defines to configure the SDL features */
|
||||||
|
|
||||||
|
typedef signed char int8_t;
|
||||||
|
typedef unsigned char uint8_t;
|
||||||
|
typedef signed short int16_t;
|
||||||
|
typedef unsigned short uint16_t;
|
||||||
|
typedef signed int int32_t;
|
||||||
|
typedef unsigned int uint32_t;
|
||||||
|
typedef unsigned int size_t;
|
||||||
|
typedef unsigned long uintptr_t;
|
||||||
|
typedef signed long long int64_t;
|
||||||
|
typedef unsigned long long uint64_t;
|
||||||
|
|
||||||
|
#define SDL_HAS_64BIT_TYPE 1
|
||||||
|
|
||||||
|
/* Use Watcom's LIBC */
|
||||||
|
#define HAVE_LIBC 1
|
||||||
|
|
||||||
|
/* Useful headers */
|
||||||
|
#define HAVE_SYS_TYPES_H 1
|
||||||
|
#define HAVE_STDIO_H 1
|
||||||
|
#define STDC_HEADERS 1
|
||||||
|
#define HAVE_STDLIB_H 1
|
||||||
|
#define HAVE_STDARG_H 1
|
||||||
|
#define HAVE_MALLOC_H 1
|
||||||
|
#define HAVE_MEMORY_H 1
|
||||||
|
#define HAVE_STRING_H 1
|
||||||
|
#define HAVE_STRINGS_H 1
|
||||||
|
#define HAVE_INTTYPES_H 1
|
||||||
|
#define HAVE_STDINT_H 1
|
||||||
|
#define HAVE_CTYPE_H 1
|
||||||
|
#define HAVE_MATH_H 1
|
||||||
|
#define HAVE_SIGNAL_H 1
|
||||||
|
|
||||||
|
/* C library functions */
|
||||||
|
#define HAVE_MALLOC 1
|
||||||
|
#define HAVE_CALLOC 1
|
||||||
|
#define HAVE_REALLOC 1
|
||||||
|
#define HAVE_FREE 1
|
||||||
|
#define HAVE_ALLOCA 1
|
||||||
|
#define HAVE_GETENV 1
|
||||||
|
#define HAVE_PUTENV 1
|
||||||
|
#define HAVE_UNSETENV 1
|
||||||
|
#define HAVE_QSORT 1
|
||||||
|
#define HAVE_ABS 1
|
||||||
|
#define HAVE_BCOPY 1
|
||||||
|
#define HAVE_MEMSET 1
|
||||||
|
#define HAVE_MEMCPY 1
|
||||||
|
#define HAVE_MEMMOVE 1
|
||||||
|
#define HAVE_MEMCMP 1
|
||||||
|
#define HAVE_STRLEN 1
|
||||||
|
#define HAVE_STRLCPY 1
|
||||||
|
#define HAVE_STRLCAT 1
|
||||||
|
#define HAVE_STRDUP 1
|
||||||
|
#define HAVE__STRREV 1
|
||||||
|
#define HAVE__STRUPR 1
|
||||||
|
#define HAVE__STRLWR 1
|
||||||
|
#define HAVE_INDEX 1
|
||||||
|
#define HAVE_RINDEX 1
|
||||||
|
#define HAVE_STRCHR 1
|
||||||
|
#define HAVE_STRRCHR 1
|
||||||
|
#define HAVE_STRSTR 1
|
||||||
|
#define HAVE_ITOA 1
|
||||||
|
#define HAVE__LTOA 1
|
||||||
|
#define HAVE__UITOA 1
|
||||||
|
#define HAVE__ULTOA 1
|
||||||
|
#define HAVE_STRTOL 1
|
||||||
|
#define HAVE__I64TOA 1
|
||||||
|
#define HAVE__UI64TOA 1
|
||||||
|
#define HAVE_STRTOLL 1
|
||||||
|
#define HAVE_STRTOD 1
|
||||||
|
#define HAVE_ATOI 1
|
||||||
|
#define HAVE_ATOF 1
|
||||||
|
#define HAVE_STRCMP 1
|
||||||
|
#define HAVE_STRNCMP 1
|
||||||
|
#define HAVE_STRICMP 1
|
||||||
|
#define HAVE_STRCASECMP 1
|
||||||
|
#define HAVE_SSCANF 1
|
||||||
|
#define HAVE_SNPRINTF 1
|
||||||
|
#define HAVE_VSNPRINTF 1
|
||||||
|
#define HAVE_SETJMP 1
|
||||||
|
#define HAVE_CLOCK_GETTIME 1
|
||||||
|
|
||||||
|
/* Enable various audio drivers */
|
||||||
|
#define SDL_AUDIO_DRIVER_DART 1
|
||||||
|
#define SDL_AUDIO_DRIVER_DISK 1
|
||||||
|
#define SDL_AUDIO_DRIVER_DUMMY 1
|
||||||
|
|
||||||
|
/* Enable various cdrom drivers */
|
||||||
|
#define SDL_CDROM_OS2 1
|
||||||
|
|
||||||
|
/* Enable various input drivers */
|
||||||
|
#define SDL_JOYSTICK_OS2 1
|
||||||
|
#define SDL_HAPTIC_DUMMY 1
|
||||||
|
|
||||||
|
/* Enable various shared object loading systems */
|
||||||
|
#define SDL_LOADSO_OS2 1
|
||||||
|
|
||||||
|
/* Enable various threading systems */
|
||||||
|
#define SDL_THREAD_OS2 1
|
||||||
|
|
||||||
|
/* Enable various timer systems */
|
||||||
|
#define SDL_TIMER_OS2 1
|
||||||
|
|
||||||
|
/* Enable various video drivers */
|
||||||
|
#define SDL_VIDEO_DRIVER_DUMMY 1
|
||||||
|
#define SDL_VIDEO_DRIVER_OS2FS 1
|
||||||
|
|
||||||
|
/* Enable OpenGL support */
|
||||||
|
/* Nothing here yet for OS/2... :( */
|
||||||
|
|
||||||
|
/* Enable assembly routines where available */
|
||||||
|
#define SDL_ASSEMBLY_ROUTINES 1
|
||||||
|
|
||||||
|
#endif /* _SDL_config_os2_h */
|
|
@ -0,0 +1,193 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_config_win32_h
|
||||||
|
#define _SDL_config_win32_h
|
||||||
|
|
||||||
|
#include "SDL_platform.h"
|
||||||
|
|
||||||
|
/* This is a set of defines to configure the SDL features */
|
||||||
|
|
||||||
|
#if defined(__GNUC__) || defined(__DMC__)
|
||||||
|
#define HAVE_STDINT_H 1
|
||||||
|
#elif defined(_MSC_VER)
|
||||||
|
typedef signed __int8 int8_t;
|
||||||
|
typedef unsigned __int8 uint8_t;
|
||||||
|
typedef signed __int16 int16_t;
|
||||||
|
typedef unsigned __int16 uint16_t;
|
||||||
|
typedef signed __int32 int32_t;
|
||||||
|
typedef unsigned __int32 uint32_t;
|
||||||
|
typedef signed __int64 int64_t;
|
||||||
|
typedef unsigned __int64 uint64_t;
|
||||||
|
#ifndef _UINTPTR_T_DEFINED
|
||||||
|
#ifdef _WIN64
|
||||||
|
typedef unsigned __int64 uintptr_t;
|
||||||
|
#else
|
||||||
|
typedef unsigned int uintptr_t;
|
||||||
|
#endif
|
||||||
|
#define _UINTPTR_T_DEFINED
|
||||||
|
#endif
|
||||||
|
/* Older Visual C++ headers don't have the Win64-compatible typedefs... */
|
||||||
|
#if ((_MSC_VER <= 1200) && (!defined(DWORD_PTR)))
|
||||||
|
#define DWORD_PTR DWORD
|
||||||
|
#endif
|
||||||
|
#if ((_MSC_VER <= 1200) && (!defined(LONG_PTR)))
|
||||||
|
#define LONG_PTR LONG
|
||||||
|
#endif
|
||||||
|
#else /* !__GNUC__ && !_MSC_VER */
|
||||||
|
typedef signed char int8_t;
|
||||||
|
typedef unsigned char uint8_t;
|
||||||
|
typedef signed short int16_t;
|
||||||
|
typedef unsigned short uint16_t;
|
||||||
|
typedef signed int int32_t;
|
||||||
|
typedef unsigned int uint32_t;
|
||||||
|
typedef signed long long int64_t;
|
||||||
|
typedef unsigned long long uint64_t;
|
||||||
|
#ifndef _SIZE_T_DEFINED_
|
||||||
|
#define _SIZE_T_DEFINED_
|
||||||
|
typedef unsigned int size_t;
|
||||||
|
#endif
|
||||||
|
typedef unsigned int uintptr_t;
|
||||||
|
#endif /* __GNUC__ || _MSC_VER */
|
||||||
|
#define SDL_HAS_64BIT_TYPE 1
|
||||||
|
|
||||||
|
/* Enabled for SDL 1.2 (binary compatibility) */
|
||||||
|
//#define HAVE_LIBC 1
|
||||||
|
#ifdef HAVE_LIBC
|
||||||
|
/* Useful headers */
|
||||||
|
#define HAVE_STDIO_H 1
|
||||||
|
#define STDC_HEADERS 1
|
||||||
|
#define HAVE_STRING_H 1
|
||||||
|
#define HAVE_CTYPE_H 1
|
||||||
|
#define HAVE_MATH_H 1
|
||||||
|
#ifndef _WIN32_WCE
|
||||||
|
#define HAVE_SIGNAL_H 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* C library functions */
|
||||||
|
#define HAVE_MALLOC 1
|
||||||
|
#define HAVE_CALLOC 1
|
||||||
|
#define HAVE_REALLOC 1
|
||||||
|
#define HAVE_FREE 1
|
||||||
|
#define HAVE_ALLOCA 1
|
||||||
|
#define HAVE_QSORT 1
|
||||||
|
#define HAVE_ABS 1
|
||||||
|
#define HAVE_MEMSET 1
|
||||||
|
#define HAVE_MEMCPY 1
|
||||||
|
#define HAVE_MEMMOVE 1
|
||||||
|
#define HAVE_MEMCMP 1
|
||||||
|
#define HAVE_STRLEN 1
|
||||||
|
#define HAVE__STRREV 1
|
||||||
|
#define HAVE__STRUPR 1
|
||||||
|
#define HAVE__STRLWR 1
|
||||||
|
#define HAVE_STRCHR 1
|
||||||
|
#define HAVE_STRRCHR 1
|
||||||
|
#define HAVE_STRSTR 1
|
||||||
|
#define HAVE_ITOA 1
|
||||||
|
#define HAVE__LTOA 1
|
||||||
|
#define HAVE__ULTOA 1
|
||||||
|
#define HAVE_STRTOL 1
|
||||||
|
#define HAVE_STRTOUL 1
|
||||||
|
#define HAVE_STRTOLL 1
|
||||||
|
#define HAVE_STRTOD 1
|
||||||
|
#define HAVE_ATOI 1
|
||||||
|
#define HAVE_ATOF 1
|
||||||
|
#define HAVE_STRCMP 1
|
||||||
|
#define HAVE_STRNCMP 1
|
||||||
|
#define HAVE__STRICMP 1
|
||||||
|
#define HAVE__STRNICMP 1
|
||||||
|
#define HAVE_SSCANF 1
|
||||||
|
#define HAVE_M_PI 1
|
||||||
|
#define HAVE_CEIL 1
|
||||||
|
#define HAVE_COPYSIGN 1
|
||||||
|
#define HAVE_COS 1
|
||||||
|
#define HAVE_COSF 1
|
||||||
|
#define HAVE_FABS 1
|
||||||
|
#define HAVE_FLOOR 1
|
||||||
|
#define HAVE_LOG 1
|
||||||
|
#define HAVE_POW 1
|
||||||
|
#define HAVE_SCALBN 1
|
||||||
|
#define HAVE_SIN 1
|
||||||
|
#define HAVE_SINF 1
|
||||||
|
#define HAVE_SQRT 1
|
||||||
|
#else
|
||||||
|
#define HAVE_STDARG_H 1
|
||||||
|
#define HAVE_STDDEF_H 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Enable various audio drivers */
|
||||||
|
#ifndef _WIN32_WCE
|
||||||
|
#define SDL_AUDIO_DRIVER_DSOUND 1
|
||||||
|
#endif
|
||||||
|
#define SDL_AUDIO_DRIVER_WINWAVEOUT 1
|
||||||
|
#define SDL_AUDIO_DRIVER_DISK 1
|
||||||
|
#define SDL_AUDIO_DRIVER_DUMMY 1
|
||||||
|
|
||||||
|
/* Enable various cdrom drivers */
|
||||||
|
#ifdef _WIN32_WCE
|
||||||
|
#define SDL_CDROM_DISABLED 1
|
||||||
|
#else
|
||||||
|
#define SDL_CDROM_WIN32 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Enable various input drivers */
|
||||||
|
#ifdef _WIN32_WCE
|
||||||
|
#define SDL_JOYSTICK_DISABLED 1
|
||||||
|
#define SDL_HAPTIC_DUMMY 1
|
||||||
|
#else
|
||||||
|
#define SDL_JOYSTICK_DINPUT 1
|
||||||
|
#define SDL_HAPTIC_DINPUT 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Enable various shared object loading systems */
|
||||||
|
#define SDL_LOADSO_WIN32 1
|
||||||
|
|
||||||
|
/* Enable various threading systems */
|
||||||
|
#define SDL_THREAD_WIN32 1
|
||||||
|
|
||||||
|
/* Enable various timer systems */
|
||||||
|
#ifdef _WIN32_WCE
|
||||||
|
#define SDL_TIMER_WINCE 1
|
||||||
|
#else
|
||||||
|
#define SDL_TIMER_WIN32 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Enable various video drivers */
|
||||||
|
#define SDL_VIDEO_DRIVER_DUMMY 1
|
||||||
|
#define SDL_VIDEO_DRIVER_WIN32 1
|
||||||
|
|
||||||
|
#define SDL_VIDEO_RENDER_D3D 1
|
||||||
|
#define SDL_VIDEO_RENDER_GDI 1
|
||||||
|
|
||||||
|
/* Enable OpenGL support */
|
||||||
|
#ifndef _WIN32_WCE
|
||||||
|
#define SDL_VIDEO_OPENGL 1
|
||||||
|
#define SDL_VIDEO_OPENGL_WGL 1
|
||||||
|
#define SDL_VIDEO_RENDER_OGL 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Enable assembly routines (Win64 doesn't have inline asm) */
|
||||||
|
#ifndef _WIN64
|
||||||
|
#define SDL_ASSEMBLY_ROUTINES 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _SDL_config_win32_h */
|
|
@ -0,0 +1,21 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
|
@ -0,0 +1,84 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_cpuinfo.h
|
||||||
|
*
|
||||||
|
* CPU feature detection for SDL
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_cpuinfo_h
|
||||||
|
#define _SDL_cpuinfo_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* This function returns true if the CPU has the RDTSC instruction
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_HasRDTSC(void);
|
||||||
|
|
||||||
|
/* This function returns true if the CPU has MMX features
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_HasMMX(void);
|
||||||
|
|
||||||
|
/* This function returns true if the CPU has MMX Ext. features
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_HasMMXExt(void);
|
||||||
|
|
||||||
|
/* This function returns true if the CPU has 3DNow features
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_Has3DNow(void);
|
||||||
|
|
||||||
|
/* This function returns true if the CPU has 3DNow! Ext. features
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_Has3DNowExt(void);
|
||||||
|
|
||||||
|
/* This function returns true if the CPU has SSE features
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_HasSSE(void);
|
||||||
|
|
||||||
|
/* This function returns true if the CPU has SSE2 features
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_HasSSE2(void);
|
||||||
|
|
||||||
|
/* This function returns true if the CPU has AltiVec features
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_HasAltiVec(void);
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_cpuinfo_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,240 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_endian.h
|
||||||
|
*
|
||||||
|
* Functions for reading and writing endian-specific values
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_endian_h
|
||||||
|
#define _SDL_endian_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
|
||||||
|
/* The two types of endianness */
|
||||||
|
#define SDL_LIL_ENDIAN 1234
|
||||||
|
#define SDL_BIG_ENDIAN 4321
|
||||||
|
|
||||||
|
#ifndef SDL_BYTEORDER /* Not defined in SDL_config.h? */
|
||||||
|
#if defined(__hppa__) || \
|
||||||
|
defined(__m68k__) || defined(mc68000) || defined(_M_M68K) || \
|
||||||
|
(defined(__MIPS__) && defined(__MISPEB__)) || \
|
||||||
|
defined(__ppc__) || defined(__POWERPC__) || defined(_M_PPC) || \
|
||||||
|
defined(__sparc__)
|
||||||
|
#define SDL_BYTEORDER SDL_BIG_ENDIAN
|
||||||
|
#else
|
||||||
|
#define SDL_BYTEORDER SDL_LIL_ENDIAN
|
||||||
|
#endif
|
||||||
|
#endif /* !SDL_BYTEORDER */
|
||||||
|
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Use inline functions for compilers that support them, and static
|
||||||
|
functions for those that do not. Because these functions become
|
||||||
|
static for compilers that do not support inline functions, this
|
||||||
|
header should only be included in files that actually use them.
|
||||||
|
*/
|
||||||
|
#if defined(__GNUC__) && defined(__i386__) && \
|
||||||
|
!(__GNUC__ == 2 && __GNUC_MINOR__ == 95 /* broken gcc version */)
|
||||||
|
static __inline__ Uint16
|
||||||
|
SDL_Swap16(Uint16 x)
|
||||||
|
{
|
||||||
|
__asm__("xchgb %b0,%h0": "=q"(x):"0"(x));
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
#elif defined(__GNUC__) && defined(__x86_64__)
|
||||||
|
static __inline__ Uint16
|
||||||
|
SDL_Swap16(Uint16 x)
|
||||||
|
{
|
||||||
|
__asm__("xchgb %b0,%h0": "=Q"(x):"0"(x));
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
#elif defined(__GNUC__) && (defined(__powerpc__) || defined(__ppc__))
|
||||||
|
static __inline__ Uint16
|
||||||
|
SDL_Swap16(Uint16 x)
|
||||||
|
{
|
||||||
|
Uint16 result;
|
||||||
|
|
||||||
|
__asm__("rlwimi %0,%2,8,16,23": "=&r"(result):"0"(x >> 8), "r"(x));
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
#elif defined(__GNUC__) && (defined(__M68000__) || defined(__M68020__))
|
||||||
|
static __inline__ Uint16
|
||||||
|
SDL_Swap16(Uint16 x)
|
||||||
|
{
|
||||||
|
__asm__("rorw #8,%0": "=d"(x): "0"(x):"cc");
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static __inline__ Uint16
|
||||||
|
SDL_Swap16(Uint16 x)
|
||||||
|
{
|
||||||
|
return ((x << 8) | (x >> 8));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__GNUC__) && defined(__i386__)
|
||||||
|
static __inline__ Uint32
|
||||||
|
SDL_Swap32(Uint32 x)
|
||||||
|
{
|
||||||
|
__asm__("bswap %0": "=r"(x):"0"(x));
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
#elif defined(__GNUC__) && defined(__x86_64__)
|
||||||
|
static __inline__ Uint32
|
||||||
|
SDL_Swap32(Uint32 x)
|
||||||
|
{
|
||||||
|
__asm__("bswapl %0": "=r"(x):"0"(x));
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
#elif defined(__GNUC__) && (defined(__powerpc__) || defined(__ppc__))
|
||||||
|
static __inline__ Uint32
|
||||||
|
SDL_Swap32(Uint32 x)
|
||||||
|
{
|
||||||
|
Uint32 result;
|
||||||
|
|
||||||
|
__asm__("rlwimi %0,%2,24,16,23": "=&r"(result):"0"(x >> 24), "r"(x));
|
||||||
|
__asm__("rlwimi %0,%2,8,8,15": "=&r"(result):"0"(result), "r"(x));
|
||||||
|
__asm__("rlwimi %0,%2,24,0,7": "=&r"(result):"0"(result), "r"(x));
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
#elif defined(__GNUC__) && (defined(__M68000__) || defined(__M68020__))
|
||||||
|
static __inline__ Uint32
|
||||||
|
SDL_Swap32(Uint32 x)
|
||||||
|
{
|
||||||
|
__asm__("rorw #8,%0\n\tswap %0\n\trorw #8,%0": "=d"(x): "0"(x):"cc");
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static __inline__ Uint32
|
||||||
|
SDL_Swap32(Uint32 x)
|
||||||
|
{
|
||||||
|
return ((x << 24) | ((x << 8) & 0x00FF0000) | ((x >> 8) & 0x0000FF00) |
|
||||||
|
(x >> 24));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef SDL_HAS_64BIT_TYPE
|
||||||
|
#if defined(__GNUC__) && defined(__i386__)
|
||||||
|
static __inline__ Uint64
|
||||||
|
SDL_Swap64(Uint64 x)
|
||||||
|
{
|
||||||
|
union
|
||||||
|
{
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
Uint32 a, b;
|
||||||
|
} s;
|
||||||
|
Uint64 u;
|
||||||
|
} v;
|
||||||
|
v.u = x;
|
||||||
|
__asm__("bswapl %0 ; bswapl %1 ; xchgl %0,%1": "=r"(v.s.a), "=r"(v.s.b):"0"(v.s.a),
|
||||||
|
"1"(v.s.
|
||||||
|
b));
|
||||||
|
return v.u;
|
||||||
|
}
|
||||||
|
#elif defined(__GNUC__) && defined(__x86_64__)
|
||||||
|
static __inline__ Uint64
|
||||||
|
SDL_Swap64(Uint64 x)
|
||||||
|
{
|
||||||
|
__asm__("bswapq %0": "=r"(x):"0"(x));
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static __inline__ Uint64
|
||||||
|
SDL_Swap64(Uint64 x)
|
||||||
|
{
|
||||||
|
Uint32 hi, lo;
|
||||||
|
|
||||||
|
/* Separate into high and low 32-bit values and swap them */
|
||||||
|
lo = (Uint32) (x & 0xFFFFFFFF);
|
||||||
|
x >>= 32;
|
||||||
|
hi = (Uint32) (x & 0xFFFFFFFF);
|
||||||
|
x = SDL_Swap32(lo);
|
||||||
|
x <<= 32;
|
||||||
|
x |= SDL_Swap32(hi);
|
||||||
|
return (x);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
/* This is mainly to keep compilers from complaining in SDL code.
|
||||||
|
If there is no real 64-bit datatype, then compilers will complain about
|
||||||
|
the fake 64-bit datatype that SDL provides when it compiles user code.
|
||||||
|
*/
|
||||||
|
#define SDL_Swap64(X) (X)
|
||||||
|
#endif /* SDL_HAS_64BIT_TYPE */
|
||||||
|
|
||||||
|
|
||||||
|
static __inline__ float
|
||||||
|
SDL_SwapFloat(float x)
|
||||||
|
{
|
||||||
|
union
|
||||||
|
{
|
||||||
|
float f;
|
||||||
|
Uint32 ui32;
|
||||||
|
} swapper;
|
||||||
|
swapper.f = x;
|
||||||
|
swapper.ui32 = SDL_Swap32(swapper.ui32);
|
||||||
|
return swapper.f;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Byteswap item from the specified endianness to the native endianness */
|
||||||
|
#if SDL_BYTEORDER == SDL_LIL_ENDIAN
|
||||||
|
#define SDL_SwapLE16(X) (X)
|
||||||
|
#define SDL_SwapLE32(X) (X)
|
||||||
|
#define SDL_SwapLE64(X) (X)
|
||||||
|
#define SDL_SwapFloatLE(X) (X)
|
||||||
|
#define SDL_SwapBE16(X) SDL_Swap16(X)
|
||||||
|
#define SDL_SwapBE32(X) SDL_Swap32(X)
|
||||||
|
#define SDL_SwapBE64(X) SDL_Swap64(X)
|
||||||
|
#define SDL_SwapFloatBE(X) SDL_SwapFloat(X)
|
||||||
|
#else
|
||||||
|
#define SDL_SwapLE16(X) SDL_Swap16(X)
|
||||||
|
#define SDL_SwapLE32(X) SDL_Swap32(X)
|
||||||
|
#define SDL_SwapLE64(X) SDL_Swap64(X)
|
||||||
|
#define SDL_SwapFloatLE(X) SDL_SwapFloat(X)
|
||||||
|
#define SDL_SwapBE16(X) (X)
|
||||||
|
#define SDL_SwapBE32(X) (X)
|
||||||
|
#define SDL_SwapBE64(X) (X)
|
||||||
|
#define SDL_SwapFloatBE(X) (X)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_endian_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,71 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_error.h
|
||||||
|
* Simple error message routines for SDL
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_error_h
|
||||||
|
#define _SDL_error_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Public functions */
|
||||||
|
extern DECLSPEC void SDLCALL SDL_SetError(const char *fmt, ...);
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_GetError(void);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_ClearError(void);
|
||||||
|
|
||||||
|
/* Private error message function - used internally */
|
||||||
|
#define SDL_OutOfMemory() SDL_Error(SDL_ENOMEM)
|
||||||
|
#define SDL_Unsupported() SDL_Error(SDL_UNSUPPORTED)
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
SDL_ENOMEM,
|
||||||
|
SDL_EFREAD,
|
||||||
|
SDL_EFWRITE,
|
||||||
|
SDL_EFSEEK,
|
||||||
|
SDL_UNSUPPORTED,
|
||||||
|
SDL_LASTERROR
|
||||||
|
} SDL_errorcode;
|
||||||
|
extern DECLSPEC void SDLCALL SDL_Error(SDL_errorcode code);
|
||||||
|
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_error_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,486 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_events.h
|
||||||
|
*
|
||||||
|
* Include file for SDL event handling
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_events_h
|
||||||
|
#define _SDL_events_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
#include "SDL_video.h"
|
||||||
|
#include "SDL_keyboard.h"
|
||||||
|
#include "SDL_mouse.h"
|
||||||
|
#include "SDL_joystick.h"
|
||||||
|
#include "SDL_quit.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* General keyboard/mouse state definitions */
|
||||||
|
#define SDL_RELEASED 0
|
||||||
|
#define SDL_PRESSED 1
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \enum SDL_EventType
|
||||||
|
*
|
||||||
|
* \brief The types of events that can be delivered
|
||||||
|
*/
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
SDL_NOEVENT = 0, /**< Unused (do not remove) */
|
||||||
|
SDL_WINDOWEVENT, /**< Window state change */
|
||||||
|
SDL_KEYDOWN, /**< Keys pressed */
|
||||||
|
SDL_KEYUP, /**< Keys released */
|
||||||
|
SDL_TEXTINPUT, /**< Keyboard text input */
|
||||||
|
SDL_MOUSEMOTION, /**< Mouse moved */
|
||||||
|
SDL_MOUSEBUTTONDOWN, /**< Mouse button pressed */
|
||||||
|
SDL_MOUSEBUTTONUP, /**< Mouse button released */
|
||||||
|
SDL_MOUSEWHEEL, /**< Mouse wheel motion */
|
||||||
|
SDL_JOYAXISMOTION, /**< Joystick axis motion */
|
||||||
|
SDL_JOYBALLMOTION, /**< Joystick trackball motion */
|
||||||
|
SDL_JOYHATMOTION, /**< Joystick hat position change */
|
||||||
|
SDL_JOYBUTTONDOWN, /**< Joystick button pressed */
|
||||||
|
SDL_JOYBUTTONUP, /**< Joystick button released */
|
||||||
|
SDL_QUIT, /**< User-requested quit */
|
||||||
|
SDL_SYSWMEVENT, /**< System specific event */
|
||||||
|
SDL_PROXIMITYIN, /**< Proximity In event */
|
||||||
|
SDL_PROXIMITYOUT, /**< Proximity Out event */
|
||||||
|
SDL_EVENT_RESERVED1, /**< Reserved for future use... */
|
||||||
|
SDL_EVENT_RESERVED2,
|
||||||
|
SDL_EVENT_RESERVED3,
|
||||||
|
/* Events SDL_USEREVENT through SDL_MAXEVENTS-1 are for your use */
|
||||||
|
SDL_USEREVENT = 24,
|
||||||
|
/* This last event is only for bounding internal arrays
|
||||||
|
It is the number of bits in the event mask datatype -- Uint32
|
||||||
|
*/
|
||||||
|
SDL_NUMEVENTS = 32
|
||||||
|
} SDL_EventType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \enum SDL_EventMask
|
||||||
|
*
|
||||||
|
* \brief Predefined event masks
|
||||||
|
*/
|
||||||
|
#define SDL_EVENTMASK(X) (1<<(X))
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
SDL_WINDOWEVENTMASK = SDL_EVENTMASK(SDL_WINDOWEVENT),
|
||||||
|
SDL_KEYDOWNMASK = SDL_EVENTMASK(SDL_KEYDOWN),
|
||||||
|
SDL_KEYUPMASK = SDL_EVENTMASK(SDL_KEYUP),
|
||||||
|
SDL_KEYEVENTMASK = SDL_EVENTMASK(SDL_KEYDOWN) | SDL_EVENTMASK(SDL_KEYUP),
|
||||||
|
SDL_TEXTINPUTMASK = SDL_EVENTMASK(SDL_TEXTINPUT),
|
||||||
|
SDL_MOUSEMOTIONMASK = SDL_EVENTMASK(SDL_MOUSEMOTION),
|
||||||
|
SDL_MOUSEBUTTONDOWNMASK = SDL_EVENTMASK(SDL_MOUSEBUTTONDOWN),
|
||||||
|
SDL_MOUSEBUTTONUPMASK = SDL_EVENTMASK(SDL_MOUSEBUTTONUP),
|
||||||
|
SDL_MOUSEWHEELMASK = SDL_EVENTMASK(SDL_MOUSEWHEEL),
|
||||||
|
SDL_MOUSEEVENTMASK = SDL_EVENTMASK(SDL_MOUSEMOTION) |
|
||||||
|
SDL_EVENTMASK(SDL_MOUSEBUTTONDOWN) | SDL_EVENTMASK(SDL_MOUSEBUTTONUP),
|
||||||
|
SDL_JOYAXISMOTIONMASK = SDL_EVENTMASK(SDL_JOYAXISMOTION),
|
||||||
|
SDL_JOYBALLMOTIONMASK = SDL_EVENTMASK(SDL_JOYBALLMOTION),
|
||||||
|
SDL_JOYHATMOTIONMASK = SDL_EVENTMASK(SDL_JOYHATMOTION),
|
||||||
|
SDL_JOYBUTTONDOWNMASK = SDL_EVENTMASK(SDL_JOYBUTTONDOWN),
|
||||||
|
SDL_JOYBUTTONUPMASK = SDL_EVENTMASK(SDL_JOYBUTTONUP),
|
||||||
|
SDL_JOYEVENTMASK = SDL_EVENTMASK(SDL_JOYAXISMOTION) |
|
||||||
|
SDL_EVENTMASK(SDL_JOYBALLMOTION) |
|
||||||
|
SDL_EVENTMASK(SDL_JOYHATMOTION) |
|
||||||
|
SDL_EVENTMASK(SDL_JOYBUTTONDOWN) | SDL_EVENTMASK(SDL_JOYBUTTONUP),
|
||||||
|
SDL_QUITMASK = SDL_EVENTMASK(SDL_QUIT),
|
||||||
|
SDL_SYSWMEVENTMASK = SDL_EVENTMASK(SDL_SYSWMEVENT),
|
||||||
|
SDL_PROXIMITYINMASK = SDL_EVENTMASK(SDL_PROXIMITYIN),
|
||||||
|
SDL_PROXIMITYOUTMASK = SDL_EVENTMASK(SDL_PROXIMITYOUT)
|
||||||
|
} SDL_EventMask;
|
||||||
|
#define SDL_ALLEVENTS 0xFFFFFFFF
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_WindowEvent
|
||||||
|
*
|
||||||
|
* \brief Window state change event data (event.window.*)
|
||||||
|
*/
|
||||||
|
typedef struct SDL_WindowEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_WINDOWEVENT */
|
||||||
|
Uint8 event; /**< SDL_WindowEventID */
|
||||||
|
int data1; /**< event dependent data */
|
||||||
|
int data2; /**< event dependent data */
|
||||||
|
SDL_WindowID windowID; /**< The associated window */
|
||||||
|
} SDL_WindowEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_KeyboardEvent
|
||||||
|
*
|
||||||
|
* \brief Keyboard button event structure (event.key.*)
|
||||||
|
*/
|
||||||
|
typedef struct SDL_KeyboardEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_KEYDOWN or SDL_KEYUP */
|
||||||
|
Uint8 which; /**< The keyboard device index */
|
||||||
|
Uint8 state; /**< SDL_PRESSED or SDL_RELEASED */
|
||||||
|
SDL_keysym keysym; /**< The key that was pressed or released */
|
||||||
|
SDL_WindowID windowID; /**< The window with keyboard focus, if any */
|
||||||
|
} SDL_KeyboardEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_TextInputEvent
|
||||||
|
*
|
||||||
|
* \brief Keyboard text input event structure (event.text.*)
|
||||||
|
*/
|
||||||
|
#define SDL_TEXTINPUTEVENT_TEXT_SIZE (32)
|
||||||
|
typedef struct SDL_TextInputEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_TEXTINPUT */
|
||||||
|
Uint8 which; /**< The keyboard device index */
|
||||||
|
char text[SDL_TEXTINPUTEVENT_TEXT_SIZE]; /**< The input text */
|
||||||
|
SDL_WindowID windowID; /**< The window with keyboard focus, if any */
|
||||||
|
} SDL_TextInputEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_MouseMotionEvent
|
||||||
|
*
|
||||||
|
* \brief Mouse motion event structure (event.motion.*)
|
||||||
|
*/
|
||||||
|
typedef struct SDL_MouseMotionEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_MOUSEMOTION */
|
||||||
|
Uint8 which; /**< The mouse device index */
|
||||||
|
Uint8 state; /**< The current button state */
|
||||||
|
int x; /**< X coordinate, relative to window */
|
||||||
|
int y; /**< Y coordinate, relative to window */
|
||||||
|
int z; /**< Z coordinate, for future use */
|
||||||
|
int pressure; /**< Pressure reported by tablets */
|
||||||
|
int pressure_max; /**< Maximum value of the pressure reported by the device */
|
||||||
|
int pressure_min; /**< Minimum value of the pressure reported by the device */
|
||||||
|
int rotation; /**< For future use */
|
||||||
|
int tilt; /**< For future use */
|
||||||
|
int cursor; /**< The cursor being used in the event */
|
||||||
|
int xrel; /**< The relative motion in the X direction */
|
||||||
|
int yrel; /**< The relative motion in the Y direction */
|
||||||
|
SDL_WindowID windowID; /**< The window with mouse focus, if any */
|
||||||
|
} SDL_MouseMotionEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_MouseButtonEvent
|
||||||
|
*
|
||||||
|
* \brief Mouse button event structure (event.button.*)
|
||||||
|
*/
|
||||||
|
typedef struct SDL_MouseButtonEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_MOUSEBUTTONDOWN or SDL_MOUSEBUTTONUP */
|
||||||
|
Uint8 which; /**< The mouse device index */
|
||||||
|
Uint8 button; /**< The mouse button index */
|
||||||
|
Uint8 state; /**< SDL_PRESSED or SDL_RELEASED */
|
||||||
|
int x; /**< X coordinate, relative to window */
|
||||||
|
int y; /**< Y coordinate, relative to window */
|
||||||
|
SDL_WindowID windowID; /**< The window with mouse focus, if any */
|
||||||
|
} SDL_MouseButtonEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_MouseWheelEvent
|
||||||
|
*
|
||||||
|
* \brief Mouse wheel event structure (event.wheel.*)
|
||||||
|
*/
|
||||||
|
typedef struct SDL_MouseWheelEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_MOUSEWHEEL */
|
||||||
|
Uint8 which; /**< The mouse device index */
|
||||||
|
int x; /**< The amount scrolled horizontally */
|
||||||
|
int y; /**< The amount scrolled vertically */
|
||||||
|
SDL_WindowID windowID; /**< The window with mouse focus, if any */
|
||||||
|
} SDL_MouseWheelEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_JoyAxisEvent
|
||||||
|
*
|
||||||
|
* \brief Joystick axis motion event structure (event.jaxis.*)
|
||||||
|
*/
|
||||||
|
typedef struct SDL_JoyAxisEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_JOYAXISMOTION */
|
||||||
|
Uint8 which; /**< The joystick device index */
|
||||||
|
Uint8 axis; /**< The joystick axis index */
|
||||||
|
int value; /**< The axis value (range: -32768 to 32767) */
|
||||||
|
} SDL_JoyAxisEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_JoyBallEvent
|
||||||
|
*
|
||||||
|
* \brief Joystick trackball motion event structure (event.jball.*)
|
||||||
|
*/
|
||||||
|
typedef struct SDL_JoyBallEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_JOYBALLMOTION */
|
||||||
|
Uint8 which; /**< The joystick device index */
|
||||||
|
Uint8 ball; /**< The joystick trackball index */
|
||||||
|
int xrel; /**< The relative motion in the X direction */
|
||||||
|
int yrel; /**< The relative motion in the Y direction */
|
||||||
|
} SDL_JoyBallEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_JoyHatEvent
|
||||||
|
*
|
||||||
|
* \brief Joystick hat position change event structure (event.jhat.*)
|
||||||
|
*/
|
||||||
|
typedef struct SDL_JoyHatEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_JOYHATMOTION */
|
||||||
|
Uint8 which; /**< The joystick device index */
|
||||||
|
Uint8 hat; /**< The joystick hat index */
|
||||||
|
Uint8 value; /**< The hat position value:
|
||||||
|
SDL_HAT_LEFTUP SDL_HAT_UP SDL_HAT_RIGHTUP
|
||||||
|
SDL_HAT_LEFT SDL_HAT_CENTERED SDL_HAT_RIGHT
|
||||||
|
SDL_HAT_LEFTDOWN SDL_HAT_DOWN SDL_HAT_RIGHTDOWN
|
||||||
|
Note that zero means the POV is centered.
|
||||||
|
*/
|
||||||
|
} SDL_JoyHatEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_JoyButtonEvent
|
||||||
|
*
|
||||||
|
* \brief Joystick button event structure (event.jbutton.*)
|
||||||
|
*/
|
||||||
|
typedef struct SDL_JoyButtonEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_JOYBUTTONDOWN or SDL_JOYBUTTONUP */
|
||||||
|
Uint8 which; /**< The joystick device index */
|
||||||
|
Uint8 button; /**< The joystick button index */
|
||||||
|
Uint8 state; /**< SDL_PRESSED or SDL_RELEASED */
|
||||||
|
} SDL_JoyButtonEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_QuitEvent
|
||||||
|
*
|
||||||
|
* \brief The "quit requested" event
|
||||||
|
*/
|
||||||
|
typedef struct SDL_QuitEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_QUIT */
|
||||||
|
} SDL_QuitEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_UserEvent
|
||||||
|
*
|
||||||
|
* \brief A user-defined event type (event.user.*)
|
||||||
|
*/
|
||||||
|
typedef struct SDL_UserEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_USEREVENT through SDL_NUMEVENTS-1 */
|
||||||
|
int code; /**< User defined event code */
|
||||||
|
void *data1; /**< User defined data pointer */
|
||||||
|
void *data2; /**< User defined data pointer */
|
||||||
|
SDL_WindowID windowID; /**< The associated window if any*/
|
||||||
|
} SDL_UserEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_SysWMEvent
|
||||||
|
*
|
||||||
|
* \brief A video driver dependent system event (event.syswm.*)
|
||||||
|
*
|
||||||
|
* \note If you want to use this event, you should include SDL_syswm.h
|
||||||
|
*/
|
||||||
|
struct SDL_SysWMmsg;
|
||||||
|
typedef struct SDL_SysWMmsg SDL_SysWMmsg;
|
||||||
|
typedef struct SDL_SysWMEvent
|
||||||
|
{
|
||||||
|
Uint8 type; /**< SDL_SYSWMEVENT */
|
||||||
|
SDL_SysWMmsg *msg; /**< driver dependent data, defined in SDL_syswm.h */
|
||||||
|
} SDL_SysWMEvent;
|
||||||
|
|
||||||
|
/* Typedefs for backwards compatibility */
|
||||||
|
typedef struct SDL_ActiveEvent
|
||||||
|
{
|
||||||
|
Uint8 type;
|
||||||
|
Uint8 gain;
|
||||||
|
Uint8 state;
|
||||||
|
} SDL_ActiveEvent;
|
||||||
|
typedef struct SDL_ResizeEvent
|
||||||
|
{
|
||||||
|
Uint8 type;
|
||||||
|
int w;
|
||||||
|
int h;
|
||||||
|
} SDL_ResizeEvent;
|
||||||
|
|
||||||
|
typedef struct SDL_ProximityEvent
|
||||||
|
{
|
||||||
|
Uint8 type;
|
||||||
|
Uint8 which;
|
||||||
|
int cursor;
|
||||||
|
int x;
|
||||||
|
int y;
|
||||||
|
} SDL_ProximityEvent;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \union SDL_Event
|
||||||
|
*
|
||||||
|
* \brief General event structure
|
||||||
|
*/
|
||||||
|
typedef union SDL_Event
|
||||||
|
{
|
||||||
|
Uint8 type; /**< Event type, shared with all events */
|
||||||
|
SDL_WindowEvent window; /**< Window event data */
|
||||||
|
SDL_KeyboardEvent key; /**< Keyboard event data */
|
||||||
|
SDL_TextInputEvent text; /**< Text input event data */
|
||||||
|
SDL_MouseMotionEvent motion; /**< Mouse motion event data */
|
||||||
|
SDL_MouseButtonEvent button; /**< Mouse button event data */
|
||||||
|
SDL_MouseWheelEvent wheel; /**< Mouse wheel event data */
|
||||||
|
SDL_JoyAxisEvent jaxis; /**< Joystick axis event data */
|
||||||
|
SDL_JoyBallEvent jball; /**< Joystick ball event data */
|
||||||
|
SDL_JoyHatEvent jhat; /**< Joystick hat event data */
|
||||||
|
SDL_JoyButtonEvent jbutton; /**< Joystick button event data */
|
||||||
|
SDL_QuitEvent quit; /**< Quit request event data */
|
||||||
|
SDL_UserEvent user; /**< Custom event data */
|
||||||
|
SDL_SysWMEvent syswm; /**< System dependent window event data */
|
||||||
|
SDL_ProximityEvent proximity; /**< Proximity In or Out event */
|
||||||
|
|
||||||
|
/* Temporarily here for backwards compatibility */
|
||||||
|
SDL_ActiveEvent active;
|
||||||
|
SDL_ResizeEvent resize;
|
||||||
|
} SDL_Event;
|
||||||
|
|
||||||
|
|
||||||
|
/* Function prototypes */
|
||||||
|
|
||||||
|
/* Pumps the event loop, gathering events from the input devices.
|
||||||
|
This function updates the event queue and internal input device state.
|
||||||
|
This should only be run in the thread that sets the video mode.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_PumpEvents(void);
|
||||||
|
|
||||||
|
/* Checks the event queue for messages and optionally returns them.
|
||||||
|
If 'action' is SDL_ADDEVENT, up to 'numevents' events will be added to
|
||||||
|
the back of the event queue.
|
||||||
|
If 'action' is SDL_PEEKEVENT, up to 'numevents' events at the front
|
||||||
|
of the event queue, matching 'mask', will be returned and will not
|
||||||
|
be removed from the queue.
|
||||||
|
If 'action' is SDL_GETEVENT, up to 'numevents' events at the front
|
||||||
|
of the event queue, matching 'mask', will be returned and will be
|
||||||
|
removed from the queue.
|
||||||
|
This function returns the number of events actually stored, or -1
|
||||||
|
if there was an error. This function is thread-safe.
|
||||||
|
*/
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
SDL_ADDEVENT,
|
||||||
|
SDL_PEEKEVENT,
|
||||||
|
SDL_GETEVENT
|
||||||
|
} SDL_eventaction;
|
||||||
|
/* */
|
||||||
|
extern DECLSPEC int SDLCALL SDL_PeepEvents(SDL_Event * events, int numevents,
|
||||||
|
SDL_eventaction action,
|
||||||
|
Uint32 mask);
|
||||||
|
|
||||||
|
/* Checks to see if certain event types are in the event queue.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_HasEvent(Uint32 mask);
|
||||||
|
|
||||||
|
/* Polls for currently pending events, and returns 1 if there are any pending
|
||||||
|
events, or 0 if there are none available. If 'event' is not NULL, the next
|
||||||
|
event is removed from the queue and stored in that area.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_PollEvent(SDL_Event * event);
|
||||||
|
|
||||||
|
/* Waits indefinitely for the next available event, returning 1, or 0 if there
|
||||||
|
was an error while waiting for events. If 'event' is not NULL, the next
|
||||||
|
event is removed from the queue and stored in that area.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_WaitEvent(SDL_Event * event);
|
||||||
|
|
||||||
|
/* Add an event to the event queue.
|
||||||
|
This function returns 1 on success, 0 if the event was filtered,
|
||||||
|
or -1 if the event queue was full or there was some other error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_PushEvent(SDL_Event * event);
|
||||||
|
|
||||||
|
/*
|
||||||
|
This function sets up a filter to process all events before they
|
||||||
|
change internal state and are posted to the internal event queue.
|
||||||
|
|
||||||
|
The filter is protypted as:
|
||||||
|
*/
|
||||||
|
typedef int (SDLCALL * SDL_EventFilter) (void *userdata, SDL_Event * event);
|
||||||
|
/*
|
||||||
|
If the filter returns 1, then the event will be added to the internal queue.
|
||||||
|
If it returns 0, then the event will be dropped from the queue, but the
|
||||||
|
internal state will still be updated. This allows selective filtering of
|
||||||
|
dynamically arriving events.
|
||||||
|
|
||||||
|
WARNING: Be very careful of what you do in the event filter function, as
|
||||||
|
it may run in a different thread!
|
||||||
|
|
||||||
|
There is one caveat when dealing with the SDL_QUITEVENT event type. The
|
||||||
|
event filter is only called when the window manager desires to close the
|
||||||
|
application window. If the event filter returns 1, then the window will
|
||||||
|
be closed, otherwise the window will remain open if possible.
|
||||||
|
If the quit event is generated by an interrupt signal, it will bypass the
|
||||||
|
internal queue and be delivered to the application at the next event poll.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_SetEventFilter(SDL_EventFilter filter,
|
||||||
|
void *userdata);
|
||||||
|
|
||||||
|
/*
|
||||||
|
Return the current event filter - can be used to "chain" filters.
|
||||||
|
If there is no event filter set, this function returns SDL_FALSE.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_GetEventFilter(SDL_EventFilter * filter,
|
||||||
|
void **userdata);
|
||||||
|
|
||||||
|
/*
|
||||||
|
Run the filter function on the current event queue, removing any
|
||||||
|
events for which the filter returns 0.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_FilterEvents(SDL_EventFilter filter,
|
||||||
|
void *userdata);
|
||||||
|
|
||||||
|
/*
|
||||||
|
This function allows you to set the state of processing certain events.
|
||||||
|
If 'state' is set to SDL_IGNORE, that event will be automatically dropped
|
||||||
|
from the event queue and will not event be filtered.
|
||||||
|
If 'state' is set to SDL_ENABLE, that event will be processed normally.
|
||||||
|
If 'state' is set to SDL_QUERY, SDL_EventState() will return the
|
||||||
|
current processing state of the specified event.
|
||||||
|
*/
|
||||||
|
#define SDL_QUERY -1
|
||||||
|
#define SDL_IGNORE 0
|
||||||
|
#define SDL_DISABLE 0
|
||||||
|
#define SDL_ENABLE 1
|
||||||
|
extern DECLSPEC Uint8 SDLCALL SDL_EventState(Uint8 type, int state);
|
||||||
|
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_events_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,181 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_joystick.h
|
||||||
|
*
|
||||||
|
* Include file for SDL joystick event handling
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_joystick_h
|
||||||
|
#define _SDL_joystick_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* In order to use these functions, SDL_Init() must have been called
|
||||||
|
with the SDL_INIT_JOYSTICK flag. This causes SDL to scan the system
|
||||||
|
for joysticks, and load appropriate drivers.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* The joystick structure used to identify an SDL joystick */
|
||||||
|
struct _SDL_Joystick;
|
||||||
|
typedef struct _SDL_Joystick SDL_Joystick;
|
||||||
|
|
||||||
|
|
||||||
|
/* Function prototypes */
|
||||||
|
/*
|
||||||
|
* Count the number of joysticks attached to the system
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_NumJoysticks(void);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the implementation dependent name of a joystick.
|
||||||
|
* This can be called before any joysticks are opened.
|
||||||
|
* If no name can be found, this function returns NULL.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC const char *SDLCALL SDL_JoystickName(int device_index);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Open a joystick for use - the index passed as an argument refers to
|
||||||
|
* the N'th joystick on the system. This index is the value which will
|
||||||
|
* identify this joystick in future joystick events.
|
||||||
|
*
|
||||||
|
* This function returns a joystick identifier, or NULL if an error occurred.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_Joystick *SDLCALL SDL_JoystickOpen(int device_index);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Returns 1 if the joystick has been opened, or 0 if it has not.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_JoystickOpened(int device_index);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the device index of an opened joystick.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_JoystickIndex(SDL_Joystick * joystick);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the number of general axis controls on a joystick
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_JoystickNumAxes(SDL_Joystick * joystick);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the number of trackballs on a joystick
|
||||||
|
* Joystick trackballs have only relative motion events associated
|
||||||
|
* with them and their state cannot be polled.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_JoystickNumBalls(SDL_Joystick * joystick);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the number of POV hats on a joystick
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_JoystickNumHats(SDL_Joystick * joystick);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the number of buttons on a joystick
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_JoystickNumButtons(SDL_Joystick * joystick);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Update the current state of the open joysticks.
|
||||||
|
* This is called automatically by the event loop if any joystick
|
||||||
|
* events are enabled.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_JoystickUpdate(void);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Enable/disable joystick event polling.
|
||||||
|
* If joystick events are disabled, you must call SDL_JoystickUpdate()
|
||||||
|
* yourself and check the state of the joystick when you want joystick
|
||||||
|
* information.
|
||||||
|
* The state can be one of SDL_QUERY, SDL_ENABLE or SDL_IGNORE.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_JoystickEventState(int state);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the current state of an axis control on a joystick
|
||||||
|
* The state is a value ranging from -32768 to 32767.
|
||||||
|
* The axis indices start at index 0.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Sint16 SDLCALL SDL_JoystickGetAxis(SDL_Joystick * joystick,
|
||||||
|
int axis);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the current state of a POV hat on a joystick
|
||||||
|
* The return value is one of the following positions:
|
||||||
|
*/
|
||||||
|
#define SDL_HAT_CENTERED 0x00
|
||||||
|
#define SDL_HAT_UP 0x01
|
||||||
|
#define SDL_HAT_RIGHT 0x02
|
||||||
|
#define SDL_HAT_DOWN 0x04
|
||||||
|
#define SDL_HAT_LEFT 0x08
|
||||||
|
#define SDL_HAT_RIGHTUP (SDL_HAT_RIGHT|SDL_HAT_UP)
|
||||||
|
#define SDL_HAT_RIGHTDOWN (SDL_HAT_RIGHT|SDL_HAT_DOWN)
|
||||||
|
#define SDL_HAT_LEFTUP (SDL_HAT_LEFT|SDL_HAT_UP)
|
||||||
|
#define SDL_HAT_LEFTDOWN (SDL_HAT_LEFT|SDL_HAT_DOWN)
|
||||||
|
/*
|
||||||
|
* The hat indices start at index 0.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint8 SDLCALL SDL_JoystickGetHat(SDL_Joystick * joystick,
|
||||||
|
int hat);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the ball axis change since the last poll
|
||||||
|
* This returns 0, or -1 if you passed it invalid parameters.
|
||||||
|
* The ball indices start at index 0.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_JoystickGetBall(SDL_Joystick * joystick,
|
||||||
|
int ball, int *dx, int *dy);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Get the current state of a button on a joystick
|
||||||
|
* The button indices start at index 0.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint8 SDLCALL SDL_JoystickGetButton(SDL_Joystick * joystick,
|
||||||
|
int button);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Close a joystick previously opened with SDL_JoystickOpen()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_JoystickClose(SDL_Joystick * joystick);
|
||||||
|
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_joystick_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,168 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_keyboard.h
|
||||||
|
*
|
||||||
|
* Include file for SDL keyboard event handling
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_keyboard_h
|
||||||
|
#define _SDL_keyboard_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
#include "SDL_keysym.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_keysym
|
||||||
|
*
|
||||||
|
* \brief The SDL keysym structure, used in key events.
|
||||||
|
*/
|
||||||
|
typedef struct SDL_keysym
|
||||||
|
{
|
||||||
|
SDL_scancode scancode; /**< SDL physical key code - see ::SDL_scancode for details */
|
||||||
|
SDLKey sym; /**< SDL virtual key code - see ::SDLKey for details */
|
||||||
|
Uint16 mod; /**< current key modifiers */
|
||||||
|
Uint32 unicode; /**< OBSOLETE, use SDL_TextInputEvent instead */
|
||||||
|
} SDL_keysym;
|
||||||
|
|
||||||
|
/* Function prototypes */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_GetNumKeyboards(void)
|
||||||
|
*
|
||||||
|
* \brief Get the number of keyboard input devices available.
|
||||||
|
*
|
||||||
|
* \sa SDL_SelectKeyboard()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetNumKeyboards(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_SelectKeyboard(int index)
|
||||||
|
*
|
||||||
|
* \brief Set the index of the currently selected keyboard.
|
||||||
|
*
|
||||||
|
* \return The index of the previously selected keyboard.
|
||||||
|
*
|
||||||
|
* \note You can query the currently selected keyboard by passing an index of -1.
|
||||||
|
*
|
||||||
|
* \sa SDL_GetNumKeyboards()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SelectKeyboard(int index);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn Uint8 *SDL_GetKeyboardState(int *numkeys)
|
||||||
|
*
|
||||||
|
* \brief Get a snapshot of the current state of the selected keyboard.
|
||||||
|
*
|
||||||
|
* \param numkeys if non-NULL, receives the length of the returned array.
|
||||||
|
*
|
||||||
|
* \return An array of key states. Indexes into this array are obtained by using ::SDL_scancode values.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
* Uint8 *state = SDL_GetKeyboardState(NULL);
|
||||||
|
* if ( state[SDL_SCANCODE_RETURN)] ) ... <RETURN> is pressed.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint8 *SDLCALL SDL_GetKeyboardState(int *numkeys);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDLMod SDL_GetModState(void)
|
||||||
|
*
|
||||||
|
* \brief Get the current key modifier state for the selected keyboard.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDLMod SDLCALL SDL_GetModState(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn void SDL_SetModState(SDLMod modstate)
|
||||||
|
*
|
||||||
|
* \brief Set the current key modifier state for the selected keyboard.
|
||||||
|
*
|
||||||
|
* \note This does not change the keyboard state, only the key modifier flags.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_SetModState(SDLMod modstate);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDLKey SDL_GetKeyFromScancode(SDL_scancode scancode)
|
||||||
|
*
|
||||||
|
* \brief Get the key code corresponding to the given scancode according to the current keyboard layout.
|
||||||
|
*
|
||||||
|
* See ::SDLKey for details.
|
||||||
|
*
|
||||||
|
* \sa SDL_GetKeyName()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDLKey SDLCALL SDL_GetKeyFromScancode(SDL_scancode scancode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDL_scancode SDL_GetScancodeFromKey(SDLKey key)
|
||||||
|
*
|
||||||
|
* \brief Get the scancode corresponding to the given key code according to the current keyboard layout.
|
||||||
|
*
|
||||||
|
* See ::SDL_scancode for details.
|
||||||
|
*
|
||||||
|
* \sa SDL_GetScancodeName()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_scancode SDLCALL SDL_GetScancodeFromKey(SDLKey key);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn const char *SDL_GetScancodeName(SDL_scancode scancode)
|
||||||
|
*
|
||||||
|
* \brief Get a human-readable name for a scancode.
|
||||||
|
*
|
||||||
|
* \return A pointer to a UTF-8 string that stays valid at least until the next call to this function. If you need it around any longer, you must copy it. If the scancode doesn't have a name, this function returns "".
|
||||||
|
*
|
||||||
|
* \sa SDL_scancode
|
||||||
|
*/
|
||||||
|
extern DECLSPEC const char *SDLCALL SDL_GetScancodeName(SDL_scancode
|
||||||
|
scancode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn const char *SDL_GetKeyName(SDLKey key)
|
||||||
|
*
|
||||||
|
* \brief Get a human-readable name for a key.
|
||||||
|
*
|
||||||
|
* \return A pointer to a UTF-8 string that stays valid at least until the next call to this function. If you need it around any longer, you must copy it. If the key doesn't have a name, this function returns "".
|
||||||
|
*
|
||||||
|
* \sa SDLKey
|
||||||
|
*/
|
||||||
|
extern DECLSPEC const char *SDLCALL SDL_GetKeyName(SDLKey key);
|
||||||
|
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_keyboard_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,277 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_keysym.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_keysym_h
|
||||||
|
#define _SDL_keysym_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_scancode.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \typedef SDLKey
|
||||||
|
*
|
||||||
|
* \brief The SDL virtual key representation.
|
||||||
|
*
|
||||||
|
* Values of this type are used to represent keyboard keys using the current
|
||||||
|
* layout of the keyboard. These values include Unicode values representing
|
||||||
|
* the unmodified character that would be generated by pressing the key, or
|
||||||
|
* an SDLK_* constant for those keys that do not generate characters.
|
||||||
|
*/
|
||||||
|
typedef Sint32 SDLKey;
|
||||||
|
|
||||||
|
#define SDLK_SCANCODE_MASK (1<<30)
|
||||||
|
#define SDL_SCANCODE_TO_KEYCODE(X) (X | SDLK_SCANCODE_MASK)
|
||||||
|
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
SDLK_UNKNOWN = 0,
|
||||||
|
|
||||||
|
SDLK_RETURN = '\r',
|
||||||
|
SDLK_ESCAPE = '\033',
|
||||||
|
SDLK_BACKSPACE = '\b',
|
||||||
|
SDLK_TAB = '\t',
|
||||||
|
SDLK_SPACE = ' ',
|
||||||
|
|
||||||
|
SDLK_CAPSLOCK = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CAPSLOCK),
|
||||||
|
|
||||||
|
SDLK_F1 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F1),
|
||||||
|
SDLK_F2 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F2),
|
||||||
|
SDLK_F3 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F3),
|
||||||
|
SDLK_F4 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F4),
|
||||||
|
SDLK_F5 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F5),
|
||||||
|
SDLK_F6 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F6),
|
||||||
|
SDLK_F7 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F7),
|
||||||
|
SDLK_F8 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F8),
|
||||||
|
SDLK_F9 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F9),
|
||||||
|
SDLK_F10 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F10),
|
||||||
|
SDLK_F11 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F11),
|
||||||
|
SDLK_F12 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F12),
|
||||||
|
|
||||||
|
SDLK_PRINTSCREEN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PRINTSCREEN),
|
||||||
|
SDLK_SCROLLLOCK = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SCROLLLOCK),
|
||||||
|
SDLK_PAUSE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PAUSE),
|
||||||
|
SDLK_INSERT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_INSERT),
|
||||||
|
SDLK_HOME = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_HOME),
|
||||||
|
SDLK_PAGEUP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PAGEUP),
|
||||||
|
SDLK_DELETE = '\177',
|
||||||
|
SDLK_END = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_END),
|
||||||
|
SDLK_PAGEDOWN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PAGEDOWN),
|
||||||
|
SDLK_RIGHT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RIGHT),
|
||||||
|
SDLK_LEFT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_LEFT),
|
||||||
|
SDLK_DOWN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_DOWN),
|
||||||
|
SDLK_UP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_UP),
|
||||||
|
|
||||||
|
SDLK_NUMLOCKCLEAR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_NUMLOCKCLEAR),
|
||||||
|
SDLK_KP_DIVIDE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DIVIDE),
|
||||||
|
SDLK_KP_MULTIPLY = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MULTIPLY),
|
||||||
|
SDLK_KP_MINUS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MINUS),
|
||||||
|
SDLK_KP_PLUS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PLUS),
|
||||||
|
SDLK_KP_ENTER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_ENTER),
|
||||||
|
SDLK_KP_1 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_1),
|
||||||
|
SDLK_KP_2 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_2),
|
||||||
|
SDLK_KP_3 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_3),
|
||||||
|
SDLK_KP_4 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_4),
|
||||||
|
SDLK_KP_5 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_5),
|
||||||
|
SDLK_KP_6 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_6),
|
||||||
|
SDLK_KP_7 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_7),
|
||||||
|
SDLK_KP_8 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_8),
|
||||||
|
SDLK_KP_9 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_9),
|
||||||
|
SDLK_KP_0 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_0),
|
||||||
|
SDLK_KP_PERIOD = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PERIOD),
|
||||||
|
|
||||||
|
SDLK_APPLICATION = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_APPLICATION),
|
||||||
|
SDLK_POWER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_POWER),
|
||||||
|
SDLK_KP_EQUALS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_EQUALS),
|
||||||
|
SDLK_F13 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F13),
|
||||||
|
SDLK_F14 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F14),
|
||||||
|
SDLK_F15 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F15),
|
||||||
|
SDLK_F16 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F16),
|
||||||
|
SDLK_F17 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F17),
|
||||||
|
SDLK_F18 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F18),
|
||||||
|
SDLK_F19 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F19),
|
||||||
|
SDLK_F20 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F20),
|
||||||
|
SDLK_F21 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F21),
|
||||||
|
SDLK_F22 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F22),
|
||||||
|
SDLK_F23 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F23),
|
||||||
|
SDLK_F24 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_F24),
|
||||||
|
SDLK_EXECUTE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_EXECUTE),
|
||||||
|
SDLK_HELP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_HELP),
|
||||||
|
SDLK_MENU = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MENU),
|
||||||
|
SDLK_SELECT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SELECT),
|
||||||
|
SDLK_STOP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_STOP),
|
||||||
|
SDLK_AGAIN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AGAIN),
|
||||||
|
SDLK_UNDO = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_UNDO),
|
||||||
|
SDLK_CUT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CUT),
|
||||||
|
SDLK_COPY = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_COPY),
|
||||||
|
SDLK_PASTE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PASTE),
|
||||||
|
SDLK_FIND = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_FIND),
|
||||||
|
SDLK_MUTE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MUTE),
|
||||||
|
SDLK_VOLUMEUP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_VOLUMEUP),
|
||||||
|
SDLK_VOLUMEDOWN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_VOLUMEDOWN),
|
||||||
|
SDLK_KP_COMMA = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_COMMA),
|
||||||
|
SDLK_KP_EQUALSAS400 =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_EQUALSAS400),
|
||||||
|
|
||||||
|
SDLK_ALTERASE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_ALTERASE),
|
||||||
|
SDLK_SYSREQ = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SYSREQ),
|
||||||
|
SDLK_CANCEL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CANCEL),
|
||||||
|
SDLK_CLEAR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CLEAR),
|
||||||
|
SDLK_PRIOR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_PRIOR),
|
||||||
|
SDLK_RETURN2 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RETURN2),
|
||||||
|
SDLK_SEPARATOR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SEPARATOR),
|
||||||
|
SDLK_OUT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_OUT),
|
||||||
|
SDLK_OPER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_OPER),
|
||||||
|
SDLK_CLEARAGAIN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CLEARAGAIN),
|
||||||
|
SDLK_CRSEL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CRSEL),
|
||||||
|
SDLK_EXSEL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_EXSEL),
|
||||||
|
|
||||||
|
SDLK_KP_00 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_00),
|
||||||
|
SDLK_KP_000 = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_000),
|
||||||
|
SDLK_THOUSANDSSEPARATOR =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_THOUSANDSSEPARATOR),
|
||||||
|
SDLK_DECIMALSEPARATOR =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_DECIMALSEPARATOR),
|
||||||
|
SDLK_CURRENCYUNIT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CURRENCYUNIT),
|
||||||
|
SDLK_CURRENCYSUBUNIT =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CURRENCYSUBUNIT),
|
||||||
|
SDLK_KP_LEFTPAREN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_LEFTPAREN),
|
||||||
|
SDLK_KP_RIGHTPAREN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_RIGHTPAREN),
|
||||||
|
SDLK_KP_LEFTBRACE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_LEFTBRACE),
|
||||||
|
SDLK_KP_RIGHTBRACE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_RIGHTBRACE),
|
||||||
|
SDLK_KP_TAB = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_TAB),
|
||||||
|
SDLK_KP_BACKSPACE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_BACKSPACE),
|
||||||
|
SDLK_KP_A = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_A),
|
||||||
|
SDLK_KP_B = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_B),
|
||||||
|
SDLK_KP_C = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_C),
|
||||||
|
SDLK_KP_D = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_D),
|
||||||
|
SDLK_KP_E = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_E),
|
||||||
|
SDLK_KP_F = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_F),
|
||||||
|
SDLK_KP_XOR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_XOR),
|
||||||
|
SDLK_KP_POWER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_POWER),
|
||||||
|
SDLK_KP_PERCENT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PERCENT),
|
||||||
|
SDLK_KP_LESS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_LESS),
|
||||||
|
SDLK_KP_GREATER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_GREATER),
|
||||||
|
SDLK_KP_AMPERSAND = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_AMPERSAND),
|
||||||
|
SDLK_KP_DBLAMPERSAND =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DBLAMPERSAND),
|
||||||
|
SDLK_KP_VERTICALBAR =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_VERTICALBAR),
|
||||||
|
SDLK_KP_DBLVERTICALBAR =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DBLVERTICALBAR),
|
||||||
|
SDLK_KP_COLON = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_COLON),
|
||||||
|
SDLK_KP_HASH = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_HASH),
|
||||||
|
SDLK_KP_SPACE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_SPACE),
|
||||||
|
SDLK_KP_AT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_AT),
|
||||||
|
SDLK_KP_EXCLAM = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_EXCLAM),
|
||||||
|
SDLK_KP_MEMSTORE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMSTORE),
|
||||||
|
SDLK_KP_MEMRECALL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMRECALL),
|
||||||
|
SDLK_KP_MEMCLEAR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMCLEAR),
|
||||||
|
SDLK_KP_MEMADD = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMADD),
|
||||||
|
SDLK_KP_MEMSUBTRACT =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMSUBTRACT),
|
||||||
|
SDLK_KP_MEMMULTIPLY =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMMULTIPLY),
|
||||||
|
SDLK_KP_MEMDIVIDE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_MEMDIVIDE),
|
||||||
|
SDLK_KP_PLUSMINUS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_PLUSMINUS),
|
||||||
|
SDLK_KP_CLEAR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_CLEAR),
|
||||||
|
SDLK_KP_CLEARENTRY = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_CLEARENTRY),
|
||||||
|
SDLK_KP_BINARY = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_BINARY),
|
||||||
|
SDLK_KP_OCTAL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_OCTAL),
|
||||||
|
SDLK_KP_DECIMAL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_DECIMAL),
|
||||||
|
SDLK_KP_HEXADECIMAL =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KP_HEXADECIMAL),
|
||||||
|
|
||||||
|
SDLK_LCTRL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_LCTRL),
|
||||||
|
SDLK_LSHIFT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_LSHIFT),
|
||||||
|
SDLK_LALT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_LALT),
|
||||||
|
SDLK_LGUI = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_LGUI),
|
||||||
|
SDLK_RCTRL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RCTRL),
|
||||||
|
SDLK_RSHIFT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RSHIFT),
|
||||||
|
SDLK_RALT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RALT),
|
||||||
|
SDLK_RGUI = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_RGUI),
|
||||||
|
|
||||||
|
SDLK_MODE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MODE),
|
||||||
|
|
||||||
|
SDLK_AUDIONEXT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIONEXT),
|
||||||
|
SDLK_AUDIOPREV = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIOPREV),
|
||||||
|
SDLK_AUDIOSTOP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIOSTOP),
|
||||||
|
SDLK_AUDIOPLAY = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIOPLAY),
|
||||||
|
SDLK_AUDIOMUTE = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AUDIOMUTE),
|
||||||
|
SDLK_MEDIASELECT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MEDIASELECT),
|
||||||
|
SDLK_WWW = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_WWW),
|
||||||
|
SDLK_MAIL = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_MAIL),
|
||||||
|
SDLK_CALCULATOR = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_CALCULATOR),
|
||||||
|
SDLK_COMPUTER = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_COMPUTER),
|
||||||
|
SDLK_AC_SEARCH = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_SEARCH),
|
||||||
|
SDLK_AC_HOME = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_HOME),
|
||||||
|
SDLK_AC_BACK = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_BACK),
|
||||||
|
SDLK_AC_FORWARD = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_FORWARD),
|
||||||
|
SDLK_AC_STOP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_STOP),
|
||||||
|
SDLK_AC_REFRESH = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_REFRESH),
|
||||||
|
SDLK_AC_BOOKMARKS = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_AC_BOOKMARKS),
|
||||||
|
|
||||||
|
SDLK_BRIGHTNESSDOWN =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_BRIGHTNESSDOWN),
|
||||||
|
SDLK_BRIGHTNESSUP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_BRIGHTNESSUP),
|
||||||
|
SDLK_DISPLAYSWITCH = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_DISPLAYSWITCH),
|
||||||
|
SDLK_KBDILLUMTOGGLE =
|
||||||
|
SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KBDILLUMTOGGLE),
|
||||||
|
SDLK_KBDILLUMDOWN = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KBDILLUMDOWN),
|
||||||
|
SDLK_KBDILLUMUP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_KBDILLUMUP),
|
||||||
|
SDLK_EJECT = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_EJECT),
|
||||||
|
SDLK_SLEEP = SDL_SCANCODE_TO_KEYCODE(SDL_SCANCODE_SLEEP)
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \enum SDLMod
|
||||||
|
*
|
||||||
|
* \brief Enumeration of valid key mods (possibly OR'd together)
|
||||||
|
*/
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
KMOD_NONE = 0x0000,
|
||||||
|
KMOD_LSHIFT = 0x0001,
|
||||||
|
KMOD_RSHIFT = 0x0002,
|
||||||
|
KMOD_LCTRL = 0x0040,
|
||||||
|
KMOD_RCTRL = 0x0080,
|
||||||
|
KMOD_LALT = 0x0100,
|
||||||
|
KMOD_RALT = 0x0200,
|
||||||
|
KMOD_LGUI = 0x0400,
|
||||||
|
KMOD_RGUI = 0x0800,
|
||||||
|
KMOD_NUM = 0x1000,
|
||||||
|
KMOD_CAPS = 0x2000,
|
||||||
|
KMOD_MODE = 0x4000,
|
||||||
|
KMOD_RESERVED = 0x8000
|
||||||
|
} SDLMod;
|
||||||
|
|
||||||
|
#define KMOD_CTRL (KMOD_LCTRL|KMOD_RCTRL)
|
||||||
|
#define KMOD_SHIFT (KMOD_LSHIFT|KMOD_RSHIFT)
|
||||||
|
#define KMOD_ALT (KMOD_LALT|KMOD_RALT)
|
||||||
|
#define KMOD_GUI (KMOD_LGUI|KMOD_RGUI)
|
||||||
|
|
||||||
|
#endif /* _SDL_keysym_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,82 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_loadso.h
|
||||||
|
*
|
||||||
|
* System dependent library loading routines
|
||||||
|
*
|
||||||
|
* Some things to keep in mind:
|
||||||
|
* - These functions only work on C function names. Other languages may
|
||||||
|
* have name mangling and intrinsic language support that varies from
|
||||||
|
* compiler to compiler.
|
||||||
|
* - Make sure you declare your function pointers with the same calling
|
||||||
|
* convention as the actual library function. Your code will crash
|
||||||
|
* mysteriously if you do not do this.
|
||||||
|
* - Avoid namespace collisions. If you load a symbol from the library,
|
||||||
|
* it is not defined whether or not it goes into the global symbol
|
||||||
|
* namespace for the application. If it does and it conflicts with
|
||||||
|
* symbols in your code or other shared libraries, you will not get
|
||||||
|
* the results you expect. :)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_loadso_h
|
||||||
|
#define _SDL_loadso_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* This function dynamically loads a shared object and returns a pointer
|
||||||
|
* to the object handle (or NULL if there was an error).
|
||||||
|
* The 'sofile' parameter is a system dependent name of the object file.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void *SDLCALL SDL_LoadObject(const char *sofile);
|
||||||
|
|
||||||
|
/* Given an object handle, this function looks up the address of the
|
||||||
|
* named function in the shared object and returns it. This address
|
||||||
|
* is no longer valid after calling SDL_UnloadObject().
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void *SDLCALL SDL_LoadFunction(void *handle,
|
||||||
|
const char *name);
|
||||||
|
|
||||||
|
/* Unload a shared object from memory */
|
||||||
|
extern DECLSPEC void SDLCALL SDL_UnloadObject(void *handle);
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_loadso_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,82 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_main_h
|
||||||
|
#define _SDL_main_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
|
||||||
|
/* Redefine main() on some platforms so that it is called by SDL */
|
||||||
|
|
||||||
|
#if defined(__WIN32__) || \
|
||||||
|
(defined(__MWERKS__) && !defined(__BEOS__)) || \
|
||||||
|
defined(__SYMBIAN32__) || defined(__IPHONEOS__)
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define C_LINKAGE "C"
|
||||||
|
#else
|
||||||
|
#define C_LINKAGE
|
||||||
|
#endif /* __cplusplus */
|
||||||
|
|
||||||
|
/* The application's main() function must be called with C linkage,
|
||||||
|
and should be declared like this:
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C"
|
||||||
|
#endif
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
#define main SDL_main
|
||||||
|
|
||||||
|
/* The prototype for the application's main() function */
|
||||||
|
extern C_LINKAGE int SDL_main(int argc, char *argv[]);
|
||||||
|
|
||||||
|
|
||||||
|
/* From the SDL library code -- needed for registering the app on Win32 */
|
||||||
|
#ifdef __WIN32__
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* This can be called to set the application class at startup */
|
||||||
|
extern DECLSPEC int SDLCALL SDL_RegisterApp(char *name, Uint32 style,
|
||||||
|
void *hInst);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_UnregisterApp(void);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* Need to redefine main()? */
|
||||||
|
|
||||||
|
#endif /* _SDL_main_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,274 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_mouse.h
|
||||||
|
*
|
||||||
|
* Include file for SDL mouse event handling
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_mouse_h
|
||||||
|
#define _SDL_mouse_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
#include "SDL_video.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct SDL_Cursor SDL_Cursor; /* Implementation dependent */
|
||||||
|
|
||||||
|
/* Function prototypes */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_GetNumMice(void)
|
||||||
|
*
|
||||||
|
* \brief Get the number of mouse input devices available.
|
||||||
|
*
|
||||||
|
* \sa SDL_SelectMouse()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetNumMice(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn char* SDL_GetMouseName(int index)
|
||||||
|
*
|
||||||
|
* \brief Gets the name of a mouse with the given index.
|
||||||
|
*
|
||||||
|
* \param index is the index of the mouse, which name is to be returned.
|
||||||
|
*
|
||||||
|
* \return the name of the mouse with the specified index
|
||||||
|
*/
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_GetMouseName(int index);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_SelectMouse(int index)
|
||||||
|
*
|
||||||
|
* \brief Set the index of the currently selected mouse.
|
||||||
|
*
|
||||||
|
* \return The index of the previously selected mouse.
|
||||||
|
*
|
||||||
|
* \note You can query the currently selected mouse by passing an index of -1.
|
||||||
|
*
|
||||||
|
* \sa SDL_GetNumMice()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SelectMouse(int index);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDL_WindowID SDL_GetMouseFocusWindow(int index)
|
||||||
|
*
|
||||||
|
* \brief Get the window which currently has focus for the currently selected mouse.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_WindowID SDLCALL SDL_GetMouseFocusWindow(int index);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_SetRelativeMouseMode(int index, SDL_bool enabled)
|
||||||
|
*
|
||||||
|
* \brief Set relative mouse mode for the currently selected mouse.
|
||||||
|
*
|
||||||
|
* \param enabled Whether or not to enable relative mode
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if relative mode is not supported.
|
||||||
|
*
|
||||||
|
* While the mouse is in relative mode, the cursor is hidden, and the
|
||||||
|
* driver will try to report continuous motion in the current window.
|
||||||
|
* Only relative motion events will be delivered, the mouse position
|
||||||
|
* will not change.
|
||||||
|
*
|
||||||
|
* \note This function will flush any pending mouse motion.
|
||||||
|
*
|
||||||
|
* \sa SDL_GetRelativeMouseMode()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetRelativeMouseMode(int index,
|
||||||
|
SDL_bool enabled);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDL_bool SDL_GetRelativeMouseMode(int index)
|
||||||
|
*
|
||||||
|
* \brief Query whether relative mouse mode is enabled for the currently selected mouse.
|
||||||
|
*
|
||||||
|
* \sa SDL_SetRelativeMouseMode()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_GetRelativeMouseMode(int index);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn Uint8 SDL_GetMouseState(int index, int *x, int *y)
|
||||||
|
*
|
||||||
|
* \brief Retrieve the current state of the currently selected mouse.
|
||||||
|
*
|
||||||
|
* The current button state is returned as a button bitmask, which can
|
||||||
|
* be tested using the SDL_BUTTON(X) macros, and x and y are set to the
|
||||||
|
* mouse cursor position relative to the focus window for the currently
|
||||||
|
* selected mouse. You can pass NULL for either x or y.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint8 SDLCALL SDL_GetMouseState(int index, int *x, int *y);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn Uint8 SDL_GetRelativeMouseState(int index, int *x, int *y)
|
||||||
|
*
|
||||||
|
* \brief Retrieve the state of the currently selected mouse.
|
||||||
|
*
|
||||||
|
* The current button state is returned as a button bitmask, which can
|
||||||
|
* be tested using the SDL_BUTTON(X) macros, and x and y are set to the
|
||||||
|
* mouse deltas since the last call to SDL_GetRelativeMouseState().
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint8 SDLCALL SDL_GetRelativeMouseState(int index, int *x,
|
||||||
|
int *y);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn void SDL_WarpMouseInWindow(SDL_WindowID windowID, int x, int y)
|
||||||
|
*
|
||||||
|
* \brief Moves the currently selected mouse to the given position within the window.
|
||||||
|
*
|
||||||
|
* \param windowID The window to move the mouse into, or 0 for the current mouse focus
|
||||||
|
* \param x The x coordinate within the window
|
||||||
|
* \param y The y coordinate within the window
|
||||||
|
*
|
||||||
|
* \note This function generates a mouse motion event
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_WarpMouseInWindow(SDL_WindowID windowID,
|
||||||
|
int x, int y);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDL_Cursor *SDL_CreateCursor (const Uint8 * data, const Uint8 * mask, int w, int h, int hot_x, int hot_y)
|
||||||
|
*
|
||||||
|
* \brief Create a cursor for the currently selected mouse, using the
|
||||||
|
* specified bitmap data and mask (in MSB format).
|
||||||
|
*
|
||||||
|
* The cursor width must be a multiple of 8 bits.
|
||||||
|
*
|
||||||
|
* The cursor is created in black and white according to the following:
|
||||||
|
* data mask resulting pixel on screen
|
||||||
|
* 0 1 White
|
||||||
|
* 1 1 Black
|
||||||
|
* 0 0 Transparent
|
||||||
|
* 1 0 Inverted color if possible, black if not.
|
||||||
|
*
|
||||||
|
* \sa SDL_FreeCursor()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_Cursor *SDLCALL SDL_CreateCursor(const Uint8 * data,
|
||||||
|
const Uint8 * mask,
|
||||||
|
int w, int h, int hot_x,
|
||||||
|
int hot_y);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn void SDL_SetCursor(SDL_Cursor * cursor)
|
||||||
|
*
|
||||||
|
* \brief Set the active cursor for the currently selected mouse.
|
||||||
|
*
|
||||||
|
* \note The cursor must have been created for the selected mouse.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_SetCursor(SDL_Cursor * cursor);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDL_Cursor *SDL_GetCursor(void)
|
||||||
|
*
|
||||||
|
* \brief Return the active cursor for the currently selected mouse.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_Cursor *SDLCALL SDL_GetCursor(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn void SDL_FreeCursor(SDL_Cursor * cursor)
|
||||||
|
*
|
||||||
|
* \brief Frees a cursor created with SDL_CreateCursor().
|
||||||
|
*
|
||||||
|
* \sa SDL_CreateCursor()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_FreeCursor(SDL_Cursor * cursor);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_ShowCursor(int toggle)
|
||||||
|
*
|
||||||
|
* \brief Toggle whether or not the cursor is shown for the currently selected mouse.
|
||||||
|
*
|
||||||
|
* \param toggle 1 to show the cursor, 0 to hide it, -1 to query the current state.
|
||||||
|
*
|
||||||
|
* \return 1 if the cursor is shown, or 0 if the cursor is hidden.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_ShowCursor(int toggle);
|
||||||
|
|
||||||
|
/* Used as a mask when testing buttons in buttonstate
|
||||||
|
Button 1: Left mouse button
|
||||||
|
Button 2: Middle mouse button
|
||||||
|
Button 3: Right mouse button
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_GetCursorsNumber(int index)
|
||||||
|
*
|
||||||
|
* \brief Gets the number of cursors a pointing device supports.
|
||||||
|
* Useful for tablet users. Useful only under Windows.
|
||||||
|
*
|
||||||
|
* \param index is the index of the pointing device, which number of cursors we
|
||||||
|
* want to receive.
|
||||||
|
*
|
||||||
|
* \return the number of cursors supported by the pointing device. On Windows
|
||||||
|
* if a device is a tablet it returns a number >=1. Normal mice always return 1.
|
||||||
|
* On Linux every device reports one cursor.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetCursorsNumber(int index);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_GetCurrentCursor(int index)
|
||||||
|
*
|
||||||
|
* \brief Returns the index of the current cursor used by a specific pointing
|
||||||
|
* device. Useful only under Windows.
|
||||||
|
*
|
||||||
|
* \param index is the index of the pointing device, which cursor index we want
|
||||||
|
* to receive.
|
||||||
|
*
|
||||||
|
* \return the index of the cursor currently used by a specific pointing device.
|
||||||
|
* Always 0 under Linux. On Windows if the device isn't a tablet it returns 0.
|
||||||
|
* If the device is the tablet it returns the cursor index.
|
||||||
|
* 0 - stylus, 1 - eraser, 2 - cursor.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetCurrentCursor(int index);
|
||||||
|
|
||||||
|
#define SDL_BUTTON(X) (1 << ((X)-1))
|
||||||
|
#define SDL_BUTTON_LEFT 1
|
||||||
|
#define SDL_BUTTON_MIDDLE 2
|
||||||
|
#define SDL_BUTTON_RIGHT 3
|
||||||
|
#define SDL_BUTTON_X1 4
|
||||||
|
#define SDL_BUTTON_X2 5
|
||||||
|
#define SDL_BUTTON_LMASK SDL_BUTTON(SDL_BUTTON_LEFT)
|
||||||
|
#define SDL_BUTTON_MMASK SDL_BUTTON(SDL_BUTTON_MIDDLE)
|
||||||
|
#define SDL_BUTTON_RMASK SDL_BUTTON(SDL_BUTTON_RIGHT)
|
||||||
|
#define SDL_BUTTON_X1MASK SDL_BUTTON(SDL_BUTTON_X1)
|
||||||
|
#define SDL_BUTTON_X2MASK SDL_BUTTON(SDL_BUTTON_X2)
|
||||||
|
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_mouse_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,170 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_mutex_h
|
||||||
|
#define _SDL_mutex_h
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_mutex.h
|
||||||
|
*
|
||||||
|
* Functions to provide thread synchronization primitives
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Synchronization functions which can time out return this value
|
||||||
|
if they time out.
|
||||||
|
*/
|
||||||
|
#define SDL_MUTEX_TIMEDOUT 1
|
||||||
|
|
||||||
|
/* This is the timeout value which corresponds to never time out */
|
||||||
|
#define SDL_MUTEX_MAXWAIT (~(Uint32)0)
|
||||||
|
|
||||||
|
|
||||||
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||||
|
/* Mutex functions */
|
||||||
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||||
|
|
||||||
|
/* The SDL mutex structure, defined in SDL_mutex.c */
|
||||||
|
struct SDL_mutex;
|
||||||
|
typedef struct SDL_mutex SDL_mutex;
|
||||||
|
|
||||||
|
/* Create a mutex, initialized unlocked */
|
||||||
|
extern DECLSPEC SDL_mutex *SDLCALL SDL_CreateMutex(void);
|
||||||
|
|
||||||
|
/* Lock the mutex (Returns 0, or -1 on error) */
|
||||||
|
#define SDL_LockMutex(m) SDL_mutexP(m)
|
||||||
|
extern DECLSPEC int SDLCALL SDL_mutexP(SDL_mutex * mutex);
|
||||||
|
|
||||||
|
/* Unlock the mutex (Returns 0, or -1 on error)
|
||||||
|
It is an error to unlock a mutex that has not been locked by
|
||||||
|
the current thread, and doing so results in undefined behavior.
|
||||||
|
*/
|
||||||
|
#define SDL_UnlockMutex(m) SDL_mutexV(m)
|
||||||
|
extern DECLSPEC int SDLCALL SDL_mutexV(SDL_mutex * mutex);
|
||||||
|
|
||||||
|
/* Destroy a mutex */
|
||||||
|
extern DECLSPEC void SDLCALL SDL_DestroyMutex(SDL_mutex * mutex);
|
||||||
|
|
||||||
|
|
||||||
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||||
|
/* Semaphore functions */
|
||||||
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||||
|
|
||||||
|
/* The SDL semaphore structure, defined in SDL_sem.c */
|
||||||
|
struct SDL_semaphore;
|
||||||
|
typedef struct SDL_semaphore SDL_sem;
|
||||||
|
|
||||||
|
/* Create a semaphore, initialized with value, returns NULL on failure. */
|
||||||
|
extern DECLSPEC SDL_sem *SDLCALL SDL_CreateSemaphore(Uint32 initial_value);
|
||||||
|
|
||||||
|
/* Destroy a semaphore */
|
||||||
|
extern DECLSPEC void SDLCALL SDL_DestroySemaphore(SDL_sem * sem);
|
||||||
|
|
||||||
|
/* This function suspends the calling thread until the semaphore pointed
|
||||||
|
* to by sem has a positive count. It then atomically decreases the semaphore
|
||||||
|
* count.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SemWait(SDL_sem * sem);
|
||||||
|
|
||||||
|
/* Non-blocking variant of SDL_SemWait(), returns 0 if the wait succeeds,
|
||||||
|
SDL_MUTEX_TIMEDOUT if the wait would block, and -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SemTryWait(SDL_sem * sem);
|
||||||
|
|
||||||
|
/* Variant of SDL_SemWait() with a timeout in milliseconds, returns 0 if
|
||||||
|
the wait succeeds, SDL_MUTEX_TIMEDOUT if the wait does not succeed in
|
||||||
|
the allotted time, and -1 on error.
|
||||||
|
On some platforms this function is implemented by looping with a delay
|
||||||
|
of 1 ms, and so should be avoided if possible.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SemWaitTimeout(SDL_sem * sem, Uint32 ms);
|
||||||
|
|
||||||
|
/* Atomically increases the semaphore's count (not blocking), returns 0,
|
||||||
|
or -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SemPost(SDL_sem * sem);
|
||||||
|
|
||||||
|
/* Returns the current count of the semaphore */
|
||||||
|
extern DECLSPEC Uint32 SDLCALL SDL_SemValue(SDL_sem * sem);
|
||||||
|
|
||||||
|
|
||||||
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||||
|
/* Condition variable functions */
|
||||||
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||||
|
|
||||||
|
/* The SDL condition variable structure, defined in SDL_cond.c */
|
||||||
|
struct SDL_cond;
|
||||||
|
typedef struct SDL_cond SDL_cond;
|
||||||
|
|
||||||
|
/* Create a condition variable */
|
||||||
|
extern DECLSPEC SDL_cond *SDLCALL SDL_CreateCond(void);
|
||||||
|
|
||||||
|
/* Destroy a condition variable */
|
||||||
|
extern DECLSPEC void SDLCALL SDL_DestroyCond(SDL_cond * cond);
|
||||||
|
|
||||||
|
/* Restart one of the threads that are waiting on the condition variable,
|
||||||
|
returns 0 or -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CondSignal(SDL_cond * cond);
|
||||||
|
|
||||||
|
/* Restart all threads that are waiting on the condition variable,
|
||||||
|
returns 0 or -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CondBroadcast(SDL_cond * cond);
|
||||||
|
|
||||||
|
/* Wait on the condition variable, unlocking the provided mutex.
|
||||||
|
The mutex must be locked before entering this function!
|
||||||
|
The mutex is re-locked once the condition variable is signaled.
|
||||||
|
Returns 0 when it is signaled, or -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CondWait(SDL_cond * cond, SDL_mutex * mut);
|
||||||
|
|
||||||
|
/* Waits for at most 'ms' milliseconds, and returns 0 if the condition
|
||||||
|
variable is signaled, SDL_MUTEX_TIMEDOUT if the condition is not
|
||||||
|
signaled in the allotted time, and -1 on error.
|
||||||
|
On some platforms this function is implemented by looping with a delay
|
||||||
|
of 1 ms, and so should be avoided if possible.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_CondWaitTimeout(SDL_cond * cond,
|
||||||
|
SDL_mutex * mutex, Uint32 ms);
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_mutex_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,11 @@
|
||||||
|
|
||||||
|
#ifndef _SDLname_h_
|
||||||
|
#define _SDLname_h_
|
||||||
|
|
||||||
|
#if defined(__STDC__) || defined(__cplusplus)
|
||||||
|
#define NeedFunctionPrototypes 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define SDL_NAME(X) SDL_##X
|
||||||
|
|
||||||
|
#endif /* _SDLname_h_ */
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,948 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
This is a simple file to encapsulate the OpenGL ES API headers.
|
||||||
|
Headers copied from The Kronos Group website.
|
||||||
|
http://www.khronos.org/opengles/
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __gles_h_
|
||||||
|
#define __gles_h_
|
||||||
|
|
||||||
|
/* $Id: gl.h 4533 2007-11-26 11:19:35Z markc $ */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C"
|
||||||
|
{
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __IPHONEOS__
|
||||||
|
#include <OpenGLES/ES1/gl.h> /* Header File For The OpenGL ES Library */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef APIENTRY
|
||||||
|
#define APIENTRY
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef GL_APIENTRY
|
||||||
|
#define GL_APIENTRY
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
** License Applicability. Except to the extent portions of this file are
|
||||||
|
** made subject to an alternative license as permitted in the SGI Free
|
||||||
|
** Software License B, Version 1.0 (the "License"), the contents of this
|
||||||
|
** file are subject only to the provisions of the License. You may not use
|
||||||
|
** this file except in compliance with the License. You may obtain a copy
|
||||||
|
** of the License at Silicon Graphics, Inc., attn: Legal Services, 1600
|
||||||
|
** Amphitheatre Parkway, Mountain View, CA 94043-1351, or at:
|
||||||
|
**
|
||||||
|
** http://oss.sgi.com/projects/FreeB
|
||||||
|
**
|
||||||
|
** Note that, as provided in the License, the Software is distributed on an
|
||||||
|
** "AS IS" basis, with ALL EXPRESS AND IMPLIED WARRANTIES AND CONDITIONS
|
||||||
|
** DISCLAIMED, INCLUDING, WITHOUT LIMITATION, ANY IMPLIED WARRANTIES AND
|
||||||
|
** CONDITIONS OF MERCHANTABILITY, SATISFACTORY QUALITY, FITNESS FOR A
|
||||||
|
** PARTICULAR PURPOSE, AND NON-INFRINGEMENT.
|
||||||
|
**
|
||||||
|
** Original Code. The Original Code is: OpenGL Sample Implementation,
|
||||||
|
** Version 1.2.1, released January 26, 2000, developed by Silicon Graphics,
|
||||||
|
** Inc. The Original Code is Copyright (c) 1991-2000 Silicon Graphics, Inc.
|
||||||
|
** Copyright in any portions created by third parties is as indicated
|
||||||
|
** elsewhere herein. All Rights Reserved.
|
||||||
|
**
|
||||||
|
** Additional Notice Provisions: The application programming interfaces
|
||||||
|
** established by SGI in conjunction with the Original Code are The
|
||||||
|
** OpenGL(R) Graphics System: A Specification (Version 1.2.1), released
|
||||||
|
** April 1, 1999; The OpenGL(R) Graphics System Utility Library (Version
|
||||||
|
** 1.3), released November 4, 1998; and OpenGL(R) Graphics with the X
|
||||||
|
** Window System(R) (Version 1.3), released October 19, 1998. This software
|
||||||
|
** was created using the OpenGL(R) version 1.2.1 Sample Implementation
|
||||||
|
** published by SGI, but has not been independently verified as being
|
||||||
|
** compliant with the OpenGL(R) version 1.2.1 Specification.
|
||||||
|
*/
|
||||||
|
|
||||||
|
typedef unsigned int GLenum;
|
||||||
|
typedef unsigned char GLboolean;
|
||||||
|
typedef unsigned int GLbitfield;
|
||||||
|
typedef signed char GLbyte;
|
||||||
|
typedef short GLshort;
|
||||||
|
typedef int GLint;
|
||||||
|
typedef int GLsizei;
|
||||||
|
typedef unsigned char GLubyte;
|
||||||
|
typedef unsigned short GLushort;
|
||||||
|
typedef unsigned int GLuint;
|
||||||
|
typedef float GLfloat;
|
||||||
|
typedef float GLclampf;
|
||||||
|
typedef void GLvoid;
|
||||||
|
typedef int GLfixed;
|
||||||
|
typedef int GLclampx;
|
||||||
|
|
||||||
|
typedef int GLintptr;
|
||||||
|
typedef int GLsizeiptr;
|
||||||
|
|
||||||
|
|
||||||
|
/*************************************************************/
|
||||||
|
|
||||||
|
/* OpenGL ES core versions */
|
||||||
|
#define GL_VERSION_ES_CM_1_0 1
|
||||||
|
#define GL_VERSION_ES_CL_1_0 1
|
||||||
|
#define GL_VERSION_ES_CM_1_1 1
|
||||||
|
#define GL_VERSION_ES_CL_1_1 1
|
||||||
|
|
||||||
|
/* ClearBufferMask */
|
||||||
|
#define GL_DEPTH_BUFFER_BIT 0x00000100
|
||||||
|
#define GL_STENCIL_BUFFER_BIT 0x00000400
|
||||||
|
#define GL_COLOR_BUFFER_BIT 0x00004000
|
||||||
|
|
||||||
|
/* Boolean */
|
||||||
|
#define GL_FALSE 0
|
||||||
|
#define GL_TRUE 1
|
||||||
|
|
||||||
|
/* BeginMode */
|
||||||
|
#define GL_POINTS 0x0000
|
||||||
|
#define GL_LINES 0x0001
|
||||||
|
#define GL_LINE_LOOP 0x0002
|
||||||
|
#define GL_LINE_STRIP 0x0003
|
||||||
|
#define GL_TRIANGLES 0x0004
|
||||||
|
#define GL_TRIANGLE_STRIP 0x0005
|
||||||
|
#define GL_TRIANGLE_FAN 0x0006
|
||||||
|
|
||||||
|
/* AlphaFunction */
|
||||||
|
#define GL_NEVER 0x0200
|
||||||
|
#define GL_LESS 0x0201
|
||||||
|
#define GL_EQUAL 0x0202
|
||||||
|
#define GL_LEQUAL 0x0203
|
||||||
|
#define GL_GREATER 0x0204
|
||||||
|
#define GL_NOTEQUAL 0x0205
|
||||||
|
#define GL_GEQUAL 0x0206
|
||||||
|
#define GL_ALWAYS 0x0207
|
||||||
|
|
||||||
|
/* BlendingFactorDest */
|
||||||
|
#define GL_ZERO 0
|
||||||
|
#define GL_ONE 1
|
||||||
|
#define GL_SRC_COLOR 0x0300
|
||||||
|
#define GL_ONE_MINUS_SRC_COLOR 0x0301
|
||||||
|
#define GL_SRC_ALPHA 0x0302
|
||||||
|
#define GL_ONE_MINUS_SRC_ALPHA 0x0303
|
||||||
|
#define GL_DST_ALPHA 0x0304
|
||||||
|
#define GL_ONE_MINUS_DST_ALPHA 0x0305
|
||||||
|
|
||||||
|
/* BlendingFactorSrc */
|
||||||
|
/* GL_ZERO */
|
||||||
|
/* GL_ONE */
|
||||||
|
#define GL_DST_COLOR 0x0306
|
||||||
|
#define GL_ONE_MINUS_DST_COLOR 0x0307
|
||||||
|
#define GL_SRC_ALPHA_SATURATE 0x0308
|
||||||
|
/* GL_SRC_ALPHA */
|
||||||
|
/* GL_ONE_MINUS_SRC_ALPHA */
|
||||||
|
/* GL_DST_ALPHA */
|
||||||
|
/* GL_ONE_MINUS_DST_ALPHA */
|
||||||
|
|
||||||
|
/* ClipPlaneName */
|
||||||
|
#define GL_CLIP_PLANE0 0x3000
|
||||||
|
#define GL_CLIP_PLANE1 0x3001
|
||||||
|
#define GL_CLIP_PLANE2 0x3002
|
||||||
|
#define GL_CLIP_PLANE3 0x3003
|
||||||
|
#define GL_CLIP_PLANE4 0x3004
|
||||||
|
#define GL_CLIP_PLANE5 0x3005
|
||||||
|
|
||||||
|
/* ColorMaterialFace */
|
||||||
|
/* GL_FRONT_AND_BACK */
|
||||||
|
|
||||||
|
/* ColorMaterialParameter */
|
||||||
|
/* GL_AMBIENT_AND_DIFFUSE */
|
||||||
|
|
||||||
|
/* ColorPointerType */
|
||||||
|
/* GL_UNSIGNED_BYTE */
|
||||||
|
/* GL_FLOAT */
|
||||||
|
/* GL_FIXED */
|
||||||
|
|
||||||
|
/* CullFaceMode */
|
||||||
|
#define GL_FRONT 0x0404
|
||||||
|
#define GL_BACK 0x0405
|
||||||
|
#define GL_FRONT_AND_BACK 0x0408
|
||||||
|
|
||||||
|
/* DepthFunction */
|
||||||
|
/* GL_NEVER */
|
||||||
|
/* GL_LESS */
|
||||||
|
/* GL_EQUAL */
|
||||||
|
/* GL_LEQUAL */
|
||||||
|
/* GL_GREATER */
|
||||||
|
/* GL_NOTEQUAL */
|
||||||
|
/* GL_GEQUAL */
|
||||||
|
/* GL_ALWAYS */
|
||||||
|
|
||||||
|
/* EnableCap */
|
||||||
|
#define GL_FOG 0x0B60
|
||||||
|
#define GL_LIGHTING 0x0B50
|
||||||
|
#define GL_TEXTURE_2D 0x0DE1
|
||||||
|
#define GL_CULL_FACE 0x0B44
|
||||||
|
#define GL_ALPHA_TEST 0x0BC0
|
||||||
|
#define GL_BLEND 0x0BE2
|
||||||
|
#define GL_COLOR_LOGIC_OP 0x0BF2
|
||||||
|
#define GL_DITHER 0x0BD0
|
||||||
|
#define GL_STENCIL_TEST 0x0B90
|
||||||
|
#define GL_DEPTH_TEST 0x0B71
|
||||||
|
/* GL_LIGHT0 */
|
||||||
|
/* GL_LIGHT1 */
|
||||||
|
/* GL_LIGHT2 */
|
||||||
|
/* GL_LIGHT3 */
|
||||||
|
/* GL_LIGHT4 */
|
||||||
|
/* GL_LIGHT5 */
|
||||||
|
/* GL_LIGHT6 */
|
||||||
|
/* GL_LIGHT7 */
|
||||||
|
#define GL_POINT_SMOOTH 0x0B10
|
||||||
|
#define GL_LINE_SMOOTH 0x0B20
|
||||||
|
#define GL_SCISSOR_TEST 0x0C11
|
||||||
|
#define GL_COLOR_MATERIAL 0x0B57
|
||||||
|
#define GL_NORMALIZE 0x0BA1
|
||||||
|
#define GL_RESCALE_NORMAL 0x803A
|
||||||
|
#define GL_POLYGON_OFFSET_FILL 0x8037
|
||||||
|
#define GL_VERTEX_ARRAY 0x8074
|
||||||
|
#define GL_NORMAL_ARRAY 0x8075
|
||||||
|
#define GL_COLOR_ARRAY 0x8076
|
||||||
|
#define GL_TEXTURE_COORD_ARRAY 0x8078
|
||||||
|
#define GL_MULTISAMPLE 0x809D
|
||||||
|
#define GL_SAMPLE_ALPHA_TO_COVERAGE 0x809E
|
||||||
|
#define GL_SAMPLE_ALPHA_TO_ONE 0x809F
|
||||||
|
#define GL_SAMPLE_COVERAGE 0x80A0
|
||||||
|
|
||||||
|
/* ErrorCode */
|
||||||
|
#define GL_NO_ERROR 0
|
||||||
|
#define GL_INVALID_ENUM 0x0500
|
||||||
|
#define GL_INVALID_VALUE 0x0501
|
||||||
|
#define GL_INVALID_OPERATION 0x0502
|
||||||
|
#define GL_STACK_OVERFLOW 0x0503
|
||||||
|
#define GL_STACK_UNDERFLOW 0x0504
|
||||||
|
#define GL_OUT_OF_MEMORY 0x0505
|
||||||
|
|
||||||
|
/* FogMode */
|
||||||
|
/* GL_LINEAR */
|
||||||
|
#define GL_EXP 0x0800
|
||||||
|
#define GL_EXP2 0x0801
|
||||||
|
|
||||||
|
/* FogParameter */
|
||||||
|
#define GL_FOG_DENSITY 0x0B62
|
||||||
|
#define GL_FOG_START 0x0B63
|
||||||
|
#define GL_FOG_END 0x0B64
|
||||||
|
#define GL_FOG_MODE 0x0B65
|
||||||
|
#define GL_FOG_COLOR 0x0B66
|
||||||
|
|
||||||
|
/* FrontFaceDirection */
|
||||||
|
#define GL_CW 0x0900
|
||||||
|
#define GL_CCW 0x0901
|
||||||
|
|
||||||
|
/* GetPName */
|
||||||
|
#define GL_CURRENT_COLOR 0x0B00
|
||||||
|
#define GL_CURRENT_NORMAL 0x0B02
|
||||||
|
#define GL_CURRENT_TEXTURE_COORDS 0x0B03
|
||||||
|
#define GL_POINT_SIZE 0x0B11
|
||||||
|
#define GL_POINT_SIZE_MIN 0x8126
|
||||||
|
#define GL_POINT_SIZE_MAX 0x8127
|
||||||
|
#define GL_POINT_FADE_THRESHOLD_SIZE 0x8128
|
||||||
|
#define GL_POINT_DISTANCE_ATTENUATION 0x8129
|
||||||
|
#define GL_SMOOTH_POINT_SIZE_RANGE 0x0B12
|
||||||
|
#define GL_LINE_WIDTH 0x0B21
|
||||||
|
#define GL_SMOOTH_LINE_WIDTH_RANGE 0x0B22
|
||||||
|
#define GL_ALIASED_POINT_SIZE_RANGE 0x846D
|
||||||
|
#define GL_ALIASED_LINE_WIDTH_RANGE 0x846E
|
||||||
|
#define GL_CULL_FACE_MODE 0x0B45
|
||||||
|
#define GL_FRONT_FACE 0x0B46
|
||||||
|
#define GL_SHADE_MODEL 0x0B54
|
||||||
|
#define GL_DEPTH_RANGE 0x0B70
|
||||||
|
#define GL_DEPTH_WRITEMASK 0x0B72
|
||||||
|
#define GL_DEPTH_CLEAR_VALUE 0x0B73
|
||||||
|
#define GL_DEPTH_FUNC 0x0B74
|
||||||
|
#define GL_STENCIL_CLEAR_VALUE 0x0B91
|
||||||
|
#define GL_STENCIL_FUNC 0x0B92
|
||||||
|
#define GL_STENCIL_VALUE_MASK 0x0B93
|
||||||
|
#define GL_STENCIL_FAIL 0x0B94
|
||||||
|
#define GL_STENCIL_PASS_DEPTH_FAIL 0x0B95
|
||||||
|
#define GL_STENCIL_PASS_DEPTH_PASS 0x0B96
|
||||||
|
#define GL_STENCIL_REF 0x0B97
|
||||||
|
#define GL_STENCIL_WRITEMASK 0x0B98
|
||||||
|
#define GL_MATRIX_MODE 0x0BA0
|
||||||
|
#define GL_VIEWPORT 0x0BA2
|
||||||
|
#define GL_MODELVIEW_STACK_DEPTH 0x0BA3
|
||||||
|
#define GL_PROJECTION_STACK_DEPTH 0x0BA4
|
||||||
|
#define GL_TEXTURE_STACK_DEPTH 0x0BA5
|
||||||
|
#define GL_MODELVIEW_MATRIX 0x0BA6
|
||||||
|
#define GL_PROJECTION_MATRIX 0x0BA7
|
||||||
|
#define GL_TEXTURE_MATRIX 0x0BA8
|
||||||
|
#define GL_ALPHA_TEST_FUNC 0x0BC1
|
||||||
|
#define GL_ALPHA_TEST_REF 0x0BC2
|
||||||
|
#define GL_BLEND_DST 0x0BE0
|
||||||
|
#define GL_BLEND_SRC 0x0BE1
|
||||||
|
#define GL_LOGIC_OP_MODE 0x0BF0
|
||||||
|
#define GL_SCISSOR_BOX 0x0C10
|
||||||
|
#define GL_SCISSOR_TEST 0x0C11
|
||||||
|
#define GL_COLOR_CLEAR_VALUE 0x0C22
|
||||||
|
#define GL_COLOR_WRITEMASK 0x0C23
|
||||||
|
#define GL_UNPACK_ALIGNMENT 0x0CF5
|
||||||
|
#define GL_PACK_ALIGNMENT 0x0D05
|
||||||
|
#define GL_MAX_LIGHTS 0x0D31
|
||||||
|
#define GL_MAX_CLIP_PLANES 0x0D32
|
||||||
|
#define GL_MAX_TEXTURE_SIZE 0x0D33
|
||||||
|
#define GL_MAX_MODELVIEW_STACK_DEPTH 0x0D36
|
||||||
|
#define GL_MAX_PROJECTION_STACK_DEPTH 0x0D38
|
||||||
|
#define GL_MAX_TEXTURE_STACK_DEPTH 0x0D39
|
||||||
|
#define GL_MAX_VIEWPORT_DIMS 0x0D3A
|
||||||
|
#define GL_MAX_TEXTURE_UNITS 0x84E2
|
||||||
|
#define GL_SUBPIXEL_BITS 0x0D50
|
||||||
|
#define GL_RED_BITS 0x0D52
|
||||||
|
#define GL_GREEN_BITS 0x0D53
|
||||||
|
#define GL_BLUE_BITS 0x0D54
|
||||||
|
#define GL_ALPHA_BITS 0x0D55
|
||||||
|
#define GL_DEPTH_BITS 0x0D56
|
||||||
|
#define GL_STENCIL_BITS 0x0D57
|
||||||
|
#define GL_POLYGON_OFFSET_UNITS 0x2A00
|
||||||
|
#define GL_POLYGON_OFFSET_FILL 0x8037
|
||||||
|
#define GL_POLYGON_OFFSET_FACTOR 0x8038
|
||||||
|
#define GL_TEXTURE_BINDING_2D 0x8069
|
||||||
|
#define GL_VERTEX_ARRAY_SIZE 0x807A
|
||||||
|
#define GL_VERTEX_ARRAY_TYPE 0x807B
|
||||||
|
#define GL_VERTEX_ARRAY_STRIDE 0x807C
|
||||||
|
#define GL_NORMAL_ARRAY_TYPE 0x807E
|
||||||
|
#define GL_NORMAL_ARRAY_STRIDE 0x807F
|
||||||
|
#define GL_COLOR_ARRAY_SIZE 0x8081
|
||||||
|
#define GL_COLOR_ARRAY_TYPE 0x8082
|
||||||
|
#define GL_COLOR_ARRAY_STRIDE 0x8083
|
||||||
|
#define GL_TEXTURE_COORD_ARRAY_SIZE 0x8088
|
||||||
|
#define GL_TEXTURE_COORD_ARRAY_TYPE 0x8089
|
||||||
|
#define GL_TEXTURE_COORD_ARRAY_STRIDE 0x808A
|
||||||
|
#define GL_VERTEX_ARRAY_POINTER 0x808E
|
||||||
|
#define GL_NORMAL_ARRAY_POINTER 0x808F
|
||||||
|
#define GL_COLOR_ARRAY_POINTER 0x8090
|
||||||
|
#define GL_TEXTURE_COORD_ARRAY_POINTER 0x8092
|
||||||
|
#define GL_SAMPLE_BUFFERS 0x80A8
|
||||||
|
#define GL_SAMPLES 0x80A9
|
||||||
|
#define GL_SAMPLE_COVERAGE_VALUE 0x80AA
|
||||||
|
#define GL_SAMPLE_COVERAGE_INVERT 0x80AB
|
||||||
|
|
||||||
|
/* GetTextureParameter */
|
||||||
|
/* GL_TEXTURE_MAG_FILTER */
|
||||||
|
/* GL_TEXTURE_MIN_FILTER */
|
||||||
|
/* GL_TEXTURE_WRAP_S */
|
||||||
|
/* GL_TEXTURE_WRAP_T */
|
||||||
|
|
||||||
|
#define GL_NUM_COMPRESSED_TEXTURE_FORMATS 0x86A2
|
||||||
|
#define GL_COMPRESSED_TEXTURE_FORMATS 0x86A3
|
||||||
|
|
||||||
|
/* HintMode */
|
||||||
|
#define GL_DONT_CARE 0x1100
|
||||||
|
#define GL_FASTEST 0x1101
|
||||||
|
#define GL_NICEST 0x1102
|
||||||
|
|
||||||
|
/* HintTarget */
|
||||||
|
#define GL_PERSPECTIVE_CORRECTION_HINT 0x0C50
|
||||||
|
#define GL_POINT_SMOOTH_HINT 0x0C51
|
||||||
|
#define GL_LINE_SMOOTH_HINT 0x0C52
|
||||||
|
#define GL_FOG_HINT 0x0C54
|
||||||
|
#define GL_GENERATE_MIPMAP_HINT 0x8192
|
||||||
|
|
||||||
|
/* LightModelParameter */
|
||||||
|
#define GL_LIGHT_MODEL_AMBIENT 0x0B53
|
||||||
|
#define GL_LIGHT_MODEL_TWO_SIDE 0x0B52
|
||||||
|
|
||||||
|
/* LightParameter */
|
||||||
|
#define GL_AMBIENT 0x1200
|
||||||
|
#define GL_DIFFUSE 0x1201
|
||||||
|
#define GL_SPECULAR 0x1202
|
||||||
|
#define GL_POSITION 0x1203
|
||||||
|
#define GL_SPOT_DIRECTION 0x1204
|
||||||
|
#define GL_SPOT_EXPONENT 0x1205
|
||||||
|
#define GL_SPOT_CUTOFF 0x1206
|
||||||
|
#define GL_CONSTANT_ATTENUATION 0x1207
|
||||||
|
#define GL_LINEAR_ATTENUATION 0x1208
|
||||||
|
#define GL_QUADRATIC_ATTENUATION 0x1209
|
||||||
|
|
||||||
|
/* DataType */
|
||||||
|
#define GL_BYTE 0x1400
|
||||||
|
#define GL_UNSIGNED_BYTE 0x1401
|
||||||
|
#define GL_SHORT 0x1402
|
||||||
|
#define GL_UNSIGNED_SHORT 0x1403
|
||||||
|
#define GL_FLOAT 0x1406
|
||||||
|
#define GL_FIXED 0x140C
|
||||||
|
|
||||||
|
/* LogicOp */
|
||||||
|
#define GL_CLEAR 0x1500
|
||||||
|
#define GL_AND 0x1501
|
||||||
|
#define GL_AND_REVERSE 0x1502
|
||||||
|
#define GL_COPY 0x1503
|
||||||
|
#define GL_AND_INVERTED 0x1504
|
||||||
|
#define GL_NOOP 0x1505
|
||||||
|
#define GL_XOR 0x1506
|
||||||
|
#define GL_OR 0x1507
|
||||||
|
#define GL_NOR 0x1508
|
||||||
|
#define GL_EQUIV 0x1509
|
||||||
|
#define GL_INVERT 0x150A
|
||||||
|
#define GL_OR_REVERSE 0x150B
|
||||||
|
#define GL_COPY_INVERTED 0x150C
|
||||||
|
#define GL_OR_INVERTED 0x150D
|
||||||
|
#define GL_NAND 0x150E
|
||||||
|
#define GL_SET 0x150F
|
||||||
|
|
||||||
|
/* MaterialFace */
|
||||||
|
/* GL_FRONT_AND_BACK */
|
||||||
|
|
||||||
|
/* MaterialParameter */
|
||||||
|
#define GL_EMISSION 0x1600
|
||||||
|
#define GL_SHININESS 0x1601
|
||||||
|
#define GL_AMBIENT_AND_DIFFUSE 0x1602
|
||||||
|
/* GL_AMBIENT */
|
||||||
|
/* GL_DIFFUSE */
|
||||||
|
/* GL_SPECULAR */
|
||||||
|
|
||||||
|
/* MatrixMode */
|
||||||
|
#define GL_MODELVIEW 0x1700
|
||||||
|
#define GL_PROJECTION 0x1701
|
||||||
|
#define GL_TEXTURE 0x1702
|
||||||
|
|
||||||
|
/* NormalPointerType */
|
||||||
|
/* GL_BYTE */
|
||||||
|
/* GL_SHORT */
|
||||||
|
/* GL_FLOAT */
|
||||||
|
/* GL_FIXED */
|
||||||
|
|
||||||
|
/* PixelFormat */
|
||||||
|
#define GL_ALPHA 0x1906
|
||||||
|
#define GL_RGB 0x1907
|
||||||
|
#define GL_RGBA 0x1908
|
||||||
|
#define GL_LUMINANCE 0x1909
|
||||||
|
#define GL_LUMINANCE_ALPHA 0x190A
|
||||||
|
|
||||||
|
/* PixelStoreParameter */
|
||||||
|
#define GL_UNPACK_ALIGNMENT 0x0CF5
|
||||||
|
#define GL_PACK_ALIGNMENT 0x0D05
|
||||||
|
|
||||||
|
/* PixelType */
|
||||||
|
/* GL_UNSIGNED_BYTE */
|
||||||
|
#define GL_UNSIGNED_SHORT_4_4_4_4 0x8033
|
||||||
|
#define GL_UNSIGNED_SHORT_5_5_5_1 0x8034
|
||||||
|
#define GL_UNSIGNED_SHORT_5_6_5 0x8363
|
||||||
|
|
||||||
|
/* ShadingModel */
|
||||||
|
#define GL_FLAT 0x1D00
|
||||||
|
#define GL_SMOOTH 0x1D01
|
||||||
|
|
||||||
|
/* StencilFunction */
|
||||||
|
/* GL_NEVER */
|
||||||
|
/* GL_LESS */
|
||||||
|
/* GL_EQUAL */
|
||||||
|
/* GL_LEQUAL */
|
||||||
|
/* GL_GREATER */
|
||||||
|
/* GL_NOTEQUAL */
|
||||||
|
/* GL_GEQUAL */
|
||||||
|
/* GL_ALWAYS */
|
||||||
|
|
||||||
|
/* StencilOp */
|
||||||
|
/* GL_ZERO */
|
||||||
|
#define GL_KEEP 0x1E00
|
||||||
|
#define GL_REPLACE 0x1E01
|
||||||
|
#define GL_INCR 0x1E02
|
||||||
|
#define GL_DECR 0x1E03
|
||||||
|
/* GL_INVERT */
|
||||||
|
|
||||||
|
/* StringName */
|
||||||
|
#define GL_VENDOR 0x1F00
|
||||||
|
#define GL_RENDERER 0x1F01
|
||||||
|
#define GL_VERSION 0x1F02
|
||||||
|
#define GL_EXTENSIONS 0x1F03
|
||||||
|
|
||||||
|
/* TexCoordPointerType */
|
||||||
|
/* GL_SHORT */
|
||||||
|
/* GL_FLOAT */
|
||||||
|
/* GL_FIXED */
|
||||||
|
/* GL_BYTE */
|
||||||
|
|
||||||
|
/* TextureEnvMode */
|
||||||
|
#define GL_MODULATE 0x2100
|
||||||
|
#define GL_DECAL 0x2101
|
||||||
|
/* GL_BLEND */
|
||||||
|
#define GL_ADD 0x0104
|
||||||
|
/* GL_REPLACE */
|
||||||
|
|
||||||
|
/* TextureEnvParameter */
|
||||||
|
#define GL_TEXTURE_ENV_MODE 0x2200
|
||||||
|
#define GL_TEXTURE_ENV_COLOR 0x2201
|
||||||
|
|
||||||
|
/* TextureEnvTarget */
|
||||||
|
#define GL_TEXTURE_ENV 0x2300
|
||||||
|
|
||||||
|
/* TextureMagFilter */
|
||||||
|
#define GL_NEAREST 0x2600
|
||||||
|
#define GL_LINEAR 0x2601
|
||||||
|
|
||||||
|
/* TextureMinFilter */
|
||||||
|
/* GL_NEAREST */
|
||||||
|
/* GL_LINEAR */
|
||||||
|
#define GL_NEAREST_MIPMAP_NEAREST 0x2700
|
||||||
|
#define GL_LINEAR_MIPMAP_NEAREST 0x2701
|
||||||
|
#define GL_NEAREST_MIPMAP_LINEAR 0x2702
|
||||||
|
#define GL_LINEAR_MIPMAP_LINEAR 0x2703
|
||||||
|
|
||||||
|
/* TextureParameterName */
|
||||||
|
#define GL_TEXTURE_MAG_FILTER 0x2800
|
||||||
|
#define GL_TEXTURE_MIN_FILTER 0x2801
|
||||||
|
#define GL_TEXTURE_WRAP_S 0x2802
|
||||||
|
#define GL_TEXTURE_WRAP_T 0x2803
|
||||||
|
#define GL_GENERATE_MIPMAP 0x8191
|
||||||
|
|
||||||
|
/* TextureTarget */
|
||||||
|
/* GL_TEXTURE_2D */
|
||||||
|
|
||||||
|
/* TextureUnit */
|
||||||
|
#define GL_TEXTURE0 0x84C0
|
||||||
|
#define GL_TEXTURE1 0x84C1
|
||||||
|
#define GL_TEXTURE2 0x84C2
|
||||||
|
#define GL_TEXTURE3 0x84C3
|
||||||
|
#define GL_TEXTURE4 0x84C4
|
||||||
|
#define GL_TEXTURE5 0x84C5
|
||||||
|
#define GL_TEXTURE6 0x84C6
|
||||||
|
#define GL_TEXTURE7 0x84C7
|
||||||
|
#define GL_TEXTURE8 0x84C8
|
||||||
|
#define GL_TEXTURE9 0x84C9
|
||||||
|
#define GL_TEXTURE10 0x84CA
|
||||||
|
#define GL_TEXTURE11 0x84CB
|
||||||
|
#define GL_TEXTURE12 0x84CC
|
||||||
|
#define GL_TEXTURE13 0x84CD
|
||||||
|
#define GL_TEXTURE14 0x84CE
|
||||||
|
#define GL_TEXTURE15 0x84CF
|
||||||
|
#define GL_TEXTURE16 0x84D0
|
||||||
|
#define GL_TEXTURE17 0x84D1
|
||||||
|
#define GL_TEXTURE18 0x84D2
|
||||||
|
#define GL_TEXTURE19 0x84D3
|
||||||
|
#define GL_TEXTURE20 0x84D4
|
||||||
|
#define GL_TEXTURE21 0x84D5
|
||||||
|
#define GL_TEXTURE22 0x84D6
|
||||||
|
#define GL_TEXTURE23 0x84D7
|
||||||
|
#define GL_TEXTURE24 0x84D8
|
||||||
|
#define GL_TEXTURE25 0x84D9
|
||||||
|
#define GL_TEXTURE26 0x84DA
|
||||||
|
#define GL_TEXTURE27 0x84DB
|
||||||
|
#define GL_TEXTURE28 0x84DC
|
||||||
|
#define GL_TEXTURE29 0x84DD
|
||||||
|
#define GL_TEXTURE30 0x84DE
|
||||||
|
#define GL_TEXTURE31 0x84DF
|
||||||
|
#define GL_ACTIVE_TEXTURE 0x84E0
|
||||||
|
#define GL_CLIENT_ACTIVE_TEXTURE 0x84E1
|
||||||
|
|
||||||
|
/* TextureWrapMode */
|
||||||
|
#define GL_REPEAT 0x2901
|
||||||
|
#define GL_CLAMP_TO_EDGE 0x812F
|
||||||
|
|
||||||
|
/* VertexPointerType */
|
||||||
|
/* GL_SHORT */
|
||||||
|
/* GL_FLOAT */
|
||||||
|
/* GL_FIXED */
|
||||||
|
/* GL_BYTE */
|
||||||
|
|
||||||
|
/* LightName */
|
||||||
|
#define GL_LIGHT0 0x4000
|
||||||
|
#define GL_LIGHT1 0x4001
|
||||||
|
#define GL_LIGHT2 0x4002
|
||||||
|
#define GL_LIGHT3 0x4003
|
||||||
|
#define GL_LIGHT4 0x4004
|
||||||
|
#define GL_LIGHT5 0x4005
|
||||||
|
#define GL_LIGHT6 0x4006
|
||||||
|
#define GL_LIGHT7 0x4007
|
||||||
|
|
||||||
|
/* Buffer Objects */
|
||||||
|
#define GL_ARRAY_BUFFER 0x8892
|
||||||
|
#define GL_ELEMENT_ARRAY_BUFFER 0x8893
|
||||||
|
|
||||||
|
#define GL_ARRAY_BUFFER_BINDING 0x8894
|
||||||
|
#define GL_ELEMENT_ARRAY_BUFFER_BINDING 0x8895
|
||||||
|
#define GL_VERTEX_ARRAY_BUFFER_BINDING 0x8896
|
||||||
|
#define GL_NORMAL_ARRAY_BUFFER_BINDING 0x8897
|
||||||
|
#define GL_COLOR_ARRAY_BUFFER_BINDING 0x8898
|
||||||
|
#define GL_TEXTURE_COORD_ARRAY_BUFFER_BINDING 0x889A
|
||||||
|
|
||||||
|
#define GL_STATIC_DRAW 0x88E4
|
||||||
|
#define GL_DYNAMIC_DRAW 0x88E8
|
||||||
|
|
||||||
|
#define GL_BUFFER_SIZE 0x8764
|
||||||
|
#define GL_BUFFER_USAGE 0x8765
|
||||||
|
|
||||||
|
/* Texture combine + dot3 */
|
||||||
|
#define GL_SUBTRACT 0x84E7
|
||||||
|
#define GL_COMBINE 0x8570
|
||||||
|
#define GL_COMBINE_RGB 0x8571
|
||||||
|
#define GL_COMBINE_ALPHA 0x8572
|
||||||
|
#define GL_RGB_SCALE 0x8573
|
||||||
|
#define GL_ADD_SIGNED 0x8574
|
||||||
|
#define GL_INTERPOLATE 0x8575
|
||||||
|
#define GL_CONSTANT 0x8576
|
||||||
|
#define GL_PRIMARY_COLOR 0x8577
|
||||||
|
#define GL_PREVIOUS 0x8578
|
||||||
|
#define GL_OPERAND0_RGB 0x8590
|
||||||
|
#define GL_OPERAND1_RGB 0x8591
|
||||||
|
#define GL_OPERAND2_RGB 0x8592
|
||||||
|
#define GL_OPERAND0_ALPHA 0x8598
|
||||||
|
#define GL_OPERAND1_ALPHA 0x8599
|
||||||
|
#define GL_OPERAND2_ALPHA 0x859A
|
||||||
|
|
||||||
|
#define GL_ALPHA_SCALE 0x0D1C
|
||||||
|
|
||||||
|
#define GL_SRC0_RGB 0x8580
|
||||||
|
#define GL_SRC1_RGB 0x8581
|
||||||
|
#define GL_SRC2_RGB 0x8582
|
||||||
|
#define GL_SRC0_ALPHA 0x8588
|
||||||
|
#define GL_SRC1_ALPHA 0x8589
|
||||||
|
#define GL_SRC2_ALPHA 0x858A
|
||||||
|
|
||||||
|
#define GL_DOT3_RGB 0x86AE
|
||||||
|
#define GL_DOT3_RGBA 0x86AF
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------*
|
||||||
|
* required OES extension tokens
|
||||||
|
*------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* OES_read_format */
|
||||||
|
#ifndef GL_OES_read_format
|
||||||
|
#define GL_IMPLEMENTATION_COLOR_READ_TYPE_OES 0x8B9A
|
||||||
|
#define GL_IMPLEMENTATION_COLOR_READ_FORMAT_OES 0x8B9B
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* GL_OES_compressed_paletted_texture */
|
||||||
|
#ifndef GL_OES_compressed_paletted_texture
|
||||||
|
#define GL_PALETTE4_RGB8_OES 0x8B90
|
||||||
|
#define GL_PALETTE4_RGBA8_OES 0x8B91
|
||||||
|
#define GL_PALETTE4_R5_G6_B5_OES 0x8B92
|
||||||
|
#define GL_PALETTE4_RGBA4_OES 0x8B93
|
||||||
|
#define GL_PALETTE4_RGB5_A1_OES 0x8B94
|
||||||
|
#define GL_PALETTE8_RGB8_OES 0x8B95
|
||||||
|
#define GL_PALETTE8_RGBA8_OES 0x8B96
|
||||||
|
#define GL_PALETTE8_R5_G6_B5_OES 0x8B97
|
||||||
|
#define GL_PALETTE8_RGBA4_OES 0x8B98
|
||||||
|
#define GL_PALETTE8_RGB5_A1_OES 0x8B99
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* OES_point_size_array */
|
||||||
|
#ifndef GL_OES_point_size_array
|
||||||
|
#define GL_POINT_SIZE_ARRAY_OES 0x8B9C
|
||||||
|
#define GL_POINT_SIZE_ARRAY_TYPE_OES 0x898A
|
||||||
|
#define GL_POINT_SIZE_ARRAY_STRIDE_OES 0x898B
|
||||||
|
#define GL_POINT_SIZE_ARRAY_POINTER_OES 0x898C
|
||||||
|
#define GL_POINT_SIZE_ARRAY_BUFFER_BINDING_OES 0x8B9F
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* GL_OES_point_sprite */
|
||||||
|
#ifndef GL_OES_point_sprite
|
||||||
|
#define GL_POINT_SPRITE_OES 0x8861
|
||||||
|
#define GL_COORD_REPLACE_OES 0x8862
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*************************************************************/
|
||||||
|
|
||||||
|
/* Available only in Common profile */
|
||||||
|
GL_API void GL_APIENTRY glAlphaFunc(GLenum func, GLclampf ref);
|
||||||
|
GL_API void GL_APIENTRY glClearColor(GLclampf red, GLclampf green,
|
||||||
|
GLclampf blue, GLclampf alpha);
|
||||||
|
GL_API void GL_APIENTRY glClearDepthf(GLclampf depth);
|
||||||
|
GL_API void GL_APIENTRY glClipPlanef(GLenum plane,
|
||||||
|
const GLfloat * equation);
|
||||||
|
GL_API void GL_APIENTRY glColor4f(GLfloat red, GLfloat green,
|
||||||
|
GLfloat blue, GLfloat alpha);
|
||||||
|
GL_API void GL_APIENTRY glDepthRangef(GLclampf zNear, GLclampf zFar);
|
||||||
|
GL_API void GL_APIENTRY glFogf(GLenum pname, GLfloat param);
|
||||||
|
GL_API void GL_APIENTRY glFogfv(GLenum pname, const GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glFrustumf(GLfloat left, GLfloat right,
|
||||||
|
GLfloat bottom, GLfloat top,
|
||||||
|
GLfloat zNear, GLfloat zFar);
|
||||||
|
GL_API void GL_APIENTRY glGetClipPlanef(GLenum pname, GLfloat eqn[4]);
|
||||||
|
GL_API void GL_APIENTRY glGetFloatv(GLenum pname, GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glGetLightfv(GLenum light, GLenum pname,
|
||||||
|
GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glGetMaterialfv(GLenum face, GLenum pname,
|
||||||
|
GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glGetTexEnvfv(GLenum env, GLenum pname,
|
||||||
|
GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glGetTexParameterfv(GLenum target, GLenum pname,
|
||||||
|
GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glLightModelf(GLenum pname, GLfloat param);
|
||||||
|
GL_API void GL_APIENTRY glLightModelfv(GLenum pname,
|
||||||
|
const GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glLightf(GLenum light, GLenum pname,
|
||||||
|
GLfloat param);
|
||||||
|
GL_API void GL_APIENTRY glLightfv(GLenum light, GLenum pname,
|
||||||
|
const GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glLineWidth(GLfloat width);
|
||||||
|
GL_API void GL_APIENTRY glLoadMatrixf(const GLfloat * m);
|
||||||
|
GL_API void GL_APIENTRY glMaterialf(GLenum face, GLenum pname,
|
||||||
|
GLfloat param);
|
||||||
|
GL_API void GL_APIENTRY glMaterialfv(GLenum face, GLenum pname,
|
||||||
|
const GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glMultMatrixf(const GLfloat * m);
|
||||||
|
GL_API void GL_APIENTRY glMultiTexCoord4f(GLenum target, GLfloat s,
|
||||||
|
GLfloat t, GLfloat r,
|
||||||
|
GLfloat q);
|
||||||
|
GL_API void GL_APIENTRY glNormal3f(GLfloat nx, GLfloat ny, GLfloat nz);
|
||||||
|
GL_API void GL_APIENTRY glOrthof(GLfloat left, GLfloat right,
|
||||||
|
GLfloat bottom, GLfloat top,
|
||||||
|
GLfloat zNear, GLfloat zFar);
|
||||||
|
GL_API void GL_APIENTRY glPointParameterf(GLenum pname, GLfloat param);
|
||||||
|
GL_API void GL_APIENTRY glPointParameterfv(GLenum pname,
|
||||||
|
const GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glPointSize(GLfloat size);
|
||||||
|
GL_API void GL_APIENTRY glPolygonOffset(GLfloat factor, GLfloat units);
|
||||||
|
GL_API void GL_APIENTRY glRotatef(GLfloat angle, GLfloat x, GLfloat y,
|
||||||
|
GLfloat z);
|
||||||
|
GL_API void GL_APIENTRY glScalef(GLfloat x, GLfloat y, GLfloat z);
|
||||||
|
GL_API void GL_APIENTRY glTexEnvf(GLenum target, GLenum pname,
|
||||||
|
GLfloat param);
|
||||||
|
GL_API void GL_APIENTRY glTexEnvfv(GLenum target, GLenum pname,
|
||||||
|
const GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glTexParameterf(GLenum target, GLenum pname,
|
||||||
|
GLfloat param);
|
||||||
|
GL_API void GL_APIENTRY glTexParameterfv(GLenum target, GLenum pname,
|
||||||
|
const GLfloat * params);
|
||||||
|
GL_API void GL_APIENTRY glTranslatef(GLfloat x, GLfloat y, GLfloat z);
|
||||||
|
|
||||||
|
/* Available in both Common and Common-Lite profiles */
|
||||||
|
GL_API void GL_APIENTRY glActiveTexture(GLenum texture);
|
||||||
|
GL_API void GL_APIENTRY glAlphaFuncx(GLenum func, GLclampx ref);
|
||||||
|
GL_API void GL_APIENTRY glBindBuffer(GLenum target, GLuint buffer);
|
||||||
|
GL_API void GL_APIENTRY glBindTexture(GLenum target, GLuint texture);
|
||||||
|
GL_API void GL_APIENTRY glBlendFunc(GLenum sfactor, GLenum dfactor);
|
||||||
|
GL_API void GL_APIENTRY glBufferData(GLenum target, GLsizeiptr size,
|
||||||
|
const GLvoid * data, GLenum usage);
|
||||||
|
GL_API void GL_APIENTRY glBufferSubData(GLenum target, GLintptr offset,
|
||||||
|
GLsizeiptr size,
|
||||||
|
const GLvoid * data);
|
||||||
|
GL_API void GL_APIENTRY glClear(GLbitfield mask);
|
||||||
|
GL_API void GL_APIENTRY glClearColorx(GLclampx red, GLclampx green,
|
||||||
|
GLclampx blue, GLclampx alpha);
|
||||||
|
GL_API void GL_APIENTRY glClearDepthx(GLclampx depth);
|
||||||
|
GL_API void GL_APIENTRY glClearStencil(GLint s);
|
||||||
|
GL_API void GL_APIENTRY glClientActiveTexture(GLenum texture);
|
||||||
|
GL_API void GL_APIENTRY glClipPlanex(GLenum plane,
|
||||||
|
const GLfixed * equation);
|
||||||
|
GL_API void GL_APIENTRY glColor4ub(GLubyte red, GLubyte green,
|
||||||
|
GLubyte blue, GLubyte alpha);
|
||||||
|
GL_API void GL_APIENTRY glColor4x(GLfixed red, GLfixed green,
|
||||||
|
GLfixed blue, GLfixed alpha);
|
||||||
|
GL_API void GL_APIENTRY glColorMask(GLboolean red, GLboolean green,
|
||||||
|
GLboolean blue, GLboolean alpha);
|
||||||
|
GL_API void GL_APIENTRY glColorPointer(GLint size, GLenum type,
|
||||||
|
GLsizei stride,
|
||||||
|
const GLvoid * pointer);
|
||||||
|
GL_API void GL_APIENTRY glCompressedTexImage2D(GLenum target, GLint level,
|
||||||
|
GLenum internalformat,
|
||||||
|
GLsizei width,
|
||||||
|
GLsizei height,
|
||||||
|
GLint border,
|
||||||
|
GLsizei imageSize,
|
||||||
|
const GLvoid * data);
|
||||||
|
GL_API void GL_APIENTRY glCompressedTexSubImage2D(GLenum target,
|
||||||
|
GLint level,
|
||||||
|
GLint xoffset,
|
||||||
|
GLint yoffset,
|
||||||
|
GLsizei width,
|
||||||
|
GLsizei height,
|
||||||
|
GLenum format,
|
||||||
|
GLsizei imageSize,
|
||||||
|
const GLvoid * data);
|
||||||
|
GL_API void GL_APIENTRY glCopyTexImage2D(GLenum target, GLint level,
|
||||||
|
GLenum internalformat, GLint x,
|
||||||
|
GLint y, GLsizei width,
|
||||||
|
GLsizei height, GLint border);
|
||||||
|
GL_API void GL_APIENTRY glCopyTexSubImage2D(GLenum target, GLint level,
|
||||||
|
GLint xoffset, GLint yoffset,
|
||||||
|
GLint x, GLint y,
|
||||||
|
GLsizei width,
|
||||||
|
GLsizei height);
|
||||||
|
GL_API void GL_APIENTRY glCullFace(GLenum mode);
|
||||||
|
GL_API void GL_APIENTRY glDeleteBuffers(GLsizei n,
|
||||||
|
const GLuint * buffers);
|
||||||
|
GL_API void GL_APIENTRY glDeleteTextures(GLsizei n,
|
||||||
|
const GLuint * textures);
|
||||||
|
GL_API void GL_APIENTRY glDepthFunc(GLenum func);
|
||||||
|
GL_API void GL_APIENTRY glDepthMask(GLboolean flag);
|
||||||
|
GL_API void GL_APIENTRY glDepthRangex(GLclampx zNear, GLclampx zFar);
|
||||||
|
GL_API void GL_APIENTRY glDisable(GLenum cap);
|
||||||
|
GL_API void GL_APIENTRY glDisableClientState(GLenum array);
|
||||||
|
GL_API void GL_APIENTRY glDrawArrays(GLenum mode, GLint first,
|
||||||
|
GLsizei count);
|
||||||
|
GL_API void GL_APIENTRY glDrawElements(GLenum mode, GLsizei count,
|
||||||
|
GLenum type,
|
||||||
|
const GLvoid * indices);
|
||||||
|
GL_API void GL_APIENTRY glEnable(GLenum cap);
|
||||||
|
GL_API void GL_APIENTRY glEnableClientState(GLenum array);
|
||||||
|
GL_API void GL_APIENTRY glFinish(void);
|
||||||
|
GL_API void GL_APIENTRY glFlush(void);
|
||||||
|
GL_API void GL_APIENTRY glFogx(GLenum pname, GLfixed param);
|
||||||
|
GL_API void GL_APIENTRY glFogxv(GLenum pname, const GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glFrontFace(GLenum mode);
|
||||||
|
GL_API void GL_APIENTRY glFrustumx(GLfixed left, GLfixed right,
|
||||||
|
GLfixed bottom, GLfixed top,
|
||||||
|
GLfixed zNear, GLfixed zFar);
|
||||||
|
GL_API void GL_APIENTRY glGetBooleanv(GLenum pname, GLboolean * params);
|
||||||
|
GL_API void GL_APIENTRY glGetBufferParameteriv(GLenum target,
|
||||||
|
GLenum pname,
|
||||||
|
GLint * params);
|
||||||
|
GL_API void GL_APIENTRY glGetClipPlanex(GLenum pname, GLfixed eqn[4]);
|
||||||
|
GL_API void GL_APIENTRY glGenBuffers(GLsizei n, GLuint * buffers);
|
||||||
|
GL_API void GL_APIENTRY glGenTextures(GLsizei n, GLuint * textures);
|
||||||
|
GL_API GLenum GL_APIENTRY glGetError(void);
|
||||||
|
GL_API void GL_APIENTRY glGetFixedv(GLenum pname, GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glGetIntegerv(GLenum pname, GLint * params);
|
||||||
|
GL_API void GL_APIENTRY glGetLightxv(GLenum light, GLenum pname,
|
||||||
|
GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glGetMaterialxv(GLenum face, GLenum pname,
|
||||||
|
GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glGetPointerv(GLenum pname, void **params);
|
||||||
|
GL_API const GLubyte *GL_APIENTRY glGetString(GLenum name);
|
||||||
|
GL_API void GL_APIENTRY glGetTexEnviv(GLenum env, GLenum pname,
|
||||||
|
GLint * params);
|
||||||
|
GL_API void GL_APIENTRY glGetTexEnvxv(GLenum env, GLenum pname,
|
||||||
|
GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glGetTexParameteriv(GLenum target, GLenum pname,
|
||||||
|
GLint * params);
|
||||||
|
GL_API void GL_APIENTRY glGetTexParameterxv(GLenum target, GLenum pname,
|
||||||
|
GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glHint(GLenum target, GLenum mode);
|
||||||
|
GL_API GLboolean GL_APIENTRY glIsBuffer(GLuint buffer);
|
||||||
|
GL_API GLboolean GL_APIENTRY glIsEnabled(GLenum cap);
|
||||||
|
GL_API GLboolean GL_APIENTRY glIsTexture(GLuint texture);
|
||||||
|
GL_API void GL_APIENTRY glLightModelx(GLenum pname, GLfixed param);
|
||||||
|
GL_API void GL_APIENTRY glLightModelxv(GLenum pname,
|
||||||
|
const GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glLightx(GLenum light, GLenum pname,
|
||||||
|
GLfixed param);
|
||||||
|
GL_API void GL_APIENTRY glLightxv(GLenum light, GLenum pname,
|
||||||
|
const GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glLineWidthx(GLfixed width);
|
||||||
|
GL_API void GL_APIENTRY glLoadIdentity(void);
|
||||||
|
GL_API void GL_APIENTRY glLoadMatrixx(const GLfixed * m);
|
||||||
|
GL_API void GL_APIENTRY glLogicOp(GLenum opcode);
|
||||||
|
GL_API void GL_APIENTRY glMaterialx(GLenum face, GLenum pname,
|
||||||
|
GLfixed param);
|
||||||
|
GL_API void GL_APIENTRY glMaterialxv(GLenum face, GLenum pname,
|
||||||
|
const GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glMatrixMode(GLenum mode);
|
||||||
|
GL_API void GL_APIENTRY glMultMatrixx(const GLfixed * m);
|
||||||
|
GL_API void GL_APIENTRY glMultiTexCoord4x(GLenum target, GLfixed s,
|
||||||
|
GLfixed t, GLfixed r,
|
||||||
|
GLfixed q);
|
||||||
|
GL_API void GL_APIENTRY glNormal3x(GLfixed nx, GLfixed ny, GLfixed nz);
|
||||||
|
GL_API void GL_APIENTRY glNormalPointer(GLenum type, GLsizei stride,
|
||||||
|
const GLvoid * pointer);
|
||||||
|
GL_API void GL_APIENTRY glOrthox(GLfixed left, GLfixed right,
|
||||||
|
GLfixed bottom, GLfixed top,
|
||||||
|
GLfixed zNear, GLfixed zFar);
|
||||||
|
GL_API void GL_APIENTRY glPixelStorei(GLenum pname, GLint param);
|
||||||
|
GL_API void GL_APIENTRY glPointParameterx(GLenum pname, GLfixed param);
|
||||||
|
GL_API void GL_APIENTRY glPointParameterxv(GLenum pname,
|
||||||
|
const GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glPointSizex(GLfixed size);
|
||||||
|
GL_API void GL_APIENTRY glPolygonOffsetx(GLfixed factor, GLfixed units);
|
||||||
|
GL_API void GL_APIENTRY glPopMatrix(void);
|
||||||
|
GL_API void GL_APIENTRY glPushMatrix(void);
|
||||||
|
GL_API void GL_APIENTRY glReadPixels(GLint x, GLint y, GLsizei width,
|
||||||
|
GLsizei height, GLenum format,
|
||||||
|
GLenum type, GLvoid * pixels);
|
||||||
|
GL_API void GL_APIENTRY glRotatex(GLfixed angle, GLfixed x, GLfixed y,
|
||||||
|
GLfixed z);
|
||||||
|
GL_API void GL_APIENTRY glSampleCoverage(GLclampf value,
|
||||||
|
GLboolean invert);
|
||||||
|
GL_API void GL_APIENTRY glSampleCoveragex(GLclampx value,
|
||||||
|
GLboolean invert);
|
||||||
|
GL_API void GL_APIENTRY glScalex(GLfixed x, GLfixed y, GLfixed z);
|
||||||
|
GL_API void GL_APIENTRY glScissor(GLint x, GLint y, GLsizei width,
|
||||||
|
GLsizei height);
|
||||||
|
GL_API void GL_APIENTRY glShadeModel(GLenum mode);
|
||||||
|
GL_API void GL_APIENTRY glStencilFunc(GLenum func, GLint ref,
|
||||||
|
GLuint mask);
|
||||||
|
GL_API void GL_APIENTRY glStencilMask(GLuint mask);
|
||||||
|
GL_API void GL_APIENTRY glStencilOp(GLenum fail, GLenum zfail,
|
||||||
|
GLenum zpass);
|
||||||
|
GL_API void GL_APIENTRY glTexCoordPointer(GLint size, GLenum type,
|
||||||
|
GLsizei stride,
|
||||||
|
const GLvoid * pointer);
|
||||||
|
GL_API void GL_APIENTRY glTexEnvi(GLenum target, GLenum pname,
|
||||||
|
GLint param);
|
||||||
|
GL_API void GL_APIENTRY glTexEnvx(GLenum target, GLenum pname,
|
||||||
|
GLfixed param);
|
||||||
|
GL_API void GL_APIENTRY glTexEnviv(GLenum target, GLenum pname,
|
||||||
|
const GLint * params);
|
||||||
|
GL_API void GL_APIENTRY glTexEnvxv(GLenum target, GLenum pname,
|
||||||
|
const GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glTexImage2D(GLenum target, GLint level,
|
||||||
|
GLint internalformat, GLsizei width,
|
||||||
|
GLsizei height, GLint border,
|
||||||
|
GLenum format, GLenum type,
|
||||||
|
const GLvoid * pixels);
|
||||||
|
GL_API void GL_APIENTRY glTexParameteri(GLenum target, GLenum pname,
|
||||||
|
GLint param);
|
||||||
|
GL_API void GL_APIENTRY glTexParameterx(GLenum target, GLenum pname,
|
||||||
|
GLfixed param);
|
||||||
|
GL_API void GL_APIENTRY glTexParameteriv(GLenum target, GLenum pname,
|
||||||
|
const GLint * params);
|
||||||
|
GL_API void GL_APIENTRY glTexParameterxv(GLenum target, GLenum pname,
|
||||||
|
const GLfixed * params);
|
||||||
|
GL_API void GL_APIENTRY glTexSubImage2D(GLenum target, GLint level,
|
||||||
|
GLint xoffset, GLint yoffset,
|
||||||
|
GLsizei width, GLsizei height,
|
||||||
|
GLenum format, GLenum type,
|
||||||
|
const GLvoid * pixels);
|
||||||
|
GL_API void GL_APIENTRY glTranslatex(GLfixed x, GLfixed y, GLfixed z);
|
||||||
|
GL_API void GL_APIENTRY glVertexPointer(GLint size, GLenum type,
|
||||||
|
GLsizei stride,
|
||||||
|
const GLvoid * pointer);
|
||||||
|
GL_API void GL_APIENTRY glViewport(GLint x, GLint y, GLsizei width,
|
||||||
|
GLsizei height);
|
||||||
|
|
||||||
|
/*------------------------------------------------------------------------*
|
||||||
|
* Required OES extension functions
|
||||||
|
*------------------------------------------------------------------------*/
|
||||||
|
|
||||||
|
/* GL_OES_read_format */
|
||||||
|
#ifndef GL_OES_read_format
|
||||||
|
#define GL_OES_read_format 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* GL_OES_compressed_paletted_texture */
|
||||||
|
#ifndef GL_OES_compressed_paletted_texture
|
||||||
|
#define GL_OES_compressed_paletted_texture 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* GL_OES_point_size_array */
|
||||||
|
#ifndef GL_OES_point_size_array
|
||||||
|
#define GL_OES_point_size_array 1
|
||||||
|
GL_API void GL_APIENTRY glPointSizePointerOES(GLenum type, GLsizei stride,
|
||||||
|
const GLvoid * pointer);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* GL_OES_point_sprite */
|
||||||
|
#ifndef GL_OES_point_sprite
|
||||||
|
#define GL_OES_point_sprite 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __gles_h_ */
|
|
@ -0,0 +1,401 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_pixels.h
|
||||||
|
*
|
||||||
|
* Header for the enumerated pixel format definitions
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_pixels_h
|
||||||
|
#define _SDL_pixels_h
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Transparency definitions: These define alpha as the opacity of a surface */
|
||||||
|
#define SDL_ALPHA_OPAQUE 255
|
||||||
|
#define SDL_ALPHA_TRANSPARENT 0
|
||||||
|
|
||||||
|
enum
|
||||||
|
{ /* Pixel type */
|
||||||
|
SDL_PIXELTYPE_UNKNOWN,
|
||||||
|
SDL_PIXELTYPE_INDEX1,
|
||||||
|
SDL_PIXELTYPE_INDEX4,
|
||||||
|
SDL_PIXELTYPE_INDEX8,
|
||||||
|
SDL_PIXELTYPE_PACKED8,
|
||||||
|
SDL_PIXELTYPE_PACKED16,
|
||||||
|
SDL_PIXELTYPE_PACKED32,
|
||||||
|
SDL_PIXELTYPE_ARRAYU8,
|
||||||
|
SDL_PIXELTYPE_ARRAYU16,
|
||||||
|
SDL_PIXELTYPE_ARRAYU32,
|
||||||
|
SDL_PIXELTYPE_ARRAYF16,
|
||||||
|
SDL_PIXELTYPE_ARRAYF32
|
||||||
|
};
|
||||||
|
|
||||||
|
enum
|
||||||
|
{ /* bitmap pixel order, high bit -> low bit */
|
||||||
|
SDL_BITMAPORDER_NONE,
|
||||||
|
SDL_BITMAPORDER_4321,
|
||||||
|
SDL_BITMAPORDER_1234
|
||||||
|
};
|
||||||
|
enum
|
||||||
|
{ /* packed component order, high bit -> low bit */
|
||||||
|
SDL_PACKEDORDER_NONE,
|
||||||
|
SDL_PACKEDORDER_XRGB,
|
||||||
|
SDL_PACKEDORDER_RGBX,
|
||||||
|
SDL_PACKEDORDER_ARGB,
|
||||||
|
SDL_PACKEDORDER_RGBA,
|
||||||
|
SDL_PACKEDORDER_XBGR,
|
||||||
|
SDL_PACKEDORDER_BGRX,
|
||||||
|
SDL_PACKEDORDER_ABGR,
|
||||||
|
SDL_PACKEDORDER_BGRA
|
||||||
|
};
|
||||||
|
enum
|
||||||
|
{ /* array component order, low byte -> high byte */
|
||||||
|
SDL_ARRAYORDER_NONE,
|
||||||
|
SDL_ARRAYORDER_RGB,
|
||||||
|
SDL_ARRAYORDER_RGBA,
|
||||||
|
SDL_ARRAYORDER_ARGB,
|
||||||
|
SDL_ARRAYORDER_BGR,
|
||||||
|
SDL_ARRAYORDER_BGRA,
|
||||||
|
SDL_ARRAYORDER_ABGR
|
||||||
|
};
|
||||||
|
|
||||||
|
enum
|
||||||
|
{ /* Packed component layout */
|
||||||
|
SDL_PACKEDLAYOUT_NONE,
|
||||||
|
SDL_PACKEDLAYOUT_332,
|
||||||
|
SDL_PACKEDLAYOUT_4444,
|
||||||
|
SDL_PACKEDLAYOUT_1555,
|
||||||
|
SDL_PACKEDLAYOUT_5551,
|
||||||
|
SDL_PACKEDLAYOUT_565,
|
||||||
|
SDL_PACKEDLAYOUT_8888,
|
||||||
|
SDL_PACKEDLAYOUT_2101010,
|
||||||
|
SDL_PACKEDLAYOUT_1010102
|
||||||
|
};
|
||||||
|
|
||||||
|
#define SDL_DEFINE_PIXELFOURCC(A, B, C, D) \
|
||||||
|
((A) | ((B) << 8) | ((C) << 16) | ((D) << 24))
|
||||||
|
|
||||||
|
#define SDL_DEFINE_PIXELFORMAT(type, order, layout, bits, bytes) \
|
||||||
|
((1 << 31) | ((type) << 24) | ((order) << 20) | ((layout) << 16) | \
|
||||||
|
((bits) << 8) | ((bytes) << 0))
|
||||||
|
|
||||||
|
#define SDL_PIXELTYPE(X) (((X) >> 24) & 0x0F)
|
||||||
|
#define SDL_PIXELORDER(X) (((X) >> 20) & 0x0F)
|
||||||
|
#define SDL_PIXELLAYOUT(X) (((X) >> 16) & 0x0F)
|
||||||
|
#define SDL_BITSPERPIXEL(X) (((X) >> 8) & 0xFF)
|
||||||
|
#define SDL_BYTESPERPIXEL(X) (((X) >> 0) & 0xFF)
|
||||||
|
|
||||||
|
#define SDL_ISPIXELFORMAT_INDEXED(format) \
|
||||||
|
((SDL_PIXELTYPE(format) == SDL_PIXELTYPE_INDEX1) || \
|
||||||
|
(SDL_PIXELTYPE(format) == SDL_PIXELTYPE_INDEX4) || \
|
||||||
|
(SDL_PIXELTYPE(format) == SDL_PIXELTYPE_INDEX8))
|
||||||
|
|
||||||
|
#define SDL_ISPIXELFORMAT_FOURCC(format) \
|
||||||
|
((format) && !((format) & 0x80000000))
|
||||||
|
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
SDL_PIXELFORMAT_UNKNOWN,
|
||||||
|
SDL_PIXELFORMAT_INDEX1LSB =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_INDEX1, SDL_BITMAPORDER_1234, 0,
|
||||||
|
1, 0),
|
||||||
|
SDL_PIXELFORMAT_INDEX1MSB =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_INDEX1, SDL_BITMAPORDER_4321, 0,
|
||||||
|
1, 0),
|
||||||
|
SDL_PIXELFORMAT_INDEX4LSB =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_INDEX4, SDL_BITMAPORDER_1234, 0,
|
||||||
|
2, 0),
|
||||||
|
SDL_PIXELFORMAT_INDEX4MSB =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_INDEX4, SDL_BITMAPORDER_4321, 0,
|
||||||
|
2, 0),
|
||||||
|
SDL_PIXELFORMAT_INDEX8 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_INDEX8, 0, 0, 8, 1),
|
||||||
|
SDL_PIXELFORMAT_RGB332 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED8, SDL_PACKEDORDER_XRGB,
|
||||||
|
SDL_PACKEDLAYOUT_332, 8, 1),
|
||||||
|
SDL_PIXELFORMAT_RGB444 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_XRGB,
|
||||||
|
SDL_PACKEDLAYOUT_4444, 12, 2),
|
||||||
|
SDL_PIXELFORMAT_RGB555 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_XRGB,
|
||||||
|
SDL_PACKEDLAYOUT_1555, 15, 2),
|
||||||
|
SDL_PIXELFORMAT_BGR555 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_XBGR,
|
||||||
|
SDL_PACKEDLAYOUT_1555, 15, 2),
|
||||||
|
SDL_PIXELFORMAT_ARGB4444 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_ARGB,
|
||||||
|
SDL_PACKEDLAYOUT_4444, 16, 2),
|
||||||
|
SDL_PIXELFORMAT_ARGB1555 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_ARGB,
|
||||||
|
SDL_PACKEDLAYOUT_1555, 16, 2),
|
||||||
|
SDL_PIXELFORMAT_ABGR1555 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_ABGR,
|
||||||
|
SDL_PACKEDLAYOUT_1555, 16, 2),
|
||||||
|
SDL_PIXELFORMAT_RGB565 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED16, SDL_PACKEDORDER_XRGB,
|
||||||
|
SDL_PACKEDLAYOUT_565, 16, 2),
|
||||||
|
SDL_PIXELFORMAT_RGB24 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_ARRAYU8, SDL_ARRAYORDER_RGB, 0,
|
||||||
|
24, 3),
|
||||||
|
SDL_PIXELFORMAT_BGR24 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_ARRAYU8, SDL_ARRAYORDER_BGR, 0,
|
||||||
|
24, 3),
|
||||||
|
SDL_PIXELFORMAT_RGB888 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_XRGB,
|
||||||
|
SDL_PACKEDLAYOUT_8888, 24, 4),
|
||||||
|
SDL_PIXELFORMAT_BGR888 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_XBGR,
|
||||||
|
SDL_PACKEDLAYOUT_8888, 24, 4),
|
||||||
|
SDL_PIXELFORMAT_ARGB8888 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_ARGB,
|
||||||
|
SDL_PACKEDLAYOUT_8888, 32, 4),
|
||||||
|
SDL_PIXELFORMAT_RGBA8888 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_RGBA,
|
||||||
|
SDL_PACKEDLAYOUT_8888, 32, 4),
|
||||||
|
SDL_PIXELFORMAT_ABGR8888 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_ABGR,
|
||||||
|
SDL_PACKEDLAYOUT_8888, 32, 4),
|
||||||
|
SDL_PIXELFORMAT_BGRA8888 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_BGRA,
|
||||||
|
SDL_PACKEDLAYOUT_8888, 32, 4),
|
||||||
|
SDL_PIXELFORMAT_ARGB2101010 =
|
||||||
|
SDL_DEFINE_PIXELFORMAT(SDL_PIXELTYPE_PACKED32, SDL_PACKEDORDER_ARGB,
|
||||||
|
SDL_PACKEDLAYOUT_2101010, 32, 4),
|
||||||
|
|
||||||
|
SDL_PIXELFORMAT_YV12 = /* Planar mode: Y + V + U (3 planes) */
|
||||||
|
SDL_DEFINE_PIXELFOURCC('Y', 'V', '1', '2'),
|
||||||
|
SDL_PIXELFORMAT_IYUV = /* Planar mode: Y + U + V (3 planes) */
|
||||||
|
SDL_DEFINE_PIXELFOURCC('I', 'Y', 'U', 'V'),
|
||||||
|
SDL_PIXELFORMAT_YUY2 = /* Packed mode: Y0+U0+Y1+V0 (1 plane) */
|
||||||
|
SDL_DEFINE_PIXELFOURCC('Y', 'U', 'Y', '2'),
|
||||||
|
SDL_PIXELFORMAT_UYVY = /* Packed mode: U0+Y0+V0+Y1 (1 plane) */
|
||||||
|
SDL_DEFINE_PIXELFOURCC('U', 'Y', 'V', 'Y'),
|
||||||
|
SDL_PIXELFORMAT_YVYU = /* Packed mode: Y0+V0+Y1+U0 (1 plane) */
|
||||||
|
SDL_DEFINE_PIXELFOURCC('Y', 'V', 'Y', 'U')
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct SDL_Color
|
||||||
|
{
|
||||||
|
Uint8 r;
|
||||||
|
Uint8 g;
|
||||||
|
Uint8 b;
|
||||||
|
Uint8 unused;
|
||||||
|
} SDL_Color;
|
||||||
|
#define SDL_Colour SDL_Color
|
||||||
|
|
||||||
|
typedef struct SDL_Palette SDL_Palette;
|
||||||
|
typedef int (*SDL_PaletteChangedFunc) (void *userdata, SDL_Palette * palette);
|
||||||
|
|
||||||
|
typedef struct SDL_PaletteWatch
|
||||||
|
{
|
||||||
|
SDL_PaletteChangedFunc callback;
|
||||||
|
void *userdata;
|
||||||
|
struct SDL_PaletteWatch *next;
|
||||||
|
} SDL_PaletteWatch;
|
||||||
|
|
||||||
|
struct SDL_Palette
|
||||||
|
{
|
||||||
|
int ncolors;
|
||||||
|
SDL_Color *colors;
|
||||||
|
|
||||||
|
int refcount;
|
||||||
|
SDL_PaletteWatch *watch;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Everything in the pixel format structure is read-only */
|
||||||
|
typedef struct SDL_PixelFormat
|
||||||
|
{
|
||||||
|
SDL_Palette *palette;
|
||||||
|
Uint8 BitsPerPixel;
|
||||||
|
Uint8 BytesPerPixel;
|
||||||
|
Uint8 Rloss;
|
||||||
|
Uint8 Gloss;
|
||||||
|
Uint8 Bloss;
|
||||||
|
Uint8 Aloss;
|
||||||
|
Uint8 Rshift;
|
||||||
|
Uint8 Gshift;
|
||||||
|
Uint8 Bshift;
|
||||||
|
Uint8 Ashift;
|
||||||
|
Uint32 Rmask;
|
||||||
|
Uint32 Gmask;
|
||||||
|
Uint32 Bmask;
|
||||||
|
Uint32 Amask;
|
||||||
|
} SDL_PixelFormat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDL_bool SDL_PixelFormatEnumToMasks(Uint32 format, int *bpp, Uint32 * Rmask, Uint32 * Gmask, Uint32 * Bmask, Uint32 * Amask)
|
||||||
|
*
|
||||||
|
* \brief Convert one of the enumerated pixel formats to a bpp and RGBA masks.
|
||||||
|
*
|
||||||
|
* \return SDL_TRUE, or SDL_FALSE if the conversion wasn't possible.
|
||||||
|
*
|
||||||
|
* \sa SDL_MasksToPixelFormatEnum()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_PixelFormatEnumToMasks(Uint32 format,
|
||||||
|
int *bpp,
|
||||||
|
Uint32 * Rmask,
|
||||||
|
Uint32 * Gmask,
|
||||||
|
Uint32 * Bmask,
|
||||||
|
Uint32 * Amask);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn Uint32 SDL_MasksToPixelFormatEnum(int bpp, Uint32 Rmask, Uint32 Gmask, Uint32 Bmask, Uint32 Amask)
|
||||||
|
*
|
||||||
|
* \brief Convert a bpp and RGBA masks to an enumerated pixel format.
|
||||||
|
*
|
||||||
|
* \return The pixel format, or SDL_PixelFormat_Unknown if the conversion wasn't possible.
|
||||||
|
*
|
||||||
|
* \sa SDL_PixelFormatEnumToMasks()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint32 SDLCALL SDL_MasksToPixelFormatEnum(int bpp,
|
||||||
|
Uint32 Rmask,
|
||||||
|
Uint32 Gmask,
|
||||||
|
Uint32 Bmask,
|
||||||
|
Uint32 Amask);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDL_Palette *SDL_AllocPalette(int ncolors)
|
||||||
|
*
|
||||||
|
* \brief Create a palette structure with the specified number of color entries.
|
||||||
|
*
|
||||||
|
* \return A new palette, or NULL if there wasn't enough memory
|
||||||
|
*
|
||||||
|
* \note The palette entries are initialized to white.
|
||||||
|
*
|
||||||
|
* \sa SDL_FreePalette()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_Palette *SDLCALL SDL_AllocPalette(int ncolors);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_AddPaletteWatch(SDL_Palette *palette, SDL_PaletteChangedFunc callback, void *userdata)
|
||||||
|
*
|
||||||
|
* \brief Add a callback function which is called when the palette changes.
|
||||||
|
*
|
||||||
|
* \sa SDL_DelPaletteWatch()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_AddPaletteWatch(SDL_Palette * palette,
|
||||||
|
SDL_PaletteChangedFunc
|
||||||
|
callback, void *userdata);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn void SDL_DelPaletteWatch(SDL_Palette *palette, SDL_PaletteChangedFunc callback, void *userdata)
|
||||||
|
*
|
||||||
|
* \brief Remove a callback function previously added with SDL_AddPaletteWatch()
|
||||||
|
*
|
||||||
|
* \sa SDL_AddPaletteWatch()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_DelPaletteWatch(SDL_Palette * palette,
|
||||||
|
SDL_PaletteChangedFunc
|
||||||
|
callback, void *userdata);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_SetPaletteColors(SDL_Palette *palette, const SDL_Colors *colors, int firstcolor, int numcolors)
|
||||||
|
*
|
||||||
|
* \brief Set a range of colors in a palette.
|
||||||
|
*
|
||||||
|
* \param palette The palette to modify
|
||||||
|
* \param colors An array of colors to copy into the palette
|
||||||
|
* \param firstcolor The index of the first palette entry to modify
|
||||||
|
* \param ncolors The number of entries to modify
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if not all of the colors could be set
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetPaletteColors(SDL_Palette * palette,
|
||||||
|
const SDL_Color * colors,
|
||||||
|
int firstcolor, int ncolors);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn void SDL_FreePalette(SDL_Palette *palette)
|
||||||
|
*
|
||||||
|
* \brief Free a palette created with SDL_AllocPalette()
|
||||||
|
*
|
||||||
|
* \sa SDL_AllocPalette()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_FreePalette(SDL_Palette * palette);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn Uint32 SDL_MapRGB(const SDL_PixelFormat *format,
|
||||||
|
* Uint8 r, Uint8 g, Uint8 b)
|
||||||
|
*
|
||||||
|
* \brief Maps an RGB triple to an opaque pixel value for a given pixel format
|
||||||
|
*
|
||||||
|
* \sa SDL_MapRGBA
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint32 SDLCALL SDL_MapRGB(const SDL_PixelFormat * format,
|
||||||
|
Uint8 r, Uint8 g, Uint8 b);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn Uint32 SDL_MapRGBA(const SDL_PixelFormat *fmt,
|
||||||
|
* Uint8 r, Uint8 g, Uint8 b, Uint8 a)
|
||||||
|
*
|
||||||
|
* \brief Maps an RGBA quadruple to a pixel value for a given pixel format
|
||||||
|
*
|
||||||
|
* \sa SDL_MapRGB
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint32 SDLCALL SDL_MapRGBA(const SDL_PixelFormat * format,
|
||||||
|
Uint8 r, Uint8 g, Uint8 b,
|
||||||
|
Uint8 a);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn void SDL_GetRGB(Uint32 pixel, const SDL_PixelFormat * format,
|
||||||
|
* Uint8 * r, Uint8 * g, Uint8 * b)
|
||||||
|
*
|
||||||
|
* \brief Maps a pixel value into the RGB components for a given pixel format
|
||||||
|
*
|
||||||
|
* \sa SDL_GetRGBA
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_GetRGB(Uint32 pixel,
|
||||||
|
const SDL_PixelFormat * format,
|
||||||
|
Uint8 * r, Uint8 * g, Uint8 * b);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn void SDL_GetRGBA(Uint32 pixel, const SDL_PixelFormat * format,
|
||||||
|
* Uint8 * r, Uint8 * g, Uint8 * b, Uint8 * a)
|
||||||
|
*
|
||||||
|
* \brief Maps a pixel value into the RGBA components for a given pixel format
|
||||||
|
*
|
||||||
|
* \sa SDL_GetRGB
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_GetRGBA(Uint32 pixel,
|
||||||
|
const SDL_PixelFormat * format,
|
||||||
|
Uint8 * r, Uint8 * g, Uint8 * b,
|
||||||
|
Uint8 * a);
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_pixels_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,122 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Try to get a standard set of platform defines */
|
||||||
|
|
||||||
|
#ifndef _SDL_platform_h
|
||||||
|
#define _SDL_platform_h
|
||||||
|
|
||||||
|
#if defined(_AIX)
|
||||||
|
#undef __AIX__
|
||||||
|
#define __AIX__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(__BEOS__)
|
||||||
|
#undef __BEOS__
|
||||||
|
#define __BEOS__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(bsdi) || defined(__bsdi) || defined(__bsdi__)
|
||||||
|
#undef __BSDI__
|
||||||
|
#define __BSDI__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(_arch_dreamcast)
|
||||||
|
#undef __DREAMCAST__
|
||||||
|
#define __DREAMCAST__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(__FreeBSD__) || defined(__DragonFly__)
|
||||||
|
#undef __FREEBSD__
|
||||||
|
#define __FREEBSD__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(hpux) || defined(__hpux) || defined(__hpux__)
|
||||||
|
#undef __HPUX__
|
||||||
|
#define __HPUX__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(sgi) || defined(__sgi) || defined(__sgi__) || defined(_SGI_SOURCE)
|
||||||
|
#undef __IRIX__
|
||||||
|
#define __IRIX__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(linux) || defined(__linux) || defined(__linux__)
|
||||||
|
#undef __LINUX__
|
||||||
|
#define __LINUX__ 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__APPLE__)
|
||||||
|
/* lets us know what version of Mac OS X we're compiling on */
|
||||||
|
#include "AvailabilityMacros.h"
|
||||||
|
#ifdef MAC_OS_X_VERSION_10_3
|
||||||
|
#include "TargetConditionals.h" /* this header is in 10.3 or later */
|
||||||
|
#if TARGET_OS_IPHONE
|
||||||
|
/* if compiling for iPhone */
|
||||||
|
#undef __IPHONEOS__
|
||||||
|
#define __IPHONEOS__ 1
|
||||||
|
#undef __MACOSX__
|
||||||
|
#else
|
||||||
|
/* if not compiling for iPhone */
|
||||||
|
#undef __MACOSX__
|
||||||
|
#define __MACOSX__ 1
|
||||||
|
#endif /* TARGET_OS_IPHONE */
|
||||||
|
#else
|
||||||
|
/* if earlier verion of Mac OS X than version 10.3 */
|
||||||
|
#undef __MACOSX__
|
||||||
|
#define __MACOSX__ 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* defined(__APPLE__) */
|
||||||
|
|
||||||
|
#if defined(__NetBSD__)
|
||||||
|
#undef __NETBSD__
|
||||||
|
#define __NETBSD__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(__OpenBSD__)
|
||||||
|
#undef __OPENBSD__
|
||||||
|
#define __OPENBSD__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(__OS2__)
|
||||||
|
#undef __OS2__
|
||||||
|
#define __OS2__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(osf) || defined(__osf) || defined(__osf__) || defined(_OSF_SOURCE)
|
||||||
|
#undef __OSF__
|
||||||
|
#define __OSF__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(__QNXNTO__)
|
||||||
|
#undef __QNXNTO__
|
||||||
|
#define __QNXNTO__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(riscos) || defined(__riscos) || defined(__riscos__)
|
||||||
|
#undef __RISCOS__
|
||||||
|
#define __RISCOS__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(__SVR4)
|
||||||
|
#undef __SOLARIS__
|
||||||
|
#define __SOLARIS__ 1
|
||||||
|
#endif
|
||||||
|
#if defined(WIN32) || defined(_WIN32)
|
||||||
|
#undef __WIN32__
|
||||||
|
#define __WIN32__ 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__NDS__)
|
||||||
|
#undef __NINTENDODS__
|
||||||
|
#define __NINTENDODS__ 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _SDL_platform_h */
|
|
@ -0,0 +1,54 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_quit.h
|
||||||
|
*
|
||||||
|
* Include file for SDL quit event handling
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_quit_h
|
||||||
|
#define _SDL_quit_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
|
||||||
|
/*
|
||||||
|
An SDL_QUITEVENT is generated when the user tries to close the application
|
||||||
|
window. If it is ignored or filtered out, the window will remain open.
|
||||||
|
If it is not ignored or filtered, it is queued normally and the window
|
||||||
|
is allowed to close. When the window is closed, screen updates will
|
||||||
|
complete, but have no effect.
|
||||||
|
|
||||||
|
SDL_Init() installs signal handlers for SIGINT (keyboard interrupt)
|
||||||
|
and SIGTERM (system termination request), if handlers do not already
|
||||||
|
exist, that generate SDL_QUITEVENT events as well. There is no way
|
||||||
|
to determine the cause of an SDL_QUITEVENT, but setting a signal
|
||||||
|
handler in your application will override the default generation of
|
||||||
|
quit events for that signal.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* There are no functions directly affecting the quit event */
|
||||||
|
#define SDL_QuitRequested() \
|
||||||
|
(SDL_PumpEvents(), SDL_PeepEvents(NULL,0,SDL_PEEKEVENT,SDL_QUITMASK))
|
||||||
|
|
||||||
|
#endif /* _SDL_quit_h */
|
|
@ -0,0 +1,129 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_rect.h
|
||||||
|
*
|
||||||
|
* Header file for SDL_rect definition and management functions
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_rect_h
|
||||||
|
#define _SDL_rect_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
#include "SDL_pixels.h"
|
||||||
|
#include "SDL_rwops.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_Rect
|
||||||
|
*
|
||||||
|
* \brief A rectangle, with the origin at the upper left.
|
||||||
|
*
|
||||||
|
* \sa SDL_RectEmpty
|
||||||
|
* \sa SDL_RectEquals
|
||||||
|
* \sa SDL_HasIntersection
|
||||||
|
* \sa SDL_IntersectRect
|
||||||
|
* \sa SDL_UnionRect
|
||||||
|
*/
|
||||||
|
typedef struct SDL_Rect
|
||||||
|
{
|
||||||
|
int x, y;
|
||||||
|
int w, h;
|
||||||
|
} SDL_Rect;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \def SDL_RectEmpty()
|
||||||
|
*
|
||||||
|
* \brief Returns true if the rectangle has no area.
|
||||||
|
*/
|
||||||
|
#define SDL_RectEmpty(X) (((X)->w <= 0) || ((X)->h <= 0))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \def SDL_RectEquals()
|
||||||
|
*
|
||||||
|
* \brief Returns true if the two rectangles are equal.
|
||||||
|
*/
|
||||||
|
#define SDL_RectEquals(A, B) (((A)->x == (B)->x) && ((A)->y == (B)->y) && \
|
||||||
|
((A)->w == (B)->w) && ((A)->h == (B)->h))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDL_bool SDL_HasIntersection(const SDL_Rect * A, const SDL_Rect * B);
|
||||||
|
*
|
||||||
|
* \brief Determine whether two rectangles intersect.
|
||||||
|
*
|
||||||
|
* \return SDL_TRUE if there is an intersection, SDL_FALSE otherwise.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_HasIntersection(const SDL_Rect * A,
|
||||||
|
const SDL_Rect * B);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDL_bool SDL_IntersectRect(const SDL_Rect * A, const SDL_Rect * B, SDL_Rect * result)
|
||||||
|
*
|
||||||
|
* \brief Calculate the intersection of two rectangles.
|
||||||
|
*
|
||||||
|
* \return SDL_TRUE if there is an intersection, SDL_FALSE otherwise.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_IntersectRect(const SDL_Rect * A,
|
||||||
|
const SDL_Rect * B,
|
||||||
|
SDL_Rect * result);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn void SDL_UnionRect(const SDL_Rect * A, const SDL_Rect * B, SDL_Rect * result)
|
||||||
|
*
|
||||||
|
* \brief Calculate the union of two rectangles
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_UnionRect(const SDL_Rect * A,
|
||||||
|
const SDL_Rect * B,
|
||||||
|
SDL_Rect * result);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn SDL_bool SDL_IntersectRectAndLine(const SDL_Rect *rect, int *X1, int *Y1, int *X2, int *Y2)
|
||||||
|
*
|
||||||
|
* \brief Calculate the intersection of a rectangle and line segment.
|
||||||
|
*
|
||||||
|
* \return SDL_TRUE if there is an intersection, SDL_FALSE otherwise.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_IntersectRectAndLine(const SDL_Rect *
|
||||||
|
rect, int *X1,
|
||||||
|
int *Y1, int *X2,
|
||||||
|
int *Y2);
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_rect_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1 @@
|
||||||
|
#define SDL_REVISION 4404
|
|
@ -0,0 +1,168 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_rwops.h
|
||||||
|
*
|
||||||
|
* This file provides a general interface for SDL to read and write
|
||||||
|
* data sources. It can easily be extended to files, memory, etc.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_rwops_h
|
||||||
|
#define _SDL_rwops_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* This is the read/write operation structure -- very basic */
|
||||||
|
|
||||||
|
typedef struct SDL_RWops
|
||||||
|
{
|
||||||
|
/* Seek to 'offset' relative to whence, one of stdio's whence values:
|
||||||
|
RW_SEEK_SET, RW_SEEK_CUR, RW_SEEK_END
|
||||||
|
Returns the final offset in the data source.
|
||||||
|
*/
|
||||||
|
long (SDLCALL * seek) (struct SDL_RWops * context, long offset,
|
||||||
|
int whence);
|
||||||
|
|
||||||
|
/* Read up to 'num' objects each of size 'objsize' from the data
|
||||||
|
source to the area pointed at by 'ptr'.
|
||||||
|
Returns the number of objects read, or 0 at error or end of file.
|
||||||
|
*/
|
||||||
|
size_t(SDLCALL * read) (struct SDL_RWops * context, void *ptr,
|
||||||
|
size_t size, size_t maxnum);
|
||||||
|
|
||||||
|
/* Write exactly 'num' objects each of size 'objsize' from the area
|
||||||
|
pointed at by 'ptr' to data source.
|
||||||
|
Returns the number of objects written, or 0 at error or end of file.
|
||||||
|
*/
|
||||||
|
size_t(SDLCALL * write) (struct SDL_RWops * context, const void *ptr,
|
||||||
|
size_t size, size_t num);
|
||||||
|
|
||||||
|
/* Close and free an allocated SDL_RWops structure.
|
||||||
|
Returns 0 if successful or -1 on write error when flushing data.
|
||||||
|
*/
|
||||||
|
int (SDLCALL * close) (struct SDL_RWops * context);
|
||||||
|
|
||||||
|
Uint32 type;
|
||||||
|
union
|
||||||
|
{
|
||||||
|
#ifdef __WIN32__
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
SDL_bool append;
|
||||||
|
void *h;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
void *data;
|
||||||
|
int size;
|
||||||
|
int left;
|
||||||
|
} buffer;
|
||||||
|
} win32io;
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_STDIO_H
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
SDL_bool autoclose;
|
||||||
|
FILE *fp;
|
||||||
|
} stdio;
|
||||||
|
#endif
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
Uint8 *base;
|
||||||
|
Uint8 *here;
|
||||||
|
Uint8 *stop;
|
||||||
|
} mem;
|
||||||
|
struct
|
||||||
|
{
|
||||||
|
void *data1;
|
||||||
|
} unknown;
|
||||||
|
} hidden;
|
||||||
|
|
||||||
|
} SDL_RWops;
|
||||||
|
|
||||||
|
|
||||||
|
/* Functions to create SDL_RWops structures from various data sources */
|
||||||
|
|
||||||
|
extern DECLSPEC SDL_RWops *SDLCALL SDL_RWFromFile(const char *file,
|
||||||
|
const char *mode);
|
||||||
|
|
||||||
|
#ifdef HAVE_STDIO_H
|
||||||
|
extern DECLSPEC SDL_RWops *SDLCALL SDL_RWFromFP(FILE * fp,
|
||||||
|
SDL_bool autoclose);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern DECLSPEC SDL_RWops *SDLCALL SDL_RWFromMem(void *mem, int size);
|
||||||
|
extern DECLSPEC SDL_RWops *SDLCALL SDL_RWFromConstMem(const void *mem,
|
||||||
|
int size);
|
||||||
|
|
||||||
|
extern DECLSPEC SDL_RWops *SDLCALL SDL_AllocRW(void);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_FreeRW(SDL_RWops * area);
|
||||||
|
|
||||||
|
#define RW_SEEK_SET 0 /* Seek from the beginning of data */
|
||||||
|
#define RW_SEEK_CUR 1 /* Seek relative to current read point */
|
||||||
|
#define RW_SEEK_END 2 /* Seek relative to the end of data */
|
||||||
|
|
||||||
|
/* Macros to easily read and write from an SDL_RWops structure */
|
||||||
|
#define SDL_RWseek(ctx, offset, whence) (ctx)->seek(ctx, offset, whence)
|
||||||
|
#define SDL_RWtell(ctx) (ctx)->seek(ctx, 0, RW_SEEK_CUR)
|
||||||
|
#define SDL_RWread(ctx, ptr, size, n) (ctx)->read(ctx, ptr, size, n)
|
||||||
|
#define SDL_RWwrite(ctx, ptr, size, n) (ctx)->write(ctx, ptr, size, n)
|
||||||
|
#define SDL_RWclose(ctx) (ctx)->close(ctx)
|
||||||
|
|
||||||
|
|
||||||
|
/* Read an item of the specified endianness and return in native format */
|
||||||
|
extern DECLSPEC Uint16 SDLCALL SDL_ReadLE16(SDL_RWops * src);
|
||||||
|
extern DECLSPEC Uint16 SDLCALL SDL_ReadBE16(SDL_RWops * src);
|
||||||
|
extern DECLSPEC Uint32 SDLCALL SDL_ReadLE32(SDL_RWops * src);
|
||||||
|
extern DECLSPEC Uint32 SDLCALL SDL_ReadBE32(SDL_RWops * src);
|
||||||
|
extern DECLSPEC Uint64 SDLCALL SDL_ReadLE64(SDL_RWops * src);
|
||||||
|
extern DECLSPEC Uint64 SDLCALL SDL_ReadBE64(SDL_RWops * src);
|
||||||
|
|
||||||
|
/* Write an item of native format to the specified endianness */
|
||||||
|
extern DECLSPEC int SDLCALL SDL_WriteLE16(SDL_RWops * dst, Uint16 value);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_WriteBE16(SDL_RWops * dst, Uint16 value);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_WriteLE32(SDL_RWops * dst, Uint32 value);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_WriteBE32(SDL_RWops * dst, Uint32 value);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_WriteLE64(SDL_RWops * dst, Uint64 value);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_WriteBE64(SDL_RWops * dst, Uint64 value);
|
||||||
|
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_rwops_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,319 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_scancode.h
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_scancode_h
|
||||||
|
#define _SDL_scancode_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \enum SDL_scancode
|
||||||
|
*
|
||||||
|
* \brief The SDL keyboard scancode representation.
|
||||||
|
*
|
||||||
|
* Values of this type are used to represent keyboard keys, among other places
|
||||||
|
* in the \link SDL_keysym::scancode key.keysym.scancode \endlink field of the
|
||||||
|
* SDL_Event structure.
|
||||||
|
*
|
||||||
|
* The values in this enumeration are based on the USB usage page standard:
|
||||||
|
* http://www.usb.org/developers/devclass_docs/Hut1_12.pdf
|
||||||
|
*/
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
SDL_SCANCODE_UNKNOWN = 0,
|
||||||
|
|
||||||
|
/* These values are from usage page 0x07 (USB keyboard page) */
|
||||||
|
|
||||||
|
SDL_SCANCODE_A = 4,
|
||||||
|
SDL_SCANCODE_B = 5,
|
||||||
|
SDL_SCANCODE_C = 6,
|
||||||
|
SDL_SCANCODE_D = 7,
|
||||||
|
SDL_SCANCODE_E = 8,
|
||||||
|
SDL_SCANCODE_F = 9,
|
||||||
|
SDL_SCANCODE_G = 10,
|
||||||
|
SDL_SCANCODE_H = 11,
|
||||||
|
SDL_SCANCODE_I = 12,
|
||||||
|
SDL_SCANCODE_J = 13,
|
||||||
|
SDL_SCANCODE_K = 14,
|
||||||
|
SDL_SCANCODE_L = 15,
|
||||||
|
SDL_SCANCODE_M = 16,
|
||||||
|
SDL_SCANCODE_N = 17,
|
||||||
|
SDL_SCANCODE_O = 18,
|
||||||
|
SDL_SCANCODE_P = 19,
|
||||||
|
SDL_SCANCODE_Q = 20,
|
||||||
|
SDL_SCANCODE_R = 21,
|
||||||
|
SDL_SCANCODE_S = 22,
|
||||||
|
SDL_SCANCODE_T = 23,
|
||||||
|
SDL_SCANCODE_U = 24,
|
||||||
|
SDL_SCANCODE_V = 25,
|
||||||
|
SDL_SCANCODE_W = 26,
|
||||||
|
SDL_SCANCODE_X = 27,
|
||||||
|
SDL_SCANCODE_Y = 28,
|
||||||
|
SDL_SCANCODE_Z = 29,
|
||||||
|
|
||||||
|
SDL_SCANCODE_1 = 30,
|
||||||
|
SDL_SCANCODE_2 = 31,
|
||||||
|
SDL_SCANCODE_3 = 32,
|
||||||
|
SDL_SCANCODE_4 = 33,
|
||||||
|
SDL_SCANCODE_5 = 34,
|
||||||
|
SDL_SCANCODE_6 = 35,
|
||||||
|
SDL_SCANCODE_7 = 36,
|
||||||
|
SDL_SCANCODE_8 = 37,
|
||||||
|
SDL_SCANCODE_9 = 38,
|
||||||
|
SDL_SCANCODE_0 = 39,
|
||||||
|
|
||||||
|
SDL_SCANCODE_RETURN = 40,
|
||||||
|
SDL_SCANCODE_ESCAPE = 41,
|
||||||
|
SDL_SCANCODE_BACKSPACE = 42,
|
||||||
|
SDL_SCANCODE_TAB = 43,
|
||||||
|
SDL_SCANCODE_SPACE = 44,
|
||||||
|
|
||||||
|
SDL_SCANCODE_MINUS = 45,
|
||||||
|
SDL_SCANCODE_EQUALS = 46,
|
||||||
|
SDL_SCANCODE_LEFTBRACKET = 47,
|
||||||
|
SDL_SCANCODE_RIGHTBRACKET = 48,
|
||||||
|
SDL_SCANCODE_BACKSLASH = 49, /**< Located at the lower left of the return key on ISO keyboards and at the right end of the QWERTY row on ANSI keyboards. Produces REVERSE SOLIDUS (backslash) and VERTICAL LINE in a US layout, REVERSE SOLIDUS and VERTICAL LINE in a UK Mac layout, NUMBER SIGN and TILDE in a UK Windows layout, DOLLAR SIGN and POUND SIGN in a Swiss German layout, NUMBER SIGN and APOSTROPHE in a German layout, GRAVE ACCENT and POUND SIGN in a French Mac layout, and ASTERISK and MICRO SIGN in a French Windows layout. */
|
||||||
|
SDL_SCANCODE_NONUSHASH = 50, /**< ISO USB keyboards actually use this code instead of 49 for the same key, but all OSes I've seen treat the two codes identically. So, as an implementor, unless your keyboard generates both of those codes and your OS treats them differently, you should generate SDL_SCANCODE_BACKSLASH instead of this code. As a user, you should not rely on this code because SDL will never generate it with most (all?) keyboards. */
|
||||||
|
SDL_SCANCODE_SEMICOLON = 51,
|
||||||
|
SDL_SCANCODE_APOSTROPHE = 52,
|
||||||
|
SDL_SCANCODE_GRAVE = 53, /**< Located in the top left corner (on both ANSI and ISO keyboards). Produces GRAVE ACCENT and TILDE in a US Windows layout and in US and UK Mac layouts on ANSI keyboards, GRAVE ACCENT and NOT SIGN in a UK Windows layout, SECTION SIGN and PLUS-MINUS SIGN in US and UK Mac layouts on ISO keyboards, SECTION SIGN and DEGREE SIGN in a Swiss German layout (Mac: only on ISO keyboards), CIRCUMFLEX ACCENT and DEGREE SIGN in a German layout (Mac: only on ISO keyboards), SUPERSCRIPT TWO and TILDE in a French Windows layout, COMMERCIAL AT and NUMBER SIGN in a French Mac layout on ISO keyboards, and LESS-THAN SIGN and GREATER-THAN SIGN in a Swiss German, German, or French Mac layout on ANSI keyboards. */
|
||||||
|
SDL_SCANCODE_COMMA = 54,
|
||||||
|
SDL_SCANCODE_PERIOD = 55,
|
||||||
|
SDL_SCANCODE_SLASH = 56,
|
||||||
|
|
||||||
|
SDL_SCANCODE_CAPSLOCK = 57,
|
||||||
|
|
||||||
|
SDL_SCANCODE_F1 = 58,
|
||||||
|
SDL_SCANCODE_F2 = 59,
|
||||||
|
SDL_SCANCODE_F3 = 60,
|
||||||
|
SDL_SCANCODE_F4 = 61,
|
||||||
|
SDL_SCANCODE_F5 = 62,
|
||||||
|
SDL_SCANCODE_F6 = 63,
|
||||||
|
SDL_SCANCODE_F7 = 64,
|
||||||
|
SDL_SCANCODE_F8 = 65,
|
||||||
|
SDL_SCANCODE_F9 = 66,
|
||||||
|
SDL_SCANCODE_F10 = 67,
|
||||||
|
SDL_SCANCODE_F11 = 68,
|
||||||
|
SDL_SCANCODE_F12 = 69,
|
||||||
|
|
||||||
|
SDL_SCANCODE_PRINTSCREEN = 70,
|
||||||
|
SDL_SCANCODE_SCROLLLOCK = 71,
|
||||||
|
SDL_SCANCODE_PAUSE = 72,
|
||||||
|
SDL_SCANCODE_INSERT = 73, /**< insert on PC, help on some Mac keyboards (but does send code 73, not 117) */
|
||||||
|
SDL_SCANCODE_HOME = 74,
|
||||||
|
SDL_SCANCODE_PAGEUP = 75,
|
||||||
|
SDL_SCANCODE_DELETE = 76,
|
||||||
|
SDL_SCANCODE_END = 77,
|
||||||
|
SDL_SCANCODE_PAGEDOWN = 78,
|
||||||
|
SDL_SCANCODE_RIGHT = 79,
|
||||||
|
SDL_SCANCODE_LEFT = 80,
|
||||||
|
SDL_SCANCODE_DOWN = 81,
|
||||||
|
SDL_SCANCODE_UP = 82,
|
||||||
|
|
||||||
|
SDL_SCANCODE_NUMLOCKCLEAR = 83, /**< num lock on PC, clear on Mac keyboards */
|
||||||
|
SDL_SCANCODE_KP_DIVIDE = 84,
|
||||||
|
SDL_SCANCODE_KP_MULTIPLY = 85,
|
||||||
|
SDL_SCANCODE_KP_MINUS = 86,
|
||||||
|
SDL_SCANCODE_KP_PLUS = 87,
|
||||||
|
SDL_SCANCODE_KP_ENTER = 88,
|
||||||
|
SDL_SCANCODE_KP_1 = 89,
|
||||||
|
SDL_SCANCODE_KP_2 = 90,
|
||||||
|
SDL_SCANCODE_KP_3 = 91,
|
||||||
|
SDL_SCANCODE_KP_4 = 92,
|
||||||
|
SDL_SCANCODE_KP_5 = 93,
|
||||||
|
SDL_SCANCODE_KP_6 = 94,
|
||||||
|
SDL_SCANCODE_KP_7 = 95,
|
||||||
|
SDL_SCANCODE_KP_8 = 96,
|
||||||
|
SDL_SCANCODE_KP_9 = 97,
|
||||||
|
SDL_SCANCODE_KP_0 = 98,
|
||||||
|
SDL_SCANCODE_KP_PERIOD = 99,
|
||||||
|
|
||||||
|
SDL_SCANCODE_NONUSBACKSLASH = 100, /**< This is the additional key that ISO keyboards have over ANSI ones, located between left shift and Y. Produces GRAVE ACCENT and TILDE in a US or UK Mac layout, REVERSE SOLIDUS (backslash) and VERTICAL LINE in a US or UK Windows layout, and LESS-THAN SIGN and GREATER-THAN SIGN in a Swiss German, German, or French layout. */
|
||||||
|
SDL_SCANCODE_APPLICATION = 101, /**< windows contextual menu, compose */
|
||||||
|
SDL_SCANCODE_POWER = 102, /**< The USB document says this is a status flag, not a physical key - but some Mac keyboards do have a power key. */
|
||||||
|
SDL_SCANCODE_KP_EQUALS = 103,
|
||||||
|
SDL_SCANCODE_F13 = 104,
|
||||||
|
SDL_SCANCODE_F14 = 105,
|
||||||
|
SDL_SCANCODE_F15 = 106,
|
||||||
|
SDL_SCANCODE_F16 = 107,
|
||||||
|
SDL_SCANCODE_F17 = 108,
|
||||||
|
SDL_SCANCODE_F18 = 109,
|
||||||
|
SDL_SCANCODE_F19 = 110,
|
||||||
|
SDL_SCANCODE_F20 = 111,
|
||||||
|
SDL_SCANCODE_F21 = 112,
|
||||||
|
SDL_SCANCODE_F22 = 113,
|
||||||
|
SDL_SCANCODE_F23 = 114,
|
||||||
|
SDL_SCANCODE_F24 = 115,
|
||||||
|
SDL_SCANCODE_EXECUTE = 116,
|
||||||
|
SDL_SCANCODE_HELP = 117,
|
||||||
|
SDL_SCANCODE_MENU = 118,
|
||||||
|
SDL_SCANCODE_SELECT = 119,
|
||||||
|
SDL_SCANCODE_STOP = 120,
|
||||||
|
SDL_SCANCODE_AGAIN = 121, /*!< redo */
|
||||||
|
SDL_SCANCODE_UNDO = 122,
|
||||||
|
SDL_SCANCODE_CUT = 123,
|
||||||
|
SDL_SCANCODE_COPY = 124,
|
||||||
|
SDL_SCANCODE_PASTE = 125,
|
||||||
|
SDL_SCANCODE_FIND = 126,
|
||||||
|
SDL_SCANCODE_MUTE = 127,
|
||||||
|
SDL_SCANCODE_VOLUMEUP = 128,
|
||||||
|
SDL_SCANCODE_VOLUMEDOWN = 129,
|
||||||
|
/* not sure whether there's a reason to enable these */
|
||||||
|
/* SDL_SCANCODE_LOCKINGCAPSLOCK = 130, */
|
||||||
|
/* SDL_SCANCODE_LOCKINGNUMLOCK = 131, */
|
||||||
|
/* SDL_SCANCODE_LOCKINGSCROLLLOCK = 132, */
|
||||||
|
SDL_SCANCODE_KP_COMMA = 133,
|
||||||
|
SDL_SCANCODE_KP_EQUALSAS400 = 134,
|
||||||
|
|
||||||
|
SDL_SCANCODE_INTERNATIONAL1 = 135, /**< used on Asian keyboards, see footnotes in USB doc */
|
||||||
|
SDL_SCANCODE_INTERNATIONAL2 = 136,
|
||||||
|
SDL_SCANCODE_INTERNATIONAL3 = 137, /**< Yen */
|
||||||
|
SDL_SCANCODE_INTERNATIONAL4 = 138,
|
||||||
|
SDL_SCANCODE_INTERNATIONAL5 = 139,
|
||||||
|
SDL_SCANCODE_INTERNATIONAL6 = 140,
|
||||||
|
SDL_SCANCODE_INTERNATIONAL7 = 141,
|
||||||
|
SDL_SCANCODE_INTERNATIONAL8 = 142,
|
||||||
|
SDL_SCANCODE_INTERNATIONAL9 = 143,
|
||||||
|
SDL_SCANCODE_LANG1 = 144, /**< Hangul/English toggle */
|
||||||
|
SDL_SCANCODE_LANG2 = 145, /**< Hanja conversion */
|
||||||
|
SDL_SCANCODE_LANG3 = 146, /**< Katakana */
|
||||||
|
SDL_SCANCODE_LANG4 = 147, /**< Hiragana */
|
||||||
|
SDL_SCANCODE_LANG5 = 148, /**< Zenkaku/Hankaku */
|
||||||
|
SDL_SCANCODE_LANG6 = 149, /**< reserved */
|
||||||
|
SDL_SCANCODE_LANG7 = 150, /**< reserved */
|
||||||
|
SDL_SCANCODE_LANG8 = 151, /**< reserved */
|
||||||
|
SDL_SCANCODE_LANG9 = 152, /**< reserved */
|
||||||
|
|
||||||
|
SDL_SCANCODE_ALTERASE = 153, /**< Erase-Eaze */
|
||||||
|
SDL_SCANCODE_SYSREQ = 154,
|
||||||
|
SDL_SCANCODE_CANCEL = 155,
|
||||||
|
SDL_SCANCODE_CLEAR = 156,
|
||||||
|
SDL_SCANCODE_PRIOR = 157,
|
||||||
|
SDL_SCANCODE_RETURN2 = 158,
|
||||||
|
SDL_SCANCODE_SEPARATOR = 159,
|
||||||
|
SDL_SCANCODE_OUT = 160,
|
||||||
|
SDL_SCANCODE_OPER = 161,
|
||||||
|
SDL_SCANCODE_CLEARAGAIN = 162,
|
||||||
|
SDL_SCANCODE_CRSEL = 163,
|
||||||
|
SDL_SCANCODE_EXSEL = 164,
|
||||||
|
|
||||||
|
SDL_SCANCODE_KP_00 = 176,
|
||||||
|
SDL_SCANCODE_KP_000 = 177,
|
||||||
|
SDL_SCANCODE_THOUSANDSSEPARATOR = 178,
|
||||||
|
SDL_SCANCODE_DECIMALSEPARATOR = 179,
|
||||||
|
SDL_SCANCODE_CURRENCYUNIT = 180,
|
||||||
|
SDL_SCANCODE_CURRENCYSUBUNIT = 181,
|
||||||
|
SDL_SCANCODE_KP_LEFTPAREN = 182,
|
||||||
|
SDL_SCANCODE_KP_RIGHTPAREN = 183,
|
||||||
|
SDL_SCANCODE_KP_LEFTBRACE = 184,
|
||||||
|
SDL_SCANCODE_KP_RIGHTBRACE = 185,
|
||||||
|
SDL_SCANCODE_KP_TAB = 186,
|
||||||
|
SDL_SCANCODE_KP_BACKSPACE = 187,
|
||||||
|
SDL_SCANCODE_KP_A = 188,
|
||||||
|
SDL_SCANCODE_KP_B = 189,
|
||||||
|
SDL_SCANCODE_KP_C = 190,
|
||||||
|
SDL_SCANCODE_KP_D = 191,
|
||||||
|
SDL_SCANCODE_KP_E = 192,
|
||||||
|
SDL_SCANCODE_KP_F = 193,
|
||||||
|
SDL_SCANCODE_KP_XOR = 194,
|
||||||
|
SDL_SCANCODE_KP_POWER = 195,
|
||||||
|
SDL_SCANCODE_KP_PERCENT = 196,
|
||||||
|
SDL_SCANCODE_KP_LESS = 197,
|
||||||
|
SDL_SCANCODE_KP_GREATER = 198,
|
||||||
|
SDL_SCANCODE_KP_AMPERSAND = 199,
|
||||||
|
SDL_SCANCODE_KP_DBLAMPERSAND = 200,
|
||||||
|
SDL_SCANCODE_KP_VERTICALBAR = 201,
|
||||||
|
SDL_SCANCODE_KP_DBLVERTICALBAR = 202,
|
||||||
|
SDL_SCANCODE_KP_COLON = 203,
|
||||||
|
SDL_SCANCODE_KP_HASH = 204,
|
||||||
|
SDL_SCANCODE_KP_SPACE = 205,
|
||||||
|
SDL_SCANCODE_KP_AT = 206,
|
||||||
|
SDL_SCANCODE_KP_EXCLAM = 207,
|
||||||
|
SDL_SCANCODE_KP_MEMSTORE = 208,
|
||||||
|
SDL_SCANCODE_KP_MEMRECALL = 209,
|
||||||
|
SDL_SCANCODE_KP_MEMCLEAR = 210,
|
||||||
|
SDL_SCANCODE_KP_MEMADD = 211,
|
||||||
|
SDL_SCANCODE_KP_MEMSUBTRACT = 212,
|
||||||
|
SDL_SCANCODE_KP_MEMMULTIPLY = 213,
|
||||||
|
SDL_SCANCODE_KP_MEMDIVIDE = 214,
|
||||||
|
SDL_SCANCODE_KP_PLUSMINUS = 215,
|
||||||
|
SDL_SCANCODE_KP_CLEAR = 216,
|
||||||
|
SDL_SCANCODE_KP_CLEARENTRY = 217,
|
||||||
|
SDL_SCANCODE_KP_BINARY = 218,
|
||||||
|
SDL_SCANCODE_KP_OCTAL = 219,
|
||||||
|
SDL_SCANCODE_KP_DECIMAL = 220,
|
||||||
|
SDL_SCANCODE_KP_HEXADECIMAL = 221,
|
||||||
|
|
||||||
|
SDL_SCANCODE_LCTRL = 224,
|
||||||
|
SDL_SCANCODE_LSHIFT = 225,
|
||||||
|
SDL_SCANCODE_LALT = 226, /**< alt, option */
|
||||||
|
SDL_SCANCODE_LGUI = 227, /**< windows, command (apple), meta */
|
||||||
|
SDL_SCANCODE_RCTRL = 228,
|
||||||
|
SDL_SCANCODE_RSHIFT = 229,
|
||||||
|
SDL_SCANCODE_RALT = 230, /**< alt gr, option */
|
||||||
|
SDL_SCANCODE_RGUI = 231, /**< windows, command (apple), meta */
|
||||||
|
|
||||||
|
SDL_SCANCODE_MODE = 257, /* I'm not sure if this is really not covered by any of the above, but since there's a special KMOD_MODE for it I'm adding it here */
|
||||||
|
|
||||||
|
/* These values are mapped from usage page 0x0C (USB consumer page) */
|
||||||
|
|
||||||
|
SDL_SCANCODE_AUDIONEXT = 258,
|
||||||
|
SDL_SCANCODE_AUDIOPREV = 259,
|
||||||
|
SDL_SCANCODE_AUDIOSTOP = 260,
|
||||||
|
SDL_SCANCODE_AUDIOPLAY = 261,
|
||||||
|
SDL_SCANCODE_AUDIOMUTE = 262,
|
||||||
|
SDL_SCANCODE_MEDIASELECT = 263,
|
||||||
|
SDL_SCANCODE_WWW = 264,
|
||||||
|
SDL_SCANCODE_MAIL = 265,
|
||||||
|
SDL_SCANCODE_CALCULATOR = 266,
|
||||||
|
SDL_SCANCODE_COMPUTER = 267,
|
||||||
|
SDL_SCANCODE_AC_SEARCH = 268,
|
||||||
|
SDL_SCANCODE_AC_HOME = 269,
|
||||||
|
SDL_SCANCODE_AC_BACK = 270,
|
||||||
|
SDL_SCANCODE_AC_FORWARD = 271,
|
||||||
|
SDL_SCANCODE_AC_STOP = 272,
|
||||||
|
SDL_SCANCODE_AC_REFRESH = 273,
|
||||||
|
SDL_SCANCODE_AC_BOOKMARKS = 274,
|
||||||
|
|
||||||
|
/* These are values that Christian Walther added (for mac keyboard?) */
|
||||||
|
|
||||||
|
SDL_SCANCODE_BRIGHTNESSDOWN = 275,
|
||||||
|
SDL_SCANCODE_BRIGHTNESSUP = 276,
|
||||||
|
SDL_SCANCODE_DISPLAYSWITCH = 277, /**< display mirroring/dual display switch, video mode switch */
|
||||||
|
SDL_SCANCODE_KBDILLUMTOGGLE = 278,
|
||||||
|
SDL_SCANCODE_KBDILLUMDOWN = 279,
|
||||||
|
SDL_SCANCODE_KBDILLUMUP = 280,
|
||||||
|
SDL_SCANCODE_EJECT = 281,
|
||||||
|
SDL_SCANCODE_SLEEP = 282,
|
||||||
|
|
||||||
|
/* Add any other keys here */
|
||||||
|
|
||||||
|
SDL_NUM_SCANCODES = 512 /**< (not a key, just marks the number of scancodes for array bounds) */
|
||||||
|
} SDL_scancode;
|
||||||
|
|
||||||
|
#endif /* _SDL_scancode_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,761 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_stdinc.h
|
||||||
|
*
|
||||||
|
* This is a general header that includes C language support
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_stdinc_h
|
||||||
|
#define _SDL_stdinc_h
|
||||||
|
|
||||||
|
#include "SDL_config.h"
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_SYS_TYPES_H
|
||||||
|
#include <sys/types.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_STDIO_H
|
||||||
|
#include <stdio.h>
|
||||||
|
#endif
|
||||||
|
#if defined(STDC_HEADERS)
|
||||||
|
# include <stdlib.h>
|
||||||
|
# include <stddef.h>
|
||||||
|
# include <stdarg.h>
|
||||||
|
#else
|
||||||
|
# if defined(HAVE_STDLIB_H)
|
||||||
|
# include <stdlib.h>
|
||||||
|
# elif defined(HAVE_MALLOC_H)
|
||||||
|
# include <malloc.h>
|
||||||
|
# endif
|
||||||
|
# if defined(HAVE_STDDEF_H)
|
||||||
|
# include <stddef.h>
|
||||||
|
# endif
|
||||||
|
# if defined(HAVE_STDARG_H)
|
||||||
|
# include <stdarg.h>
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_STRING_H
|
||||||
|
# if !defined(STDC_HEADERS) && defined(HAVE_MEMORY_H)
|
||||||
|
# include <memory.h>
|
||||||
|
# endif
|
||||||
|
# include <string.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_STRINGS_H
|
||||||
|
# include <strings.h>
|
||||||
|
#endif
|
||||||
|
#if defined(HAVE_INTTYPES_H)
|
||||||
|
# include <inttypes.h>
|
||||||
|
#elif defined(HAVE_STDINT_H)
|
||||||
|
# include <stdint.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_CTYPE_H
|
||||||
|
# include <ctype.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_MATH_H
|
||||||
|
# include <math.h>
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_ICONV_H
|
||||||
|
# include <iconv.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The number of elements in an array */
|
||||||
|
#define SDL_arraysize(array) (sizeof(array)/sizeof(array[0]))
|
||||||
|
#define SDL_TABLESIZE(table) SDL_arraysize(table)
|
||||||
|
|
||||||
|
/* Basic data types */
|
||||||
|
typedef enum SDL_bool
|
||||||
|
{
|
||||||
|
SDL_FALSE = 0,
|
||||||
|
SDL_TRUE = 1
|
||||||
|
} SDL_bool;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \typedef Sint8
|
||||||
|
* \brief A signed 8-bit integer type.
|
||||||
|
*/
|
||||||
|
typedef int8_t Sint8;
|
||||||
|
/**
|
||||||
|
* \typedef Uint8
|
||||||
|
* \brief An unsigned 8-bit integer type.
|
||||||
|
*/
|
||||||
|
typedef uint8_t Uint8;
|
||||||
|
/**
|
||||||
|
* \typedef Sint16
|
||||||
|
* \brief A signed 16-bit integer type.
|
||||||
|
*/
|
||||||
|
typedef int16_t Sint16;
|
||||||
|
/**
|
||||||
|
* \typedef Uint16
|
||||||
|
* \brief An unsigned 16-bit integer type.
|
||||||
|
*/
|
||||||
|
typedef uint16_t Uint16;
|
||||||
|
/**
|
||||||
|
* \typedef Sint32
|
||||||
|
* \brief A signed 32-bit integer type.
|
||||||
|
*/
|
||||||
|
typedef int32_t Sint32;
|
||||||
|
/**
|
||||||
|
* \typedef Uint32
|
||||||
|
* \brief An unsigned 32-bit integer type.
|
||||||
|
*/
|
||||||
|
typedef uint32_t Uint32;
|
||||||
|
|
||||||
|
#ifdef SDL_HAS_64BIT_TYPE
|
||||||
|
/**
|
||||||
|
* \typedef Sint64
|
||||||
|
* \brief A signed 64-bit integer type.
|
||||||
|
* \warning On platforms without any sort of 64-bit datatype, this is equivalent to Sint32!
|
||||||
|
*/
|
||||||
|
typedef int64_t Sint64;
|
||||||
|
/**
|
||||||
|
* \typedef Uint64
|
||||||
|
* \brief An unsigned 64-bit integer type.
|
||||||
|
* \warning On platforms without any sort of 64-bit datatype, this is equivalent to Uint32!
|
||||||
|
*/
|
||||||
|
typedef uint64_t Uint64;
|
||||||
|
#else
|
||||||
|
/* This is really just a hack to prevent the compiler from complaining */
|
||||||
|
typedef Sint32 Sint64;
|
||||||
|
typedef Uint32 Uint64;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Make sure the types really have the right sizes */
|
||||||
|
#define SDL_COMPILE_TIME_ASSERT(name, x) \
|
||||||
|
typedef int SDL_dummy_ ## name[(x) * 2 - 1]
|
||||||
|
#ifndef DOXYGEN_SHOULD_IGNORE_THIS
|
||||||
|
SDL_COMPILE_TIME_ASSERT(uint8, sizeof(Uint8) == 1);
|
||||||
|
SDL_COMPILE_TIME_ASSERT(sint8, sizeof(Sint8) == 1);
|
||||||
|
SDL_COMPILE_TIME_ASSERT(uint16, sizeof(Uint16) == 2);
|
||||||
|
SDL_COMPILE_TIME_ASSERT(sint16, sizeof(Sint16) == 2);
|
||||||
|
SDL_COMPILE_TIME_ASSERT(uint32, sizeof(Uint32) == 4);
|
||||||
|
SDL_COMPILE_TIME_ASSERT(sint32, sizeof(Sint32) == 4);
|
||||||
|
#ifndef __NINTENDODS__ /* TODO: figure out why the following happens:
|
||||||
|
include/SDL_stdinc.h:150: error: size of array 'SDL_dummy_uint64' is negative
|
||||||
|
include/SDL_stdinc.h:151: error: size of array 'SDL_dummy_sint64' is negative */
|
||||||
|
SDL_COMPILE_TIME_ASSERT(uint64, sizeof(Uint64) == 8);
|
||||||
|
SDL_COMPILE_TIME_ASSERT(sint64, sizeof(Sint64) == 8);
|
||||||
|
#endif
|
||||||
|
#endif /* DOXYGEN_SHOULD_IGNORE_THIS */
|
||||||
|
|
||||||
|
/* Check to make sure enums are the size of ints, for structure packing.
|
||||||
|
For both Watcom C/C++ and Borland C/C++ the compiler option that makes
|
||||||
|
enums having the size of an int must be enabled.
|
||||||
|
This is "-b" for Borland C/C++ and "-ei" for Watcom C/C++ (v11).
|
||||||
|
*/
|
||||||
|
/* Enable enums always int in CodeWarrior (for MPW use "-enum int") */
|
||||||
|
#ifdef __MWERKS__
|
||||||
|
#pragma enumsalwaysint on
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef DOXYGEN_SHOULD_IGNORE_THIS
|
||||||
|
#ifndef __NINTENDODS__ /* TODO: include/SDL_stdinc.h:174: error: size of array 'SDL_dummy_enum' is negative */
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
DUMMY_ENUM_VALUE
|
||||||
|
} SDL_DUMMY_ENUM;
|
||||||
|
|
||||||
|
SDL_COMPILE_TIME_ASSERT(enum, sizeof(SDL_DUMMY_ENUM) == sizeof(int));
|
||||||
|
#endif
|
||||||
|
#endif /* DOXYGEN_SHOULD_IGNORE_THIS */
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_MALLOC
|
||||||
|
#define SDL_malloc malloc
|
||||||
|
#else
|
||||||
|
extern DECLSPEC void *SDLCALL SDL_malloc(size_t size);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_CALLOC
|
||||||
|
#define SDL_calloc calloc
|
||||||
|
#else
|
||||||
|
extern DECLSPEC void *SDLCALL SDL_calloc(size_t nmemb, size_t size);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_REALLOC
|
||||||
|
#define SDL_realloc realloc
|
||||||
|
#else
|
||||||
|
extern DECLSPEC void *SDLCALL SDL_realloc(void *mem, size_t size);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_FREE
|
||||||
|
#define SDL_free free
|
||||||
|
#else
|
||||||
|
extern DECLSPEC void SDLCALL SDL_free(void *mem);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(HAVE_ALLOCA) && !defined(alloca)
|
||||||
|
# if defined(HAVE_ALLOCA_H)
|
||||||
|
# include <alloca.h>
|
||||||
|
# elif defined(__GNUC__)
|
||||||
|
# define alloca __builtin_alloca
|
||||||
|
# elif defined(_MSC_VER)
|
||||||
|
# include <malloc.h>
|
||||||
|
# define alloca _alloca
|
||||||
|
# elif defined(__WATCOMC__)
|
||||||
|
# include <malloc.h>
|
||||||
|
# elif defined(__BORLANDC__)
|
||||||
|
# include <malloc.h>
|
||||||
|
# elif defined(__DMC__)
|
||||||
|
# include <stdlib.h>
|
||||||
|
# elif defined(__AIX__)
|
||||||
|
#pragma alloca
|
||||||
|
# elif defined(__MRC__)
|
||||||
|
void *alloca(unsigned);
|
||||||
|
# else
|
||||||
|
char *alloca();
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#ifdef HAVE_ALLOCA
|
||||||
|
#define SDL_stack_alloc(type, count) (type*)alloca(sizeof(type)*(count))
|
||||||
|
#define SDL_stack_free(data)
|
||||||
|
#else
|
||||||
|
#define SDL_stack_alloc(type, count) (type*)SDL_malloc(sizeof(type)*(count))
|
||||||
|
#define SDL_stack_free(data) SDL_free(data)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_GETENV
|
||||||
|
#define SDL_getenv getenv
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_getenv(const char *name);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_PUTENV
|
||||||
|
#define SDL_putenv putenv
|
||||||
|
#else
|
||||||
|
extern DECLSPEC int SDLCALL SDL_putenv(const char *variable);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_QSORT
|
||||||
|
#define SDL_qsort qsort
|
||||||
|
#else
|
||||||
|
extern DECLSPEC void SDLCALL SDL_qsort(void *base, size_t nmemb, size_t size,
|
||||||
|
int (*compare) (const void *,
|
||||||
|
const void *));
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_ABS
|
||||||
|
#define SDL_abs abs
|
||||||
|
#else
|
||||||
|
#define SDL_abs(X) ((X) < 0 ? -(X) : (X))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define SDL_min(x, y) (((x) < (y)) ? (x) : (y))
|
||||||
|
#define SDL_max(x, y) (((x) > (y)) ? (x) : (y))
|
||||||
|
|
||||||
|
#ifdef HAVE_CTYPE_H
|
||||||
|
#define SDL_isdigit(X) isdigit(X)
|
||||||
|
#define SDL_isspace(X) isspace(X)
|
||||||
|
#define SDL_toupper(X) toupper(X)
|
||||||
|
#define SDL_tolower(X) tolower(X)
|
||||||
|
#else
|
||||||
|
#define SDL_isdigit(X) (((X) >= '0') && ((X) <= '9'))
|
||||||
|
#define SDL_isspace(X) (((X) == ' ') || ((X) == '\t') || ((X) == '\r') || ((X) == '\n'))
|
||||||
|
#define SDL_toupper(X) (((X) >= 'a') && ((X) <= 'z') ? ('A'+((X)-'a')) : (X))
|
||||||
|
#define SDL_tolower(X) (((X) >= 'A') && ((X) <= 'Z') ? ('a'+((X)-'A')) : (X))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_MEMSET
|
||||||
|
#define SDL_memset memset
|
||||||
|
#else
|
||||||
|
extern DECLSPEC void *SDLCALL SDL_memset(void *dst, int c, size_t len);
|
||||||
|
#endif
|
||||||
|
#define SDL_zero(x) SDL_memset(&(x), 0, sizeof((x)))
|
||||||
|
#define SDL_zerop(x) SDL_memset((x), 0, sizeof(*(x)))
|
||||||
|
|
||||||
|
#if defined(__GNUC__) && defined(i386)
|
||||||
|
#define SDL_memset4(dst, val, len) \
|
||||||
|
do { \
|
||||||
|
int u0, u1, u2; \
|
||||||
|
__asm__ __volatile__ ( \
|
||||||
|
"cld\n\t" \
|
||||||
|
"rep ; stosl\n\t" \
|
||||||
|
: "=&D" (u0), "=&a" (u1), "=&c" (u2) \
|
||||||
|
: "0" (dst), "1" (val), "2" ((Uint32)(len)) \
|
||||||
|
: "memory" ); \
|
||||||
|
} while(0)
|
||||||
|
#endif
|
||||||
|
#ifndef SDL_memset4
|
||||||
|
#define SDL_memset4(dst, val, len) \
|
||||||
|
do { \
|
||||||
|
unsigned _count = (len); \
|
||||||
|
unsigned _n = (_count + 3) / 4; \
|
||||||
|
Uint32 *_p = (Uint32 *)(dst); \
|
||||||
|
Uint32 _val = (val); \
|
||||||
|
switch (_count % 4) { \
|
||||||
|
case 0: do { *_p++ = _val; \
|
||||||
|
case 3: *_p++ = _val; \
|
||||||
|
case 2: *_p++ = _val; \
|
||||||
|
case 1: *_p++ = _val; \
|
||||||
|
} while ( --_n ); \
|
||||||
|
} \
|
||||||
|
} while(0)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* We can count on memcpy existing on Mac OS X and being well-tuned. */
|
||||||
|
#if defined(__MACH__) && defined(__APPLE__)
|
||||||
|
#define SDL_memcpy(dst, src, len) memcpy(dst, src, len)
|
||||||
|
#elif defined(__GNUC__) && defined(i386)
|
||||||
|
#define SDL_memcpy(dst, src, len) \
|
||||||
|
do { \
|
||||||
|
int u0, u1, u2; \
|
||||||
|
__asm__ __volatile__ ( \
|
||||||
|
"cld\n\t" \
|
||||||
|
"rep ; movsl\n\t" \
|
||||||
|
"testb $2,%b4\n\t" \
|
||||||
|
"je 1f\n\t" \
|
||||||
|
"movsw\n" \
|
||||||
|
"1:\ttestb $1,%b4\n\t" \
|
||||||
|
"je 2f\n\t" \
|
||||||
|
"movsb\n" \
|
||||||
|
"2:" \
|
||||||
|
: "=&c" (u0), "=&D" (u1), "=&S" (u2) \
|
||||||
|
: "0" ((unsigned)(len)/4), "q" (len), "1" (dst),"2" (src) \
|
||||||
|
: "memory" ); \
|
||||||
|
} while(0)
|
||||||
|
#endif
|
||||||
|
#ifndef SDL_memcpy
|
||||||
|
#ifdef HAVE_MEMCPY
|
||||||
|
#define SDL_memcpy memcpy
|
||||||
|
#elif defined(HAVE_BCOPY)
|
||||||
|
#define SDL_memcpy(d, s, n) bcopy((s), (d), (n))
|
||||||
|
#else
|
||||||
|
extern DECLSPEC void *SDLCALL SDL_memcpy(void *dst, const void *src,
|
||||||
|
size_t len);
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* We can count on memcpy existing on Mac OS X and being well-tuned. */
|
||||||
|
#if defined(__MACH__) && defined(__APPLE__)
|
||||||
|
#define SDL_memcpy4(dst, src, len) memcpy(dst, src, (len)*4)
|
||||||
|
#elif defined(__GNUC__) && defined(i386)
|
||||||
|
#define SDL_memcpy4(dst, src, len) \
|
||||||
|
do { \
|
||||||
|
int ecx, edi, esi; \
|
||||||
|
__asm__ __volatile__ ( \
|
||||||
|
"cld\n\t" \
|
||||||
|
"rep ; movsl" \
|
||||||
|
: "=&c" (ecx), "=&D" (edi), "=&S" (esi) \
|
||||||
|
: "0" ((unsigned)(len)), "1" (dst), "2" (src) \
|
||||||
|
: "memory" ); \
|
||||||
|
} while(0)
|
||||||
|
#endif
|
||||||
|
#ifndef SDL_memcpy4
|
||||||
|
#define SDL_memcpy4(dst, src, len) SDL_memcpy(dst, src, (len) << 2)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__GNUC__) && defined(i386)
|
||||||
|
#define SDL_revcpy(dst, src, len) \
|
||||||
|
do { \
|
||||||
|
int u0, u1, u2; \
|
||||||
|
char *dstp = (char *)(dst); \
|
||||||
|
char *srcp = (char *)(src); \
|
||||||
|
int n = (len); \
|
||||||
|
if ( n >= 4 ) { \
|
||||||
|
__asm__ __volatile__ ( \
|
||||||
|
"std\n\t" \
|
||||||
|
"rep ; movsl\n\t" \
|
||||||
|
"cld\n\t" \
|
||||||
|
: "=&c" (u0), "=&D" (u1), "=&S" (u2) \
|
||||||
|
: "0" (n >> 2), \
|
||||||
|
"1" (dstp+(n-4)), "2" (srcp+(n-4)) \
|
||||||
|
: "memory" ); \
|
||||||
|
} \
|
||||||
|
switch (n & 3) { \
|
||||||
|
case 3: dstp[2] = srcp[2]; \
|
||||||
|
case 2: dstp[1] = srcp[1]; \
|
||||||
|
case 1: dstp[0] = srcp[0]; \
|
||||||
|
break; \
|
||||||
|
default: \
|
||||||
|
break; \
|
||||||
|
} \
|
||||||
|
} while(0)
|
||||||
|
#endif
|
||||||
|
#ifndef SDL_revcpy
|
||||||
|
extern DECLSPEC void *SDLCALL SDL_revcpy(void *dst, const void *src,
|
||||||
|
size_t len);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_MEMMOVE
|
||||||
|
#define SDL_memmove memmove
|
||||||
|
#elif defined(HAVE_BCOPY)
|
||||||
|
#define SDL_memmove(d, s, n) bcopy((s), (d), (n))
|
||||||
|
#else
|
||||||
|
#define SDL_memmove(dst, src, len) \
|
||||||
|
do { \
|
||||||
|
if ( dst < src ) { \
|
||||||
|
SDL_memcpy(dst, src, len); \
|
||||||
|
} else { \
|
||||||
|
SDL_revcpy(dst, src, len); \
|
||||||
|
} \
|
||||||
|
} while(0)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_MEMCMP
|
||||||
|
#define SDL_memcmp memcmp
|
||||||
|
#else
|
||||||
|
extern DECLSPEC int SDLCALL SDL_memcmp(const void *s1, const void *s2,
|
||||||
|
size_t len);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRLEN
|
||||||
|
#define SDL_strlen strlen
|
||||||
|
#else
|
||||||
|
extern DECLSPEC size_t SDLCALL SDL_strlen(const char *string);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_WCSLEN
|
||||||
|
#define SDL_wcslen wcslen
|
||||||
|
#else
|
||||||
|
#if !defined(wchar_t) && defined(__NINTENDODS__)
|
||||||
|
#define wchar_t short /* TODO: figure out why libnds doesn't have this */
|
||||||
|
#endif
|
||||||
|
extern DECLSPEC size_t SDLCALL SDL_wcslen(const wchar_t * string);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRLCPY
|
||||||
|
#define SDL_strlcpy strlcpy
|
||||||
|
#else
|
||||||
|
extern DECLSPEC size_t SDLCALL SDL_strlcpy(char *dst, const char *src,
|
||||||
|
size_t maxlen);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRLCAT
|
||||||
|
#define SDL_strlcat strlcat
|
||||||
|
#else
|
||||||
|
extern DECLSPEC size_t SDLCALL SDL_strlcat(char *dst, const char *src,
|
||||||
|
size_t maxlen);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRDUP
|
||||||
|
#define SDL_strdup strdup
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_strdup(const char *string);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE__STRREV
|
||||||
|
#define SDL_strrev _strrev
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_strrev(char *string);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE__STRUPR
|
||||||
|
#define SDL_strupr _strupr
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_strupr(char *string);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE__STRLWR
|
||||||
|
#define SDL_strlwr _strlwr
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_strlwr(char *string);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRCHR
|
||||||
|
#define SDL_strchr strchr
|
||||||
|
#elif defined(HAVE_INDEX)
|
||||||
|
#define SDL_strchr index
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_strchr(const char *string, int c);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRRCHR
|
||||||
|
#define SDL_strrchr strrchr
|
||||||
|
#elif defined(HAVE_RINDEX)
|
||||||
|
#define SDL_strrchr rindex
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_strrchr(const char *string, int c);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRSTR
|
||||||
|
#define SDL_strstr strstr
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_strstr(const char *haystack,
|
||||||
|
const char *needle);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_ITOA
|
||||||
|
#define SDL_itoa itoa
|
||||||
|
#else
|
||||||
|
#define SDL_itoa(value, string, radix) SDL_ltoa((long)value, string, radix)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE__LTOA
|
||||||
|
#define SDL_ltoa _ltoa
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_ltoa(long value, char *string, int radix);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE__UITOA
|
||||||
|
#define SDL_uitoa _uitoa
|
||||||
|
#else
|
||||||
|
#define SDL_uitoa(value, string, radix) SDL_ultoa((long)value, string, radix)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE__ULTOA
|
||||||
|
#define SDL_ultoa _ultoa
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_ultoa(unsigned long value, char *string,
|
||||||
|
int radix);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRTOL
|
||||||
|
#define SDL_strtol strtol
|
||||||
|
#else
|
||||||
|
extern DECLSPEC long SDLCALL SDL_strtol(const char *string, char **endp,
|
||||||
|
int base);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRTOUL
|
||||||
|
#define SDL_strtoul strtoul
|
||||||
|
#else
|
||||||
|
extern DECLSPEC unsigned long SDLCALL SDL_strtoul(const char *string,
|
||||||
|
char **endp, int base);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef SDL_HAS_64BIT_TYPE
|
||||||
|
|
||||||
|
#ifdef HAVE__I64TOA
|
||||||
|
#define SDL_lltoa _i64toa
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_lltoa(Sint64 value, char *string,
|
||||||
|
int radix);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE__UI64TOA
|
||||||
|
#define SDL_ulltoa _ui64toa
|
||||||
|
#else
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_ulltoa(Uint64 value, char *string,
|
||||||
|
int radix);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRTOLL
|
||||||
|
#define SDL_strtoll strtoll
|
||||||
|
#else
|
||||||
|
extern DECLSPEC Sint64 SDLCALL SDL_strtoll(const char *string, char **endp,
|
||||||
|
int base);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRTOULL
|
||||||
|
#define SDL_strtoull strtoull
|
||||||
|
#else
|
||||||
|
extern DECLSPEC Uint64 SDLCALL SDL_strtoull(const char *string, char **endp,
|
||||||
|
int base);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* SDL_HAS_64BIT_TYPE */
|
||||||
|
|
||||||
|
#ifdef HAVE_STRTOD
|
||||||
|
#define SDL_strtod strtod
|
||||||
|
#else
|
||||||
|
extern DECLSPEC double SDLCALL SDL_strtod(const char *string, char **endp);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_ATOI
|
||||||
|
#define SDL_atoi atoi
|
||||||
|
#else
|
||||||
|
#define SDL_atoi(X) SDL_strtol(X, NULL, 0)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_ATOF
|
||||||
|
#define SDL_atof atof
|
||||||
|
#else
|
||||||
|
#define SDL_atof(X) SDL_strtod(X, NULL)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRCMP
|
||||||
|
#define SDL_strcmp strcmp
|
||||||
|
#else
|
||||||
|
extern DECLSPEC int SDLCALL SDL_strcmp(const char *str1, const char *str2);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRNCMP
|
||||||
|
#define SDL_strncmp strncmp
|
||||||
|
#else
|
||||||
|
extern DECLSPEC int SDLCALL SDL_strncmp(const char *str1, const char *str2,
|
||||||
|
size_t maxlen);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRCASECMP
|
||||||
|
#define SDL_strcasecmp strcasecmp
|
||||||
|
#elif defined(HAVE__STRICMP)
|
||||||
|
#define SDL_strcasecmp _stricmp
|
||||||
|
#else
|
||||||
|
extern DECLSPEC int SDLCALL SDL_strcasecmp(const char *str1,
|
||||||
|
const char *str2);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_STRNCASECMP
|
||||||
|
#define SDL_strncasecmp strncasecmp
|
||||||
|
#elif defined(HAVE__STRNICMP)
|
||||||
|
#define SDL_strncasecmp _strnicmp
|
||||||
|
#else
|
||||||
|
extern DECLSPEC int SDLCALL SDL_strncasecmp(const char *str1,
|
||||||
|
const char *str2, size_t maxlen);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_SSCANF
|
||||||
|
#define SDL_sscanf sscanf
|
||||||
|
#else
|
||||||
|
extern DECLSPEC int SDLCALL SDL_sscanf(const char *text, const char *fmt,
|
||||||
|
...);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_SNPRINTF
|
||||||
|
#define SDL_snprintf snprintf
|
||||||
|
#else
|
||||||
|
extern DECLSPEC int SDLCALL SDL_snprintf(char *text, size_t maxlen,
|
||||||
|
const char *fmt, ...);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_VSNPRINTF
|
||||||
|
#define SDL_vsnprintf vsnprintf
|
||||||
|
#else
|
||||||
|
extern DECLSPEC int SDLCALL SDL_vsnprintf(char *text, size_t maxlen,
|
||||||
|
const char *fmt, va_list ap);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef HAVE_M_PI
|
||||||
|
#define M_PI 3.14159265358979323846264338327950288 /* pi */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_CEIL
|
||||||
|
#define SDL_ceil ceil
|
||||||
|
#else
|
||||||
|
#define SDL_ceil(x) ((double)(int)((x)+0.5))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_COPYSIGN
|
||||||
|
#define SDL_copysign copysign
|
||||||
|
#else
|
||||||
|
extern DECLSPEC double SDLCALL SDL_copysign(double x, double y);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_COS
|
||||||
|
#define SDL_cos cos
|
||||||
|
#else
|
||||||
|
extern DECLSPEC double SDLCALL SDL_cos(double x);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_COSF
|
||||||
|
#define SDL_cosf cosf
|
||||||
|
#else
|
||||||
|
#define SDL_cosf(x) (float)SDL_cos((double)x)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_FABS
|
||||||
|
#define SDL_fabs fabs
|
||||||
|
#else
|
||||||
|
extern DECLSPEC double SDLCALL SDL_fabs(double x);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_FLOOR
|
||||||
|
#define SDL_floor floor
|
||||||
|
#else
|
||||||
|
extern DECLSPEC double SDLCALL SDL_floor(double x);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_LOG
|
||||||
|
#define SDL_log log
|
||||||
|
#else
|
||||||
|
extern DECLSPEC double SDLCALL SDL_log(double x);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_POW
|
||||||
|
#define SDL_pow pow
|
||||||
|
#else
|
||||||
|
extern DECLSPEC double SDLCALL SDL_pow(double x, double y);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_SCALBN
|
||||||
|
#define SDL_scalbn scalbn
|
||||||
|
#else
|
||||||
|
extern DECLSPEC double SDLCALL SDL_scalbn(double x, int n);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_SIN
|
||||||
|
#define SDL_sin sin
|
||||||
|
#else
|
||||||
|
extern DECLSPEC double SDLCALL SDL_sin(double x);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_SINF
|
||||||
|
#define SDL_sinf sinf
|
||||||
|
#else
|
||||||
|
#define SDL_sinf(x) (float)SDL_sin((double)x)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef HAVE_SQRT
|
||||||
|
#define SDL_sqrt sqrt
|
||||||
|
#else
|
||||||
|
extern DECLSPEC double SDLCALL SDL_sqrt(double x);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The SDL implementation of iconv() returns these error codes */
|
||||||
|
#define SDL_ICONV_ERROR (size_t)-1
|
||||||
|
#define SDL_ICONV_E2BIG (size_t)-2
|
||||||
|
#define SDL_ICONV_EILSEQ (size_t)-3
|
||||||
|
#define SDL_ICONV_EINVAL (size_t)-4
|
||||||
|
|
||||||
|
#ifdef HAVE_ICONV
|
||||||
|
#define SDL_iconv_t iconv_t
|
||||||
|
#define SDL_iconv_open iconv_open
|
||||||
|
#define SDL_iconv_close iconv_close
|
||||||
|
#else
|
||||||
|
typedef struct _SDL_iconv_t *SDL_iconv_t;
|
||||||
|
extern DECLSPEC SDL_iconv_t SDLCALL SDL_iconv_open(const char *tocode,
|
||||||
|
const char *fromcode);
|
||||||
|
extern DECLSPEC int SDLCALL SDL_iconv_close(SDL_iconv_t cd);
|
||||||
|
#endif
|
||||||
|
extern DECLSPEC size_t SDLCALL SDL_iconv(SDL_iconv_t cd, const char **inbuf,
|
||||||
|
size_t * inbytesleft, char **outbuf,
|
||||||
|
size_t * outbytesleft);
|
||||||
|
/* This function converts a string between encodings in one pass, returning a
|
||||||
|
string that must be freed with SDL_free() or NULL on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC char *SDLCALL SDL_iconv_string(const char *tocode,
|
||||||
|
const char *fromcode,
|
||||||
|
const char *inbuf,
|
||||||
|
size_t inbytesleft);
|
||||||
|
#define SDL_iconv_utf8_locale(S) SDL_iconv_string("", "UTF-8", S, SDL_strlen(S)+1)
|
||||||
|
#define SDL_iconv_utf8_ucs2(S) (Uint16 *)SDL_iconv_string("UCS-2", "UTF-8", S, SDL_strlen(S)+1)
|
||||||
|
#define SDL_iconv_utf8_ucs4(S) (Uint32 *)SDL_iconv_string("UCS-4", "UTF-8", S, SDL_strlen(S)+1)
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_stdinc_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,533 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_surface.h
|
||||||
|
*
|
||||||
|
* Header file for SDL_surface definition and management functions
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_surface_h
|
||||||
|
#define _SDL_surface_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_pixels.h"
|
||||||
|
#include "SDL_rect.h"
|
||||||
|
#include "SDL_rwops.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* These are the currently supported flags for the SDL_surface */
|
||||||
|
/* Used internally (read-only) */
|
||||||
|
#define SDL_PREALLOC 0x00000001 /* Surface uses preallocated memory */
|
||||||
|
#define SDL_RLEACCEL 0x00000002 /* Surface is RLE encoded */
|
||||||
|
|
||||||
|
/* Evaluates to true if the surface needs to be locked before access */
|
||||||
|
#define SDL_MUSTLOCK(S) (((S)->flags & SDL_RLEACCEL) != 0)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_Surface
|
||||||
|
*
|
||||||
|
* \brief A collection of pixels used in software blitting
|
||||||
|
*
|
||||||
|
* \note This structure should be treated as read-only, except for 'pixels',
|
||||||
|
* which, if not NULL, contains the raw pixel data for the surface.
|
||||||
|
*/
|
||||||
|
typedef struct SDL_Surface
|
||||||
|
{
|
||||||
|
Uint32 flags; /**< Read-only */
|
||||||
|
SDL_PixelFormat *format; /**< Read-only */
|
||||||
|
int w, h; /**< Read-only */
|
||||||
|
int pitch; /**< Read-only */
|
||||||
|
void *pixels; /**< Read-write */
|
||||||
|
|
||||||
|
/* Application data associated with the surfade */
|
||||||
|
void *userdata; /**< Read-write */
|
||||||
|
|
||||||
|
/* information needed for surfaces requiring locks */
|
||||||
|
int locked; /**< Read-only */
|
||||||
|
void *lock_data; /**< Read-only */
|
||||||
|
|
||||||
|
/* clipping information */
|
||||||
|
SDL_Rect clip_rect; /**< Read-only */
|
||||||
|
|
||||||
|
/* info for fast blit mapping to other surfaces */
|
||||||
|
struct SDL_BlitMap *map; /**< Private */
|
||||||
|
|
||||||
|
/* format version, bumped at every change to invalidate blit maps */
|
||||||
|
unsigned int format_version; /**< Private */
|
||||||
|
|
||||||
|
/* Reference count -- used when freeing surface */
|
||||||
|
int refcount; /**< Read-mostly */
|
||||||
|
} SDL_Surface;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \typedef SDL_blit
|
||||||
|
*
|
||||||
|
* \brief The type of function used for surface blitting functions
|
||||||
|
*/
|
||||||
|
typedef int (*SDL_blit) (struct SDL_Surface * src, SDL_Rect * srcrect,
|
||||||
|
struct SDL_Surface * dst, SDL_Rect * dstrect);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Allocate and free an RGB surface (must be called after SDL_SetVideoMode)
|
||||||
|
* If the depth is 4 or 8 bits, an empty palette is allocated for the surface.
|
||||||
|
* If the depth is greater than 8 bits, the pixel format is set using the
|
||||||
|
* flags '[RGB]mask'.
|
||||||
|
* If the function runs out of memory, it will return NULL.
|
||||||
|
*
|
||||||
|
* The 'flags' are obsolete and should be set to 0.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_Surface *SDLCALL SDL_CreateRGBSurface
|
||||||
|
(Uint32 flags, int width, int height, int depth,
|
||||||
|
Uint32 Rmask, Uint32 Gmask, Uint32 Bmask, Uint32 Amask);
|
||||||
|
extern DECLSPEC SDL_Surface *SDLCALL SDL_CreateRGBSurfaceFrom(void *pixels,
|
||||||
|
int width,
|
||||||
|
int height,
|
||||||
|
int depth,
|
||||||
|
int pitch,
|
||||||
|
Uint32 Rmask,
|
||||||
|
Uint32 Gmask,
|
||||||
|
Uint32 Bmask,
|
||||||
|
Uint32 Amask);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_FreeSurface(SDL_Surface * surface);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_SetSurfacePalette(SDL_Surface *surface, SDL_Palette *palette)
|
||||||
|
*
|
||||||
|
* \brief Set the palette used by a surface.
|
||||||
|
*
|
||||||
|
* \return 0, or -1 if the surface format doesn't use a palette.
|
||||||
|
*
|
||||||
|
* \note A single palette can be shared with many surfaces.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetSurfacePalette(SDL_Surface * surface,
|
||||||
|
SDL_Palette * palette);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* SDL_LockSurface() sets up a surface for directly accessing the pixels.
|
||||||
|
* Between calls to SDL_LockSurface()/SDL_UnlockSurface(), you can write
|
||||||
|
* to and read from 'surface->pixels', using the pixel format stored in
|
||||||
|
* 'surface->format'. Once you are done accessing the surface, you should
|
||||||
|
* use SDL_UnlockSurface() to release it.
|
||||||
|
*
|
||||||
|
* Not all surfaces require locking. If SDL_MUSTLOCK(surface) evaluates
|
||||||
|
* to 0, then you can read and write to the surface at any time, and the
|
||||||
|
* pixel format of the surface will not change.
|
||||||
|
*
|
||||||
|
* No operating system or library calls should be made between lock/unlock
|
||||||
|
* pairs, as critical system locks may be held during this time.
|
||||||
|
*
|
||||||
|
* SDL_LockSurface() returns 0, or -1 if the surface couldn't be locked.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_LockSurface(SDL_Surface * surface);
|
||||||
|
extern DECLSPEC void SDLCALL SDL_UnlockSurface(SDL_Surface * surface);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Load a surface from a seekable SDL data source (memory or file.)
|
||||||
|
* If 'freesrc' is non-zero, the source will be closed after being read.
|
||||||
|
* Returns the new surface, or NULL if there was an error.
|
||||||
|
* The new surface should be freed with SDL_FreeSurface().
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_Surface *SDLCALL SDL_LoadBMP_RW(SDL_RWops * src,
|
||||||
|
int freesrc);
|
||||||
|
|
||||||
|
/* Convenience macro -- load a surface from a file */
|
||||||
|
#define SDL_LoadBMP(file) SDL_LoadBMP_RW(SDL_RWFromFile(file, "rb"), 1)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Save a surface to a seekable SDL data source (memory or file.)
|
||||||
|
* If 'freedst' is non-zero, the source will be closed after being written.
|
||||||
|
* Returns 0 if successful or -1 if there was an error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SaveBMP_RW
|
||||||
|
(SDL_Surface * surface, SDL_RWops * dst, int freedst);
|
||||||
|
|
||||||
|
/* Convenience macro -- save a surface to a file */
|
||||||
|
#define SDL_SaveBMP(surface, file) \
|
||||||
|
SDL_SaveBMP_RW(surface, SDL_RWFromFile(file, "wb"), 1)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* \fn int SDL_SetSurfaceRLE(SDL_Surface *surface, int flag)
|
||||||
|
*
|
||||||
|
* \brief Sets the RLE acceleration hint for a surface.
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if the surface is not valid
|
||||||
|
*
|
||||||
|
* \note If RLE is enabled, colorkey and alpha blending blits are much faster,
|
||||||
|
* but the surface must be locked before directly accessing the pixels.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetSurfaceRLE(SDL_Surface * surface,
|
||||||
|
int flag);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* \fn int SDL_SetColorKey(SDL_Surface *surface, Uint32 flag, Uint32 key)
|
||||||
|
*
|
||||||
|
* \brief Sets the color key (transparent pixel) in a blittable surface.
|
||||||
|
*
|
||||||
|
* \param surface The surface to update
|
||||||
|
* \param flag Non-zero to enable colorkey and 0 to disable colorkey
|
||||||
|
* \param key The transparent pixel in the native surface format
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if the surface is not valid
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetColorKey(SDL_Surface * surface,
|
||||||
|
Uint32 flag, Uint32 key);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_SetSurfaceColorMod(SDL_Surface *surface, Uint8 r, Uint8 g, Uint8 b)
|
||||||
|
*
|
||||||
|
* \brief Set an additional color value used in blit operations
|
||||||
|
*
|
||||||
|
* \param surface The surface to update
|
||||||
|
* \param r The red source color value multiplied into blit operations
|
||||||
|
* \param g The green source color value multiplied into blit operations
|
||||||
|
* \param b The blue source color value multiplied into blit operations
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if the surface is not valid
|
||||||
|
*
|
||||||
|
* \sa SDL_GetSurfaceColorMod()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetSurfaceColorMod(SDL_Surface * surface,
|
||||||
|
Uint8 r, Uint8 g, Uint8 b);
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_GetSurfaceColorMod(SDL_Surface *surface, Uint8 *r, Uint8 *g, Uint8 *b)
|
||||||
|
*
|
||||||
|
* \brief Get the additional color value used in blit operations
|
||||||
|
*
|
||||||
|
* \param surface The surface to query
|
||||||
|
* \param r A pointer filled in with the source red color value
|
||||||
|
* \param g A pointer filled in with the source green color value
|
||||||
|
* \param b A pointer filled in with the source blue color value
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if the surface is not valid
|
||||||
|
*
|
||||||
|
* \sa SDL_SetSurfaceColorMod()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetSurfaceColorMod(SDL_Surface * surface,
|
||||||
|
Uint8 * r, Uint8 * g,
|
||||||
|
Uint8 * b);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_SetSurfaceAlphaMod(SDL_Surface *surface, Uint8 alpha)
|
||||||
|
*
|
||||||
|
* \brief Set an additional alpha value used in blit operations
|
||||||
|
*
|
||||||
|
* \param surface The surface to update
|
||||||
|
* \param alpha The source alpha value multiplied into blit operations.
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if the surface is not valid
|
||||||
|
*
|
||||||
|
* \sa SDL_GetSurfaceAlphaMod()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetSurfaceAlphaMod(SDL_Surface * surface,
|
||||||
|
Uint8 alpha);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_GetSurfaceAlphaMod(SDL_Surface *surface, Uint8 *alpha)
|
||||||
|
*
|
||||||
|
* \brief Get the additional alpha value used in blit operations
|
||||||
|
*
|
||||||
|
* \param surface The surface to query
|
||||||
|
* \param alpha A pointer filled in with the source alpha value
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if the surface is not valid
|
||||||
|
*
|
||||||
|
* \sa SDL_SetSurfaceAlphaMod()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetSurfaceAlphaMod(SDL_Surface * surface,
|
||||||
|
Uint8 * alpha);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_SetSurfaceBlendMode(SDL_Surface *surface, int blendMode)
|
||||||
|
*
|
||||||
|
* \brief Set the blend mode used for blit operations
|
||||||
|
*
|
||||||
|
* \param surface The surface to update
|
||||||
|
* \param blendMode SDL_TextureBlendMode to use for blit blending
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if the parameters are not valid
|
||||||
|
*
|
||||||
|
* \sa SDL_GetSurfaceBlendMode()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetSurfaceBlendMode(SDL_Surface * surface,
|
||||||
|
int blendMode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_GetSurfaceBlendMode(SDL_Surface *surface, int *blendMode)
|
||||||
|
*
|
||||||
|
* \brief Get the blend mode used for blit operations
|
||||||
|
*
|
||||||
|
* \param surface The surface to query
|
||||||
|
* \param blendMode A pointer filled in with the current blend mode
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if the surface is not valid
|
||||||
|
*
|
||||||
|
* \sa SDL_SetSurfaceBlendMode()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetSurfaceBlendMode(SDL_Surface * surface,
|
||||||
|
int *blendMode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_SetSurfaceScaleMode(SDL_Surface *surface, int scaleMode)
|
||||||
|
*
|
||||||
|
* \brief Set the scale mode used for blit operations
|
||||||
|
*
|
||||||
|
* \param surface The surface to update
|
||||||
|
* \param scaleMode SDL_TextureScaleMode to use for blit scaling
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if the surface is not valid or the scale mode is not supported
|
||||||
|
*
|
||||||
|
* \note If the scale mode is not supported, the closest supported mode is chosen. Currently only SDL_TEXTURESCALEMODE_FAST is supported on surfaces.
|
||||||
|
*
|
||||||
|
* \sa SDL_GetSurfaceScaleMode()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetSurfaceScaleMode(SDL_Surface * surface,
|
||||||
|
int scaleMode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_GetSurfaceScaleMode(SDL_Surface *surface, int *scaleMode)
|
||||||
|
*
|
||||||
|
* \brief Get the scale mode used for blit operations
|
||||||
|
*
|
||||||
|
* \param surface The surface to query
|
||||||
|
* \param scaleMode A pointer filled in with the current scale mode
|
||||||
|
*
|
||||||
|
* \return 0 on success, or -1 if the surface is not valid
|
||||||
|
*
|
||||||
|
* \sa SDL_SetSurfaceScaleMode()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetSurfaceScaleMode(SDL_Surface * surface,
|
||||||
|
int *scaleMode);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Sets the clipping rectangle for the destination surface in a blit.
|
||||||
|
*
|
||||||
|
* If the clip rectangle is NULL, clipping will be disabled.
|
||||||
|
* If the clip rectangle doesn't intersect the surface, the function will
|
||||||
|
* return SDL_FALSE and blits will be completely clipped. Otherwise the
|
||||||
|
* function returns SDL_TRUE and blits to the surface will be clipped to
|
||||||
|
* the intersection of the surface area and the clipping rectangle.
|
||||||
|
*
|
||||||
|
* Note that blits are automatically clipped to the edges of the source
|
||||||
|
* and destination surfaces.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_SetClipRect(SDL_Surface * surface,
|
||||||
|
const SDL_Rect * rect);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Gets the clipping rectangle for the destination surface in a blit.
|
||||||
|
* 'rect' must be a pointer to a valid rectangle which will be filled
|
||||||
|
* with the correct values.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_GetClipRect(SDL_Surface * surface,
|
||||||
|
SDL_Rect * rect);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Creates a new surface of the specified format, and then copies and maps
|
||||||
|
* the given surface to it so the blit of the converted surface will be as
|
||||||
|
* fast as possible. If this function fails, it returns NULL.
|
||||||
|
*
|
||||||
|
* The 'flags' parameter is passed to SDL_CreateRGBSurface() and has those
|
||||||
|
* semantics. You can also pass SDL_RLEACCEL in the flags parameter and
|
||||||
|
* SDL will try to RLE accelerate colorkey and alpha blits in the resulting
|
||||||
|
* surface.
|
||||||
|
*
|
||||||
|
* This function is used internally by SDL_DisplayFormat().
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_Surface *SDLCALL SDL_ConvertSurface
|
||||||
|
(SDL_Surface * src, SDL_PixelFormat * fmt, Uint32 flags);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function draws a point with 'color'
|
||||||
|
* The color should be a pixel of the format used by the surface, and
|
||||||
|
* can be generated by the SDL_MapRGB() function.
|
||||||
|
* This function returns 0 on success, or -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_DrawPoint
|
||||||
|
(SDL_Surface * dst, int x, int y, Uint32 color);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function blends a point with an RGBA value
|
||||||
|
* The color should be a pixel of the format used by the surface, and
|
||||||
|
* can be generated by the SDL_MapRGB() function.
|
||||||
|
* This function returns 0 on success, or -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_BlendPoint
|
||||||
|
(SDL_Surface * dst, int x, int y, int blendMode,
|
||||||
|
Uint8 r, Uint8 g, Uint8 b, Uint8 a);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function draws a line with 'color'
|
||||||
|
* The color should be a pixel of the format used by the surface, and
|
||||||
|
* can be generated by the SDL_MapRGB() function.
|
||||||
|
* This function returns 0 on success, or -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_DrawLine
|
||||||
|
(SDL_Surface * dst, int x1, int y1, int x2, int y2, Uint32 color);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function blends an RGBA value along a line
|
||||||
|
* This function returns 0 on success, or -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_BlendLine
|
||||||
|
(SDL_Surface * dst, int x1, int y1, int x2, int y2, int blendMode,
|
||||||
|
Uint8 r, Uint8 g, Uint8 b, Uint8 a);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function performs a fast fill of the given rectangle with 'color'
|
||||||
|
* The given rectangle is clipped to the destination surface clip area
|
||||||
|
* and the final fill rectangle is saved in the passed in pointer.
|
||||||
|
* If 'dstrect' is NULL, the whole surface will be filled with 'color'
|
||||||
|
* The color should be a pixel of the format used by the surface, and
|
||||||
|
* can be generated by the SDL_MapRGB() function.
|
||||||
|
* This function returns 0 on success, or -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_FillRect
|
||||||
|
(SDL_Surface * dst, SDL_Rect * dstrect, Uint32 color);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function blends an RGBA value into the given rectangle.
|
||||||
|
* The given rectangle is clipped to the destination surface clip area
|
||||||
|
* and the final fill rectangle is saved in the passed in pointer.
|
||||||
|
* If 'dstrect' is NULL, the whole surface will be filled with 'color'
|
||||||
|
* This function returns 0 on success, or -1 on error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_BlendRect
|
||||||
|
(SDL_Surface * dst, SDL_Rect * dstrect, int blendMode, Uint8 r, Uint8 g,
|
||||||
|
Uint8 b, Uint8 a);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This performs a fast blit from the source surface to the destination
|
||||||
|
* surface. It assumes that the source and destination rectangles are
|
||||||
|
* the same size. If either 'srcrect' or 'dstrect' are NULL, the entire
|
||||||
|
* surface (src or dst) is copied. The final blit rectangles are saved
|
||||||
|
* in 'srcrect' and 'dstrect' after all clipping is performed.
|
||||||
|
* If the blit is successful, it returns 0, otherwise it returns -1.
|
||||||
|
*
|
||||||
|
* The blit function should not be called on a locked surface.
|
||||||
|
*
|
||||||
|
* The blit semantics for surfaces with and without alpha and colorkey
|
||||||
|
* are defined as follows:
|
||||||
|
*
|
||||||
|
* RGBA->RGB:
|
||||||
|
* SDL_SRCALPHA set:
|
||||||
|
* alpha-blend (using alpha-channel).
|
||||||
|
* SDL_SRCCOLORKEY ignored.
|
||||||
|
* SDL_SRCALPHA not set:
|
||||||
|
* copy RGB.
|
||||||
|
* if SDL_SRCCOLORKEY set, only copy the pixels matching the
|
||||||
|
* RGB values of the source colour key, ignoring alpha in the
|
||||||
|
* comparison.
|
||||||
|
*
|
||||||
|
* RGB->RGBA:
|
||||||
|
* SDL_SRCALPHA set:
|
||||||
|
* alpha-blend (using the source per-surface alpha value);
|
||||||
|
* set destination alpha to opaque.
|
||||||
|
* SDL_SRCALPHA not set:
|
||||||
|
* copy RGB, set destination alpha to source per-surface alpha value.
|
||||||
|
* both:
|
||||||
|
* if SDL_SRCCOLORKEY set, only copy the pixels matching the
|
||||||
|
* source colour key.
|
||||||
|
*
|
||||||
|
* RGBA->RGBA:
|
||||||
|
* SDL_SRCALPHA set:
|
||||||
|
* alpha-blend (using the source alpha channel) the RGB values;
|
||||||
|
* leave destination alpha untouched. [Note: is this correct?]
|
||||||
|
* SDL_SRCCOLORKEY ignored.
|
||||||
|
* SDL_SRCALPHA not set:
|
||||||
|
* copy all of RGBA to the destination.
|
||||||
|
* if SDL_SRCCOLORKEY set, only copy the pixels matching the
|
||||||
|
* RGB values of the source colour key, ignoring alpha in the
|
||||||
|
* comparison.
|
||||||
|
*
|
||||||
|
* RGB->RGB:
|
||||||
|
* SDL_SRCALPHA set:
|
||||||
|
* alpha-blend (using the source per-surface alpha value).
|
||||||
|
* SDL_SRCALPHA not set:
|
||||||
|
* copy RGB.
|
||||||
|
* both:
|
||||||
|
* if SDL_SRCCOLORKEY set, only copy the pixels matching the
|
||||||
|
* source colour key.
|
||||||
|
*
|
||||||
|
* If either of the surfaces were in video memory, and the blit returns -2,
|
||||||
|
* the video memory was lost, so it should be reloaded with artwork and
|
||||||
|
* re-blitted:
|
||||||
|
while ( SDL_BlitSurface(image, imgrect, screen, dstrect) == -2 ) {
|
||||||
|
while ( SDL_LockSurface(image) < 0 )
|
||||||
|
Sleep(10);
|
||||||
|
-- Write image pixels to image->pixels --
|
||||||
|
SDL_UnlockSurface(image);
|
||||||
|
}
|
||||||
|
* This happens under DirectX 5.0 when the system switches away from your
|
||||||
|
* fullscreen application. The lock will also fail until you have access
|
||||||
|
* to the video memory again.
|
||||||
|
*/
|
||||||
|
/* You should call SDL_BlitSurface() unless you know exactly how SDL
|
||||||
|
blitting works internally and how to use the other blit functions.
|
||||||
|
*/
|
||||||
|
#define SDL_BlitSurface SDL_UpperBlit
|
||||||
|
|
||||||
|
/* This is the public blit function, SDL_BlitSurface(), and it performs
|
||||||
|
rectangle validation and clipping before passing it to SDL_LowerBlit()
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_UpperBlit
|
||||||
|
(SDL_Surface * src, SDL_Rect * srcrect,
|
||||||
|
SDL_Surface * dst, SDL_Rect * dstrect);
|
||||||
|
/* This is a semi-private blit function and it performs low-level surface
|
||||||
|
blitting only.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_LowerBlit
|
||||||
|
(SDL_Surface * src, SDL_Rect * srcrect,
|
||||||
|
SDL_Surface * dst, SDL_Rect * dstrect);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_SoftStretch(SDL_Surface * src, const SDL_Rect * srcrect, SDL_Surface * dst, const SDL_Rect * dstrect)
|
||||||
|
*
|
||||||
|
* \brief Perform a fast, low quality, stretch blit between two surfaces of the same pixel format.
|
||||||
|
*
|
||||||
|
* \note This function uses a static buffer, and is not thread-safe.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SoftStretch(SDL_Surface * src,
|
||||||
|
const SDL_Rect * srcrect,
|
||||||
|
SDL_Surface * dst,
|
||||||
|
const SDL_Rect * dstrect);
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_surface_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,244 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_syswm.h
|
||||||
|
*
|
||||||
|
* Include file for SDL custom system window manager hooks
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_syswm_h
|
||||||
|
#define _SDL_syswm_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
#include "SDL_video.h"
|
||||||
|
#include "SDL_version.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#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;
|
||||||
|
#else
|
||||||
|
|
||||||
|
/* This is the structure for custom window manager events */
|
||||||
|
#if defined(SDL_VIDEO_DRIVER_X11)
|
||||||
|
#if defined(__APPLE__) && defined(__MACH__)
|
||||||
|
/* conflicts with Quickdraw.h */
|
||||||
|
#define Cursor X11Cursor
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <X11/Xlib.h>
|
||||||
|
#include <X11/Xatom.h>
|
||||||
|
|
||||||
|
#if defined(__APPLE__) && defined(__MACH__)
|
||||||
|
/* matches the re-define above */
|
||||||
|
#undef Cursor
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* 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.
|
||||||
|
*/
|
||||||
|
struct SDL_SysWMinfo
|
||||||
|
{
|
||||||
|
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
|
||||||
|
any X11 functions using the display variable.
|
||||||
|
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 */
|
||||||
|
} x11;
|
||||||
|
} info;
|
||||||
|
};
|
||||||
|
|
||||||
|
#elif defined(SDL_VIDEO_DRIVER_NANOX)
|
||||||
|
#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 */
|
||||||
|
struct SDL_SysWMinfo
|
||||||
|
{
|
||||||
|
SDL_version version;
|
||||||
|
GR_WINDOW_ID window; /* The display window */
|
||||||
|
};
|
||||||
|
|
||||||
|
#elif defined(SDL_VIDEO_DRIVER_WIN32)
|
||||||
|
#define WIN32_LEAN_AND_MEAN
|
||||||
|
#include <windows.h>
|
||||||
|
|
||||||
|
/* 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 */
|
||||||
|
struct SDL_SysWMinfo
|
||||||
|
{
|
||||||
|
SDL_version version;
|
||||||
|
HWND window; /* The Win32 display window */
|
||||||
|
};
|
||||||
|
|
||||||
|
#elif defined(SDL_VIDEO_DRIVER_RISCOS)
|
||||||
|
|
||||||
|
/* RISC OS custom event structure */
|
||||||
|
struct SDL_SysWMmsg
|
||||||
|
{
|
||||||
|
SDL_version version;
|
||||||
|
int eventCode; /* The window for the message */
|
||||||
|
int pollBlock[64];
|
||||||
|
};
|
||||||
|
|
||||||
|
/* The RISC OS custom window manager information structure */
|
||||||
|
struct SDL_SysWMinfo
|
||||||
|
{
|
||||||
|
SDL_version version;
|
||||||
|
int wimpVersion; /* Wimp version running under */
|
||||||
|
int taskHandle; /* The RISC OS task handle */
|
||||||
|
int window; /* The RISC OS display window */
|
||||||
|
};
|
||||||
|
|
||||||
|
#elif defined(SDL_VIDEO_DRIVER_PHOTON)
|
||||||
|
#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 */
|
||||||
|
struct SDL_SysWMinfo
|
||||||
|
{
|
||||||
|
SDL_version version;
|
||||||
|
int data;
|
||||||
|
};
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
/* The generic custom event structure */
|
||||||
|
struct SDL_SysWMmsg
|
||||||
|
{
|
||||||
|
SDL_version version;
|
||||||
|
int data;
|
||||||
|
};
|
||||||
|
|
||||||
|
/* The generic custom window manager information structure */
|
||||||
|
struct SDL_SysWMinfo
|
||||||
|
{
|
||||||
|
SDL_version version;
|
||||||
|
int data;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif /* video driver type */
|
||||||
|
|
||||||
|
#endif /* SDL_PROTOTYPES_ONLY */
|
||||||
|
|
||||||
|
typedef struct SDL_SysWMinfo SDL_SysWMinfo;
|
||||||
|
|
||||||
|
/* Function prototypes */
|
||||||
|
/**
|
||||||
|
* \fn SDL_bool SDL_GetWindowWMInfo (SDL_WindowID windowID, SDL_SysWMinfo * info)
|
||||||
|
*
|
||||||
|
* \brief This function allows access to driver-dependent window information.
|
||||||
|
*
|
||||||
|
* \param windowID The window about which information is being requested
|
||||||
|
* \param info This structure must be initialized with the SDL version, and is then filled in with information about the given window.
|
||||||
|
*
|
||||||
|
* \return SDL_TRUE if the function is implemented and the version member of the 'info' struct is valid, SDL_FALSE otherwise.
|
||||||
|
*
|
||||||
|
* You typically use this function like this:
|
||||||
|
* \code
|
||||||
|
* SDL_SysWMInfo info;
|
||||||
|
* SDL_VERSION(&info.version);
|
||||||
|
* if ( SDL_GetWindowWMInfo(&info) ) { ... }
|
||||||
|
* \endcode
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_GetWindowWMInfo(SDL_WindowID windowID,
|
||||||
|
SDL_SysWMinfo * info);
|
||||||
|
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_syswm_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,144 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_thread_h
|
||||||
|
#define _SDL_thread_h
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_thread.h
|
||||||
|
*
|
||||||
|
* Header for the SDL thread management routines
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
|
||||||
|
/* Thread synchronization primitives */
|
||||||
|
#include "SDL_mutex.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* The SDL thread structure, defined in SDL_thread.c */
|
||||||
|
struct SDL_Thread;
|
||||||
|
typedef struct SDL_Thread SDL_Thread;
|
||||||
|
|
||||||
|
/* Create a thread */
|
||||||
|
#if (defined(__WIN32__) && !defined(HAVE_LIBC)) || defined(__OS2__)
|
||||||
|
/*
|
||||||
|
We compile SDL into a DLL on OS/2. This means, that it's the DLL which
|
||||||
|
creates a new thread for the calling process with the SDL_CreateThread()
|
||||||
|
API. There is a problem with this, that only the RTL of the SDL.DLL will
|
||||||
|
be initialized for those threads, and not the RTL of the calling application!
|
||||||
|
To solve this, we make a little hack here.
|
||||||
|
We'll always use the caller's _beginthread() and _endthread() APIs to
|
||||||
|
start a new thread. This way, if it's the SDL.DLL which uses this API,
|
||||||
|
then the RTL of SDL.DLL will be used to create the new thread, and if it's
|
||||||
|
the application, then the RTL of the application will be used.
|
||||||
|
So, in short:
|
||||||
|
Always use the _beginthread() and _endthread() of the calling runtime library!
|
||||||
|
*/
|
||||||
|
#define SDL_PASSED_BEGINTHREAD_ENDTHREAD
|
||||||
|
#ifndef _WIN32_WCE
|
||||||
|
#include <process.h> /* This has _beginthread() and _endthread() defined! */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __OS2__
|
||||||
|
typedef int (*pfnSDL_CurrentBeginThread) (void (*func) (void *), void *,
|
||||||
|
unsigned, void *arg);
|
||||||
|
typedef void (*pfnSDL_CurrentEndThread) (void);
|
||||||
|
#elif __GNUC__
|
||||||
|
typedef unsigned long (__cdecl * pfnSDL_CurrentBeginThread) (void *, unsigned,
|
||||||
|
unsigned
|
||||||
|
(__stdcall *
|
||||||
|
func) (void *),
|
||||||
|
void *arg,
|
||||||
|
unsigned,
|
||||||
|
unsigned
|
||||||
|
*threadID);
|
||||||
|
typedef void (__cdecl * pfnSDL_CurrentEndThread) (unsigned code);
|
||||||
|
#else
|
||||||
|
typedef uintptr_t(__cdecl * pfnSDL_CurrentBeginThread) (void *, unsigned,
|
||||||
|
unsigned (__stdcall *
|
||||||
|
func) (void
|
||||||
|
*),
|
||||||
|
void *arg, unsigned,
|
||||||
|
unsigned *threadID);
|
||||||
|
typedef void (__cdecl * pfnSDL_CurrentEndThread) (unsigned code);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern DECLSPEC SDL_Thread *SDLCALL
|
||||||
|
SDL_CreateThread(int (SDLCALL * f) (void *), void *data,
|
||||||
|
pfnSDL_CurrentBeginThread pfnBeginThread,
|
||||||
|
pfnSDL_CurrentEndThread pfnEndThread);
|
||||||
|
|
||||||
|
#ifdef __OS2__
|
||||||
|
#define SDL_CreateThread(fn, data) SDL_CreateThread(fn, data, _beginthread, _endthread)
|
||||||
|
#elif defined(_WIN32_WCE)
|
||||||
|
#define SDL_CreateThread(fn, data) SDL_CreateThread(fn, data, NULL, NULL)
|
||||||
|
#else
|
||||||
|
#define SDL_CreateThread(fn, data) SDL_CreateThread(fn, data, _beginthreadex, _endthreadex)
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
extern DECLSPEC SDL_Thread *SDLCALL
|
||||||
|
SDL_CreateThread(int (SDLCALL * fn) (void *), void *data);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Get the 32-bit thread identifier for the current thread */
|
||||||
|
extern DECLSPEC Uint32 SDLCALL SDL_ThreadID(void);
|
||||||
|
|
||||||
|
/* Get the 32-bit thread identifier for the specified thread,
|
||||||
|
equivalent to SDL_ThreadID() if the specified thread is NULL.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint32 SDLCALL SDL_GetThreadID(SDL_Thread * thread);
|
||||||
|
|
||||||
|
/* Wait for a thread to finish.
|
||||||
|
The return code for the thread function is placed in the area
|
||||||
|
pointed to by 'status', if 'status' is not NULL.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_WaitThread(SDL_Thread * thread, int *status);
|
||||||
|
|
||||||
|
/* This function is here for binary compatibility with legacy apps, but
|
||||||
|
in SDL 1.3 and later, it's a no-op. You cannot forcibly kill a thread
|
||||||
|
in a safe manner on many platforms. You should instead find a way to
|
||||||
|
alert your thread that it is time to terminate, and then have it gracefully
|
||||||
|
exit on its own. Do not ever call this function!
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_KillThread(SDL_Thread * thread);
|
||||||
|
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_thread_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,128 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_timer_h
|
||||||
|
#define _SDL_timer_h
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_timer.h
|
||||||
|
*
|
||||||
|
* Header for the SDL time management routines
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_error.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* This is the OS scheduler timeslice, in milliseconds */
|
||||||
|
#define SDL_TIMESLICE 10
|
||||||
|
|
||||||
|
/* This is the maximum resolution of the SDL timer on all platforms */
|
||||||
|
#define TIMER_RESOLUTION 10 /* Experimentally determined */
|
||||||
|
|
||||||
|
/* Get the number of milliseconds since the SDL library initialization.
|
||||||
|
* Note that this value wraps if the program runs for more than ~49 days.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC Uint32 SDLCALL SDL_GetTicks(void);
|
||||||
|
|
||||||
|
/* Wait a specified number of milliseconds before returning */
|
||||||
|
extern DECLSPEC void SDLCALL SDL_Delay(Uint32 ms);
|
||||||
|
|
||||||
|
/* Function prototype for the timer callback function */
|
||||||
|
typedef Uint32(SDLCALL * SDL_TimerCallback) (Uint32 interval);
|
||||||
|
|
||||||
|
/* Set a callback to run after the specified number of milliseconds has
|
||||||
|
* elapsed. The callback function is passed the current timer interval
|
||||||
|
* and returns the next timer interval. If the returned value is the
|
||||||
|
* same as the one passed in, the periodic alarm continues, otherwise a
|
||||||
|
* new alarm is scheduled. If the callback returns 0, the periodic alarm
|
||||||
|
* is cancelled.
|
||||||
|
*
|
||||||
|
* To cancel a currently running timer, call SDL_SetTimer(0, NULL);
|
||||||
|
*
|
||||||
|
* The timer callback function may run in a different thread than your
|
||||||
|
* main code, and so shouldn't call any functions from within itself.
|
||||||
|
*
|
||||||
|
* The maximum resolution of this timer is 10 ms, which means that if
|
||||||
|
* you request a 16 ms timer, your callback will run approximately 20 ms
|
||||||
|
* later on an unloaded system. If you wanted to set a flag signaling
|
||||||
|
* a frame update at 30 frames per second (every 33 ms), you might set a
|
||||||
|
* timer for 30 ms:
|
||||||
|
* SDL_SetTimer((33/10)*10, flag_update);
|
||||||
|
*
|
||||||
|
* If you use this function, you need to pass SDL_INIT_TIMER to SDL_Init().
|
||||||
|
*
|
||||||
|
* Under UNIX, you should not use raise or use SIGALRM and this function
|
||||||
|
* in the same program, as it is implemented using setitimer(). You also
|
||||||
|
* should not use this function in multi-threaded applications as signals
|
||||||
|
* to multi-threaded apps have undefined behavior in some implementations.
|
||||||
|
*
|
||||||
|
* This function returns 0 if successful, or -1 if there was an error.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_SetTimer(Uint32 interval,
|
||||||
|
SDL_TimerCallback callback);
|
||||||
|
|
||||||
|
/* New timer API, supports multiple timers
|
||||||
|
* Written by Stephane Peter <megastep@lokigames.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Function prototype for the new timer callback function.
|
||||||
|
* The callback function is passed the current timer interval and returns
|
||||||
|
* the next timer interval. If the returned value is the same as the one
|
||||||
|
* passed in, the periodic alarm continues, otherwise a new alarm is
|
||||||
|
* scheduled. If the callback returns 0, the periodic alarm is cancelled.
|
||||||
|
*/
|
||||||
|
typedef Uint32(SDLCALL * SDL_NewTimerCallback) (Uint32 interval, void *param);
|
||||||
|
|
||||||
|
/* Definition of the timer ID type */
|
||||||
|
typedef struct _SDL_TimerID *SDL_TimerID;
|
||||||
|
|
||||||
|
/* Add a new timer to the pool of timers already running.
|
||||||
|
Returns a timer ID, or NULL when an error occurs.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_TimerID SDLCALL SDL_AddTimer(Uint32 interval,
|
||||||
|
SDL_NewTimerCallback
|
||||||
|
callback, void *param);
|
||||||
|
|
||||||
|
/* Remove one of the multiple timers knowing its ID.
|
||||||
|
* Returns a boolean value indicating success.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC SDL_bool SDLCALL SDL_RemoveTimer(SDL_TimerID t);
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_timer_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
|
@ -0,0 +1,24 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* DEPRECATED */
|
||||||
|
#include "SDL_stdinc.h"
|
|
@ -0,0 +1,151 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Lesser General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2.1 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \file SDL_version.h
|
||||||
|
*
|
||||||
|
* This header defines the current SDL version
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SDL_version_h
|
||||||
|
#define _SDL_version_h
|
||||||
|
|
||||||
|
#include "SDL_stdinc.h"
|
||||||
|
#include "SDL_revision.h"
|
||||||
|
|
||||||
|
#include "begin_code.h"
|
||||||
|
/* Set up for C function definitions, even when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
extern "C" {
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \struct SDL_version
|
||||||
|
* \brief Information the version of SDL in use.
|
||||||
|
*
|
||||||
|
* Represents the library's version as three levels: major revision
|
||||||
|
* (increments with massive changes, additions, and enhancements),
|
||||||
|
* minor revision (increments with backwards-compatible changes to the
|
||||||
|
* major revision), and patchlevel (increments with fixes to the minor
|
||||||
|
* revision).
|
||||||
|
*
|
||||||
|
* \sa SDL_VERSION
|
||||||
|
* \sa SDL_GetVersion
|
||||||
|
*/
|
||||||
|
typedef struct SDL_version
|
||||||
|
{
|
||||||
|
Uint8 major; /**< major version */
|
||||||
|
Uint8 minor; /**< minor version */
|
||||||
|
Uint8 patch; /**< update version */
|
||||||
|
} SDL_version;
|
||||||
|
|
||||||
|
/* Printable format: "%d.%d.%d", MAJOR, MINOR, PATCHLEVEL
|
||||||
|
*/
|
||||||
|
#define SDL_MAJOR_VERSION 1
|
||||||
|
#define SDL_MINOR_VERSION 3
|
||||||
|
#define SDL_PATCHLEVEL 0
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \def SDL_VERSION(x)
|
||||||
|
* \brief Macro to determine SDL version program was compiled against.
|
||||||
|
*
|
||||||
|
* This macro fills in a SDL_version structure with the version of the
|
||||||
|
* library you compiled against. This is determined by what header the
|
||||||
|
* compiler uses. Note that if you dynamically linked the library, you might
|
||||||
|
* have a slightly newer or older version at runtime. That version can be
|
||||||
|
* determined with SDL_GetVersion(), which, unlike SDL_VERSION,
|
||||||
|
* is not a macro.
|
||||||
|
*
|
||||||
|
* \param x A pointer to a SDL_version struct to initialize.
|
||||||
|
*
|
||||||
|
* \sa SDL_version
|
||||||
|
* \sa SDL_GetVersion
|
||||||
|
*/
|
||||||
|
#define SDL_VERSION(x) \
|
||||||
|
{ \
|
||||||
|
(x)->major = SDL_MAJOR_VERSION; \
|
||||||
|
(x)->minor = SDL_MINOR_VERSION; \
|
||||||
|
(x)->patch = SDL_PATCHLEVEL; \
|
||||||
|
}
|
||||||
|
|
||||||
|
/* This macro turns the version numbers into a numeric value:
|
||||||
|
(1,2,3) -> (1203)
|
||||||
|
This assumes that there will never be more than 100 patchlevels
|
||||||
|
*/
|
||||||
|
#define SDL_VERSIONNUM(X, Y, Z) \
|
||||||
|
((X)*1000 + (Y)*100 + (Z))
|
||||||
|
|
||||||
|
/* This is the version number macro for the current SDL version */
|
||||||
|
#define SDL_COMPILEDVERSION \
|
||||||
|
SDL_VERSIONNUM(SDL_MAJOR_VERSION, SDL_MINOR_VERSION, SDL_PATCHLEVEL)
|
||||||
|
|
||||||
|
/* This macro will evaluate to true if compiled with SDL at least X.Y.Z */
|
||||||
|
#define SDL_VERSION_ATLEAST(X, Y, Z) \
|
||||||
|
(SDL_COMPILEDVERSION >= SDL_VERSIONNUM(X, Y, Z))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn void SDL_GetVersion(SDL_version *ver)
|
||||||
|
* \brief Get the version of SDL that is linked against your program.
|
||||||
|
*
|
||||||
|
* If you are using a shared library (DLL) version of SDL, then it is
|
||||||
|
* possible that it will be different than the version you compiled against.
|
||||||
|
*
|
||||||
|
* This is a real function; the macro SDL_VERSION tells you what version
|
||||||
|
* of SDL you compiled against:
|
||||||
|
*
|
||||||
|
* \code
|
||||||
|
* SDL_version compiled;
|
||||||
|
* SDL_version linked;
|
||||||
|
*
|
||||||
|
* SDL_VERSION(&compiled);
|
||||||
|
* SDL_GetVersion(&linked);
|
||||||
|
* printf("We compiled against SDL version %d.%d.%d ...\n",
|
||||||
|
* compiled.major, compiled.minor, compiled.patch);
|
||||||
|
* printf("But we linked against SDL version %d.%d.%d.\n",
|
||||||
|
* linked.major, linked.minor, linked.patch);
|
||||||
|
* \endcode
|
||||||
|
*
|
||||||
|
* This function may be called safely at any time, even before SDL_Init().
|
||||||
|
*
|
||||||
|
* \sa SDL_VERSION
|
||||||
|
*/
|
||||||
|
extern DECLSPEC void SDLCALL SDL_GetVersion(SDL_version * ver);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \fn int SDL_GetRevision(void)
|
||||||
|
* \brief Get the code revision of SDL that is linked against your program.
|
||||||
|
*/
|
||||||
|
extern DECLSPEC int SDLCALL SDL_GetRevision(void);
|
||||||
|
|
||||||
|
/* Ends C function definitions when using C++ */
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
#endif
|
||||||
|
#include "close_code.h"
|
||||||
|
|
||||||
|
#endif /* _SDL_version_h */
|
||||||
|
|
||||||
|
/* vi: set ts=4 sw=4 expandtab: */
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,149 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Library General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public
|
||||||
|
License along with this library; if not, write to the Free
|
||||||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This file sets things up for C dynamic library function definitions,
|
||||||
|
static inlined functions, and structures aligned at 4-byte alignment.
|
||||||
|
If you don't like ugly C preprocessor code, don't look at this file. :)
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This shouldn't be nested -- included it around code only. */
|
||||||
|
#ifdef _begin_code_h
|
||||||
|
#error Nested inclusion of begin_code.h
|
||||||
|
#endif
|
||||||
|
#define _begin_code_h
|
||||||
|
|
||||||
|
/* Some compilers use a special export keyword */
|
||||||
|
#ifndef DECLSPEC
|
||||||
|
# if defined(__BEOS__)
|
||||||
|
# if defined(__GNUC__)
|
||||||
|
# define DECLSPEC __declspec(dllexport)
|
||||||
|
# else
|
||||||
|
# define DECLSPEC __declspec(export)
|
||||||
|
# endif
|
||||||
|
# elif defined(__WIN32__)
|
||||||
|
# ifdef __BORLANDC__
|
||||||
|
# ifdef BUILD_SDL
|
||||||
|
# define DECLSPEC
|
||||||
|
# else
|
||||||
|
# define DECLSPEC __declspec(dllimport)
|
||||||
|
# endif
|
||||||
|
# else
|
||||||
|
# define DECLSPEC __declspec(dllexport)
|
||||||
|
# endif
|
||||||
|
# elif defined(__OS2__)
|
||||||
|
# ifdef __WATCOMC__
|
||||||
|
# ifdef BUILD_SDL
|
||||||
|
# define DECLSPEC __declspec(dllexport)
|
||||||
|
# else
|
||||||
|
# define DECLSPEC
|
||||||
|
# endif
|
||||||
|
# else
|
||||||
|
# define DECLSPEC
|
||||||
|
# endif
|
||||||
|
# else
|
||||||
|
# if defined(__GNUC__) && __GNUC__ >= 4
|
||||||
|
# define DECLSPEC __attribute__ ((visibility("default")))
|
||||||
|
# else
|
||||||
|
# define DECLSPEC
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* By default SDL uses the C calling convention */
|
||||||
|
#ifndef SDLCALL
|
||||||
|
#if defined(__WIN32__) && !defined(__GNUC__)
|
||||||
|
#define SDLCALL __cdecl
|
||||||
|
#else
|
||||||
|
#ifdef __OS2__
|
||||||
|
/* But on OS/2, we use the _System calling convention */
|
||||||
|
/* to be compatible with every compiler */
|
||||||
|
#define SDLCALL _System
|
||||||
|
#else
|
||||||
|
#define SDLCALL
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif /* SDLCALL */
|
||||||
|
|
||||||
|
/* Removed DECLSPEC on Symbian OS because SDL cannot be a DLL in EPOC */
|
||||||
|
#ifdef __SYMBIAN32__
|
||||||
|
#undef DECLSPEC
|
||||||
|
#define DECLSPEC
|
||||||
|
#endif /* __SYMBIAN32__ */
|
||||||
|
|
||||||
|
/* Force structure packing at 4 byte alignment.
|
||||||
|
This is necessary if the header is included in code which has structure
|
||||||
|
packing set to an alternate value, say for loading structures from disk.
|
||||||
|
The packing is reset to the previous value in close_code.h
|
||||||
|
*/
|
||||||
|
#if defined(_MSC_VER) || defined(__MWERKS__) || defined(__BORLANDC__)
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#pragma warning(disable: 4103)
|
||||||
|
#endif
|
||||||
|
#ifdef __BORLANDC__
|
||||||
|
#pragma nopackwarning
|
||||||
|
#endif
|
||||||
|
#pragma pack(push,4)
|
||||||
|
#endif /* Compiler needs structure packing set */
|
||||||
|
|
||||||
|
/* Set up compiler-specific options for inlining functions */
|
||||||
|
#ifndef SDL_INLINE_OKAY
|
||||||
|
#ifdef __GNUC__
|
||||||
|
#define SDL_INLINE_OKAY
|
||||||
|
#else
|
||||||
|
/* Add any special compiler-specific cases here */
|
||||||
|
#if defined(_MSC_VER) || defined(__BORLANDC__) || \
|
||||||
|
defined(__DMC__) || defined(__SC__) || \
|
||||||
|
defined(__WATCOMC__) || defined(__LCC__) || \
|
||||||
|
defined(__DECC)
|
||||||
|
#ifndef __inline__
|
||||||
|
#define __inline__ __inline
|
||||||
|
#endif
|
||||||
|
#define SDL_INLINE_OKAY
|
||||||
|
#else
|
||||||
|
#if !defined(__MRC__) && !defined(_SGI_SOURCE)
|
||||||
|
#ifndef __inline__
|
||||||
|
#define __inline__ inline
|
||||||
|
#endif
|
||||||
|
#define SDL_INLINE_OKAY
|
||||||
|
#endif /* Not a funky compiler */
|
||||||
|
#endif /* Visual C++ */
|
||||||
|
#endif /* GNU C */
|
||||||
|
#endif /* SDL_INLINE_OKAY */
|
||||||
|
|
||||||
|
/* If inlining isn't supported, remove "__inline__", turning static
|
||||||
|
inlined functions into static functions (resulting in code bloat
|
||||||
|
in all files which include the offending header files)
|
||||||
|
*/
|
||||||
|
#ifndef SDL_INLINE_OKAY
|
||||||
|
#define __inline__
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Apparently this is needed by several Windows compilers */
|
||||||
|
#if !defined(__MACH__)
|
||||||
|
#ifndef NULL
|
||||||
|
#ifdef __cplusplus
|
||||||
|
#define NULL 0
|
||||||
|
#else
|
||||||
|
#define NULL ((void *)0)
|
||||||
|
#endif
|
||||||
|
#endif /* NULL */
|
||||||
|
#endif /* ! Mac OS X - breaks precompiled headers */
|
|
@ -0,0 +1,35 @@
|
||||||
|
/*
|
||||||
|
SDL - Simple DirectMedia Layer
|
||||||
|
Copyright (C) 1997-2009 Sam Lantinga
|
||||||
|
|
||||||
|
This library is free software; you can redistribute it and/or
|
||||||
|
modify it under the terms of the GNU Library General Public
|
||||||
|
License as published by the Free Software Foundation; either
|
||||||
|
version 2 of the License, or (at your option) any later version.
|
||||||
|
|
||||||
|
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
|
||||||
|
Library General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Library General Public
|
||||||
|
License along with this library; if not, write to the Free
|
||||||
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
|
Sam Lantinga
|
||||||
|
slouken@libsdl.org
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* This file reverses the effects of begin_code.h and should be included
|
||||||
|
after you finish any function and structure declarations in your headers
|
||||||
|
*/
|
||||||
|
|
||||||
|
#undef _begin_code_h
|
||||||
|
|
||||||
|
/* Reset structure packing at previous byte alignment */
|
||||||
|
#if defined(_MSC_VER) || defined(__MWERKS__) || defined(__WATCOMC__) || defined(__BORLANDC__)
|
||||||
|
#ifdef __BORLANDC__
|
||||||
|
#pragma nopackwarning
|
||||||
|
#endif
|
||||||
|
#pragma pack(pop)
|
||||||
|
#endif /* Compiler needs structure packing set */
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue