2020-11-16 14:47:43 +08:00
|
|
|
#ifndef AL_ALC_H
|
|
|
|
#define AL_ALC_H
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
#ifdef __cplusplus
|
2020-11-16 14:47:43 +08:00
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifndef ALC_API
|
|
|
|
#if defined(AL_LIBTYPE_STATIC)
|
|
|
|
#define ALC_API
|
|
|
|
#elif defined(_WIN32)
|
|
|
|
#define ALC_API __declspec(dllimport)
|
|
|
|
#else
|
|
|
|
#define ALC_API extern
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
#ifdef _WIN32
|
2020-11-16 14:47:43 +08:00
|
|
|
#define ALC_APIENTRY __cdecl
|
|
|
|
#else
|
|
|
|
#define ALC_APIENTRY
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/* Deprecated macros. */
|
|
|
|
#define ALCAPI ALC_API
|
|
|
|
#define ALCAPIENTRY ALC_APIENTRY
|
|
|
|
#define ALC_INVALID 0
|
|
|
|
|
|
|
|
/** Supported ALC version? */
|
|
|
|
#define ALC_VERSION_0_1 1
|
|
|
|
|
|
|
|
/** Opaque device handle */
|
|
|
|
typedef struct ALCdevice ALCdevice;
|
|
|
|
/** Opaque context handle */
|
|
|
|
typedef struct ALCcontext ALCcontext;
|
|
|
|
|
|
|
|
/** 8-bit boolean */
|
|
|
|
typedef char ALCboolean;
|
|
|
|
|
|
|
|
/** character */
|
|
|
|
typedef char ALCchar;
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/** signed 8-bit integer */
|
2020-11-16 14:47:43 +08:00
|
|
|
typedef signed char ALCbyte;
|
|
|
|
|
|
|
|
/** unsigned 8-bit integer */
|
|
|
|
typedef unsigned char ALCubyte;
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/** signed 16-bit integer */
|
2020-11-16 14:47:43 +08:00
|
|
|
typedef short ALCshort;
|
|
|
|
|
|
|
|
/** unsigned 16-bit integer */
|
|
|
|
typedef unsigned short ALCushort;
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/** signed 32-bit integer */
|
2020-11-16 14:47:43 +08:00
|
|
|
typedef int ALCint;
|
|
|
|
|
|
|
|
/** unsigned 32-bit integer */
|
|
|
|
typedef unsigned int ALCuint;
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/** non-negative 32-bit integer size */
|
2020-11-16 14:47:43 +08:00
|
|
|
typedef int ALCsizei;
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/** 32-bit enumeration value */
|
2020-11-16 14:47:43 +08:00
|
|
|
typedef int ALCenum;
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/** 32-bit IEEE-754 floating-point */
|
2020-11-16 14:47:43 +08:00
|
|
|
typedef float ALCfloat;
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/** 64-bit IEEE-754 floating-point */
|
2020-11-16 14:47:43 +08:00
|
|
|
typedef double ALCdouble;
|
|
|
|
|
|
|
|
/** void type (for opaque pointers only) */
|
|
|
|
typedef void ALCvoid;
|
|
|
|
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/* Enumeration values begin at column 50. Do not use tabs. */
|
2020-11-16 14:47:43 +08:00
|
|
|
|
|
|
|
/** Boolean False. */
|
|
|
|
#define ALC_FALSE 0
|
|
|
|
|
|
|
|
/** Boolean True. */
|
|
|
|
#define ALC_TRUE 1
|
|
|
|
|
|
|
|
/** Context attribute: <int> Hz. */
|
|
|
|
#define ALC_FREQUENCY 0x1007
|
|
|
|
|
|
|
|
/** Context attribute: <int> Hz. */
|
|
|
|
#define ALC_REFRESH 0x1008
|
|
|
|
|
|
|
|
/** Context attribute: AL_TRUE or AL_FALSE synchronous context? */
|
|
|
|
#define ALC_SYNC 0x1009
|
|
|
|
|
|
|
|
/** Context attribute: <int> requested Mono (3D) Sources. */
|
|
|
|
#define ALC_MONO_SOURCES 0x1010
|
|
|
|
|
|
|
|
/** Context attribute: <int> requested Stereo Sources. */
|
|
|
|
#define ALC_STEREO_SOURCES 0x1011
|
|
|
|
|
|
|
|
/** No error. */
|
|
|
|
#define ALC_NO_ERROR 0
|
|
|
|
|
|
|
|
/** Invalid device handle. */
|
|
|
|
#define ALC_INVALID_DEVICE 0xA001
|
|
|
|
|
|
|
|
/** Invalid context handle. */
|
|
|
|
#define ALC_INVALID_CONTEXT 0xA002
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/** Invalid enumeration passed to an ALC call. */
|
2020-11-16 14:47:43 +08:00
|
|
|
#define ALC_INVALID_ENUM 0xA003
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/** Invalid value passed to an ALC call. */
|
2020-11-16 14:47:43 +08:00
|
|
|
#define ALC_INVALID_VALUE 0xA004
|
|
|
|
|
|
|
|
/** Out of memory. */
|
|
|
|
#define ALC_OUT_OF_MEMORY 0xA005
|
|
|
|
|
|
|
|
|
|
|
|
/** Runtime ALC major version. */
|
|
|
|
#define ALC_MAJOR_VERSION 0x1000
|
|
|
|
/** Runtime ALC minor version. */
|
|
|
|
#define ALC_MINOR_VERSION 0x1001
|
|
|
|
|
|
|
|
/** Context attribute list size. */
|
|
|
|
#define ALC_ATTRIBUTES_SIZE 0x1002
|
|
|
|
/** Context attribute list properties. */
|
|
|
|
#define ALC_ALL_ATTRIBUTES 0x1003
|
|
|
|
|
|
|
|
/** String for the default device specifier. */
|
|
|
|
#define ALC_DEFAULT_DEVICE_SPECIFIER 0x1004
|
|
|
|
/**
|
2023-02-04 15:03:54 +08:00
|
|
|
* Device specifier string.
|
2020-11-16 14:47:43 +08:00
|
|
|
*
|
2023-02-04 15:03:54 +08:00
|
|
|
* If device handle is NULL, it is instead a null-character separated list of
|
2020-11-16 14:47:43 +08:00
|
|
|
* strings of known device specifiers (list ends with an empty string).
|
|
|
|
*/
|
|
|
|
#define ALC_DEVICE_SPECIFIER 0x1005
|
|
|
|
/** String for space-separated list of ALC extensions. */
|
|
|
|
#define ALC_EXTENSIONS 0x1006
|
|
|
|
|
|
|
|
|
|
|
|
/** Capture extension */
|
|
|
|
#define ALC_EXT_CAPTURE 1
|
|
|
|
/**
|
2023-02-04 15:03:54 +08:00
|
|
|
* Capture device specifier string.
|
2020-11-16 14:47:43 +08:00
|
|
|
*
|
2023-02-04 15:03:54 +08:00
|
|
|
* If device handle is NULL, it is instead a null-character separated list of
|
2020-11-16 14:47:43 +08:00
|
|
|
* strings of known capture device specifiers (list ends with an empty string).
|
|
|
|
*/
|
|
|
|
#define ALC_CAPTURE_DEVICE_SPECIFIER 0x310
|
|
|
|
/** String for the default capture device specifier. */
|
|
|
|
#define ALC_CAPTURE_DEFAULT_DEVICE_SPECIFIER 0x311
|
|
|
|
/** Number of sample frames available for capture. */
|
|
|
|
#define ALC_CAPTURE_SAMPLES 0x312
|
|
|
|
|
|
|
|
|
|
|
|
/** Enumerate All extension */
|
|
|
|
#define ALC_ENUMERATE_ALL_EXT 1
|
|
|
|
/** String for the default extended device specifier. */
|
|
|
|
#define ALC_DEFAULT_ALL_DEVICES_SPECIFIER 0x1012
|
|
|
|
/**
|
2023-02-04 15:03:54 +08:00
|
|
|
* Device's extended specifier string.
|
2020-11-16 14:47:43 +08:00
|
|
|
*
|
2023-02-04 15:03:54 +08:00
|
|
|
* If device handle is NULL, it is instead a null-character separated list of
|
2020-11-16 14:47:43 +08:00
|
|
|
* strings of known extended device specifiers (list ends with an empty string).
|
|
|
|
*/
|
|
|
|
#define ALC_ALL_DEVICES_SPECIFIER 0x1013
|
|
|
|
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
#ifndef ALC_NO_PROTOTYPES
|
2020-11-16 14:47:43 +08:00
|
|
|
/* Context management. */
|
|
|
|
|
|
|
|
/** Create and attach a context to the given device. */
|
|
|
|
ALC_API ALCcontext* ALC_APIENTRY alcCreateContext(ALCdevice *device, const ALCint *attrlist);
|
|
|
|
/**
|
|
|
|
* Makes the given context the active process-wide context. Passing NULL clears
|
|
|
|
* the active context.
|
|
|
|
*/
|
|
|
|
ALC_API ALCboolean ALC_APIENTRY alcMakeContextCurrent(ALCcontext *context);
|
|
|
|
/** Resumes processing updates for the given context. */
|
|
|
|
ALC_API void ALC_APIENTRY alcProcessContext(ALCcontext *context);
|
|
|
|
/** Suspends updates for the given context. */
|
|
|
|
ALC_API void ALC_APIENTRY alcSuspendContext(ALCcontext *context);
|
|
|
|
/** Remove a context from its device and destroys it. */
|
|
|
|
ALC_API void ALC_APIENTRY alcDestroyContext(ALCcontext *context);
|
|
|
|
/** Returns the currently active context. */
|
|
|
|
ALC_API ALCcontext* ALC_APIENTRY alcGetCurrentContext(void);
|
|
|
|
/** Returns the device that a particular context is attached to. */
|
|
|
|
ALC_API ALCdevice* ALC_APIENTRY alcGetContextsDevice(ALCcontext *context);
|
|
|
|
|
|
|
|
/* Device management. */
|
|
|
|
|
|
|
|
/** Opens the named playback device. */
|
|
|
|
ALC_API ALCdevice* ALC_APIENTRY alcOpenDevice(const ALCchar *devicename);
|
|
|
|
/** Closes the given playback device. */
|
|
|
|
ALC_API ALCboolean ALC_APIENTRY alcCloseDevice(ALCdevice *device);
|
|
|
|
|
|
|
|
/* Error support. */
|
|
|
|
|
|
|
|
/** Obtain the most recent Device error. */
|
|
|
|
ALC_API ALCenum ALC_APIENTRY alcGetError(ALCdevice *device);
|
|
|
|
|
|
|
|
/* Extension support. */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Query for the presence of an extension on the device. Pass a NULL device to
|
|
|
|
* query a device-inspecific extension.
|
|
|
|
*/
|
|
|
|
ALC_API ALCboolean ALC_APIENTRY alcIsExtensionPresent(ALCdevice *device, const ALCchar *extname);
|
|
|
|
/**
|
|
|
|
* Retrieve the address of a function. Given a non-NULL device, the returned
|
|
|
|
* function may be device-specific.
|
|
|
|
*/
|
|
|
|
ALC_API ALCvoid* ALC_APIENTRY alcGetProcAddress(ALCdevice *device, const ALCchar *funcname);
|
|
|
|
/**
|
|
|
|
* Retrieve the value of an enum. Given a non-NULL device, the returned value
|
|
|
|
* may be device-specific.
|
|
|
|
*/
|
|
|
|
ALC_API ALCenum ALC_APIENTRY alcGetEnumValue(ALCdevice *device, const ALCchar *enumname);
|
|
|
|
|
|
|
|
/* Query functions. */
|
|
|
|
|
|
|
|
/** Returns information about the device, and error strings. */
|
|
|
|
ALC_API const ALCchar* ALC_APIENTRY alcGetString(ALCdevice *device, ALCenum param);
|
|
|
|
/** Returns information about the device and the version of OpenAL. */
|
|
|
|
ALC_API void ALC_APIENTRY alcGetIntegerv(ALCdevice *device, ALCenum param, ALCsizei size, ALCint *values);
|
|
|
|
|
|
|
|
/* Capture functions. */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Opens the named capture device with the given frequency, format, and buffer
|
|
|
|
* size.
|
|
|
|
*/
|
|
|
|
ALC_API ALCdevice* ALC_APIENTRY alcCaptureOpenDevice(const ALCchar *devicename, ALCuint frequency, ALCenum format, ALCsizei buffersize);
|
|
|
|
/** Closes the given capture device. */
|
|
|
|
ALC_API ALCboolean ALC_APIENTRY alcCaptureCloseDevice(ALCdevice *device);
|
2023-02-04 15:03:54 +08:00
|
|
|
/** Starts capturing samples into the device buffer. */
|
2020-11-16 14:47:43 +08:00
|
|
|
ALC_API void ALC_APIENTRY alcCaptureStart(ALCdevice *device);
|
|
|
|
/** Stops capturing samples. Samples in the device buffer remain available. */
|
|
|
|
ALC_API void ALC_APIENTRY alcCaptureStop(ALCdevice *device);
|
|
|
|
/** Reads samples from the device buffer. */
|
|
|
|
ALC_API void ALC_APIENTRY alcCaptureSamples(ALCdevice *device, ALCvoid *buffer, ALCsizei samples);
|
2023-02-04 15:03:54 +08:00
|
|
|
#endif /* ALC_NO_PROTOTYPES */
|
2020-11-16 14:47:43 +08:00
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
/* Pointer-to-function types, useful for storing dynamically loaded ALC entry
|
|
|
|
* points.
|
|
|
|
*/
|
2020-11-16 14:47:43 +08:00
|
|
|
typedef ALCcontext* (ALC_APIENTRY *LPALCCREATECONTEXT)(ALCdevice *device, const ALCint *attrlist);
|
|
|
|
typedef ALCboolean (ALC_APIENTRY *LPALCMAKECONTEXTCURRENT)(ALCcontext *context);
|
|
|
|
typedef void (ALC_APIENTRY *LPALCPROCESSCONTEXT)(ALCcontext *context);
|
|
|
|
typedef void (ALC_APIENTRY *LPALCSUSPENDCONTEXT)(ALCcontext *context);
|
|
|
|
typedef void (ALC_APIENTRY *LPALCDESTROYCONTEXT)(ALCcontext *context);
|
|
|
|
typedef ALCcontext* (ALC_APIENTRY *LPALCGETCURRENTCONTEXT)(void);
|
|
|
|
typedef ALCdevice* (ALC_APIENTRY *LPALCGETCONTEXTSDEVICE)(ALCcontext *context);
|
|
|
|
typedef ALCdevice* (ALC_APIENTRY *LPALCOPENDEVICE)(const ALCchar *devicename);
|
|
|
|
typedef ALCboolean (ALC_APIENTRY *LPALCCLOSEDEVICE)(ALCdevice *device);
|
|
|
|
typedef ALCenum (ALC_APIENTRY *LPALCGETERROR)(ALCdevice *device);
|
|
|
|
typedef ALCboolean (ALC_APIENTRY *LPALCISEXTENSIONPRESENT)(ALCdevice *device, const ALCchar *extname);
|
|
|
|
typedef ALCvoid* (ALC_APIENTRY *LPALCGETPROCADDRESS)(ALCdevice *device, const ALCchar *funcname);
|
|
|
|
typedef ALCenum (ALC_APIENTRY *LPALCGETENUMVALUE)(ALCdevice *device, const ALCchar *enumname);
|
|
|
|
typedef const ALCchar* (ALC_APIENTRY *LPALCGETSTRING)(ALCdevice *device, ALCenum param);
|
|
|
|
typedef void (ALC_APIENTRY *LPALCGETINTEGERV)(ALCdevice *device, ALCenum param, ALCsizei size, ALCint *values);
|
|
|
|
typedef ALCdevice* (ALC_APIENTRY *LPALCCAPTUREOPENDEVICE)(const ALCchar *devicename, ALCuint frequency, ALCenum format, ALCsizei buffersize);
|
|
|
|
typedef ALCboolean (ALC_APIENTRY *LPALCCAPTURECLOSEDEVICE)(ALCdevice *device);
|
|
|
|
typedef void (ALC_APIENTRY *LPALCCAPTURESTART)(ALCdevice *device);
|
|
|
|
typedef void (ALC_APIENTRY *LPALCCAPTURESTOP)(ALCdevice *device);
|
|
|
|
typedef void (ALC_APIENTRY *LPALCCAPTURESAMPLES)(ALCdevice *device, ALCvoid *buffer, ALCsizei samples);
|
|
|
|
|
2023-02-04 15:03:54 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* extern "C" */
|
2020-11-16 14:47:43 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* AL_ALC_H */
|