4 #if defined(__cplusplus)
9 #if defined(AL_LIBTYPE_STATIC)
12 #define AL_API __declspec(dllimport)
19 #define AL_APIENTRY __cdecl
24 #if defined(TARGET_OS_MAC) && TARGET_OS_MAC
29 * The OPENAL, ALAPI, ALAPIENTRY, AL_INVALID, AL_ILLEGAL_ENUM, and
30 * AL_ILLEGAL_COMMAND macros are deprecated, but are included for
31 * applications porting code from AL 1.0
35 #define ALAPIENTRY AL_APIENTRY
36 #define AL_INVALID (-1)
37 #define AL_ILLEGAL_ENUM AL_INVALID_ENUM
38 #define AL_ILLEGAL_COMMAND AL_INVALID_OPERATION
40 #define AL_VERSION_1_0
41 #define AL_VERSION_1_1
45 typedef char ALboolean
;
50 /** signed 8-bit 2's complement integer */
51 typedef signed char ALbyte
;
53 /** unsigned 8-bit integer */
54 typedef unsigned char ALubyte
;
56 /** signed 16-bit 2's complement integer */
57 typedef short ALshort
;
59 /** unsigned 16-bit integer */
60 typedef unsigned short ALushort
;
62 /** signed 32-bit 2's complement integer */
65 /** unsigned 32-bit integer */
66 typedef unsigned int ALuint
;
68 /** non-negative 32-bit binary integer size */
71 /** enumerated 32-bit value */
74 /** 32-bit IEEE754 floating-point */
75 typedef float ALfloat
;
77 /** 64-bit IEEE754 floating-point */
78 typedef double ALdouble
;
80 /** void type (for opaque pointers only) */
84 /* Enumerant values begin at column 50. No tabs. */
86 /* "no distance model" or "no buffer" */
95 /** Indicate Source has relative coordinates. */
96 #define AL_SOURCE_RELATIVE 0x202
101 * Directional source, inner cone angle, in degrees.
105 #define AL_CONE_INNER_ANGLE 0x1001
108 * Directional source, outer cone angle, in degrees.
112 #define AL_CONE_OUTER_ANGLE 0x1002
115 * Specify the pitch to be applied at source.
119 #define AL_PITCH 0x1003
122 * Specify the current location in three dimensional space.
123 * OpenAL, like OpenGL, uses a right handed coordinate system,
124 * where in a frontal default view X (thumb) points right,
125 * Y points up (index finger), and Z points towards the
126 * viewer/camera (middle finger).
127 * To switch from a left handed coordinate system, flip the
128 * sign on the Z coordinate.
129 * Listener position is always in the world coordinate system.
131 #define AL_POSITION 0x1004
133 /** Specify the current direction. */
134 #define AL_DIRECTION 0x1005
136 /** Specify the current velocity in three dimensional space. */
137 #define AL_VELOCITY 0x1006
140 * Indicate whether source is looping.
142 * Range: [AL_TRUE, AL_FALSE]
145 #define AL_LOOPING 0x1007
148 * Indicate the buffer to provide sound samples.
150 * Range: any valid Buffer id.
152 #define AL_BUFFER 0x1009
155 * Indicate the gain (volume amplification) applied.
158 * A value of 1.0 means un-attenuated/unchanged.
159 * Each division by 2 equals an attenuation of -6dB.
160 * Each multiplicaton with 2 equals an amplification of +6dB.
161 * A value of 0.0 is meaningless with respect to a logarithmic
162 * scale; it is interpreted as zero volume - the channel
163 * is effectively disabled.
165 #define AL_GAIN 0x100A
168 * Indicate minimum source attenuation
174 #define AL_MIN_GAIN 0x100D
177 * Indicate maximum source attenuation
183 #define AL_MAX_GAIN 0x100E
186 * Indicate listener orientation.
190 #define AL_ORIENTATION 0x100F
193 * Source state information.
195 #define AL_SOURCE_STATE 0x1010
196 #define AL_INITIAL 0x1011
197 #define AL_PLAYING 0x1012
198 #define AL_PAUSED 0x1013
199 #define AL_STOPPED 0x1014
202 * Buffer Queue params
204 #define AL_BUFFERS_QUEUED 0x1015
205 #define AL_BUFFERS_PROCESSED 0x1016
208 * Source buffer position information
210 #define AL_SEC_OFFSET 0x1024
211 #define AL_SAMPLE_OFFSET 0x1025
212 #define AL_BYTE_OFFSET 0x1026
215 * Source type (Static, Streaming or undetermined)
216 * Source is Static if a Buffer has been attached using AL_BUFFER
217 * Source is Streaming if one or more Buffers have been attached using alSourceQueueBuffers
218 * Source is undetermined when it has the NULL buffer attached
220 #define AL_SOURCE_TYPE 0x1027
221 #define AL_STATIC 0x1028
222 #define AL_STREAMING 0x1029
223 #define AL_UNDETERMINED 0x1030
225 /** Sound samples: format specifier. */
226 #define AL_FORMAT_MONO8 0x1100
227 #define AL_FORMAT_MONO16 0x1101
228 #define AL_FORMAT_STEREO8 0x1102
229 #define AL_FORMAT_STEREO16 0x1103
232 * source specific reference distance
236 * At 0.0, no distance attenuation occurs. Default is
239 #define AL_REFERENCE_DISTANCE 0x1020
242 * source specific rolloff factor
247 #define AL_ROLLOFF_FACTOR 0x1021
250 * Directional source, outer cone gain.
256 #define AL_CONE_OUTER_GAIN 0x1022
259 * Indicate distance above which sources are not
260 * attenuated using the inverse clamped distance model.
266 #define AL_MAX_DISTANCE 0x1023
269 * Sound samples: frequency, in units of Hertz [Hz].
270 * This is the number of samples per second. Half of the
271 * sample frequency marks the maximum significant
272 * frequency component.
274 #define AL_FREQUENCY 0x2001
275 #define AL_BITS 0x2002
276 #define AL_CHANNELS 0x2003
277 #define AL_SIZE 0x2004
282 * Not supported for public use (yet).
284 #define AL_UNUSED 0x2010
285 #define AL_PENDING 0x2011
286 #define AL_PROCESSED 0x2012
289 /** Errors: No Error. */
290 #define AL_NO_ERROR 0
293 * Invalid Name paramater passed to AL call.
295 #define AL_INVALID_NAME 0xA001
298 * Invalid parameter passed to AL call.
300 #define AL_INVALID_ENUM 0xA002
303 * Invalid enum parameter value.
305 #define AL_INVALID_VALUE 0xA003
310 #define AL_INVALID_OPERATION 0xA004
316 #define AL_OUT_OF_MEMORY 0xA005
319 /** Context strings: Vendor Name. */
320 #define AL_VENDOR 0xB001
321 #define AL_VERSION 0xB002
322 #define AL_RENDERER 0xB003
323 #define AL_EXTENSIONS 0xB004
325 /** Global tweakage. */
328 * Doppler scale. Default 1.0
330 #define AL_DOPPLER_FACTOR 0xC000
333 * Tweaks speed of propagation.
335 #define AL_DOPPLER_VELOCITY 0xC001
338 * Speed of Sound in units per second
340 #define AL_SPEED_OF_SOUND 0xC003
345 * used in conjunction with DistanceModel
347 * implicit: NONE, which disances distance attenuation.
349 #define AL_DISTANCE_MODEL 0xD000
350 #define AL_INVERSE_DISTANCE 0xD001
351 #define AL_INVERSE_DISTANCE_CLAMPED 0xD002
352 #define AL_LINEAR_DISTANCE 0xD003
353 #define AL_LINEAR_DISTANCE_CLAMPED 0xD004
354 #define AL_EXPONENT_DISTANCE 0xD005
355 #define AL_EXPONENT_DISTANCE_CLAMPED 0xD006
358 * Renderer State management
360 AL_API
void AL_APIENTRY
alEnable( ALenum capability
);
362 AL_API
void AL_APIENTRY
alDisable( ALenum capability
);
364 AL_API ALboolean AL_APIENTRY
alIsEnabled( ALenum capability
);
370 AL_API
const ALchar
* AL_APIENTRY
alGetString( ALenum param
);
372 AL_API
void AL_APIENTRY
alGetBooleanv( ALenum param
, ALboolean
* data
);
374 AL_API
void AL_APIENTRY
alGetIntegerv( ALenum param
, ALint
* data
);
376 AL_API
void AL_APIENTRY
alGetFloatv( ALenum param
, ALfloat
* data
);
378 AL_API
void AL_APIENTRY
alGetDoublev( ALenum param
, ALdouble
* data
);
380 AL_API ALboolean AL_APIENTRY
alGetBoolean( ALenum param
);
382 AL_API ALint AL_APIENTRY
alGetInteger( ALenum param
);
384 AL_API ALfloat AL_APIENTRY
alGetFloat( ALenum param
);
386 AL_API ALdouble AL_APIENTRY
alGetDouble( ALenum param
);
391 * Obtain the most recent error generated in the AL state machine.
393 AL_API ALenum AL_APIENTRY
alGetError( void );
398 * Query for the presence of an extension, and obtain any appropriate
399 * function pointers and enum values.
401 AL_API ALboolean AL_APIENTRY
alIsExtensionPresent( const ALchar
* extname
);
403 AL_API
void* AL_APIENTRY
alGetProcAddress( const ALchar
* fname
);
405 AL_API ALenum AL_APIENTRY
alGetEnumValue( const ALchar
* ename
);
410 * Listener represents the location and orientation of the
411 * 'user' in 3D-space.
413 * Properties include: -
415 * Gain AL_GAIN ALfloat
416 * Position AL_POSITION ALfloat[3]
417 * Velocity AL_VELOCITY ALfloat[3]
418 * Orientation AL_ORIENTATION ALfloat[6] (Forward then Up vectors)
422 * Set Listener parameters
424 AL_API
void AL_APIENTRY
alListenerf( ALenum param
, ALfloat value
);
426 AL_API
void AL_APIENTRY
alListener3f( ALenum param
, ALfloat value1
, ALfloat value2
, ALfloat value3
);
428 AL_API
void AL_APIENTRY
alListenerfv( ALenum param
, const ALfloat
* values
);
430 AL_API
void AL_APIENTRY
alListeneri( ALenum param
, ALint value
);
432 AL_API
void AL_APIENTRY
alListener3i( ALenum param
, ALint value1
, ALint value2
, ALint value3
);
434 AL_API
void AL_APIENTRY
alListeneriv( ALenum param
, const ALint
* values
);
437 * Get Listener parameters
439 AL_API
void AL_APIENTRY
alGetListenerf( ALenum param
, ALfloat
* value
);
441 AL_API
void AL_APIENTRY
alGetListener3f( ALenum param
, ALfloat
*value1
, ALfloat
*value2
, ALfloat
*value3
);
443 AL_API
void AL_APIENTRY
alGetListenerfv( ALenum param
, ALfloat
* values
);
445 AL_API
void AL_APIENTRY
alGetListeneri( ALenum param
, ALint
* value
);
447 AL_API
void AL_APIENTRY
alGetListener3i( ALenum param
, ALint
*value1
, ALint
*value2
, ALint
*value3
);
449 AL_API
void AL_APIENTRY
alGetListeneriv( ALenum param
, ALint
* values
);
454 * Sources represent individual sound objects in 3D-space.
455 * Sources take the PCM data provided in the specified Buffer,
456 * apply Source-specific modifications, and then
457 * submit them to be mixed according to spatial arrangement etc.
459 * Properties include: -
461 * Gain AL_GAIN ALfloat
462 * Min Gain AL_MIN_GAIN ALfloat
463 * Max Gain AL_MAX_GAIN ALfloat
464 * Position AL_POSITION ALfloat[3]
465 * Velocity AL_VELOCITY ALfloat[3]
466 * Direction AL_DIRECTION ALfloat[3]
467 * Head Relative Mode AL_SOURCE_RELATIVE ALint (AL_TRUE or AL_FALSE)
468 * Reference Distance AL_REFERENCE_DISTANCE ALfloat
469 * Max Distance AL_MAX_DISTANCE ALfloat
470 * RollOff Factor AL_ROLLOFF_FACTOR ALfloat
471 * Inner Angle AL_CONE_INNER_ANGLE ALint or ALfloat
472 * Outer Angle AL_CONE_OUTER_ANGLE ALint or ALfloat
473 * Cone Outer Gain AL_CONE_OUTER_GAIN ALint or ALfloat
474 * Pitch AL_PITCH ALfloat
475 * Looping AL_LOOPING ALint (AL_TRUE or AL_FALSE)
476 * MS Offset AL_MSEC_OFFSET ALint or ALfloat
477 * Byte Offset AL_BYTE_OFFSET ALint or ALfloat
478 * Sample Offset AL_SAMPLE_OFFSET ALint or ALfloat
479 * Attached Buffer AL_BUFFER ALint
480 * State (Query only) AL_SOURCE_STATE ALint
481 * Buffers Queued (Query only) AL_BUFFERS_QUEUED ALint
482 * Buffers Processed (Query only) AL_BUFFERS_PROCESSED ALint
485 /* Create Source objects */
486 AL_API
void AL_APIENTRY
alGenSources( ALsizei n
, ALuint
* sources
);
488 /* Delete Source objects */
489 AL_API
void AL_APIENTRY
alDeleteSources( ALsizei n
, const ALuint
* sources
);
491 /* Verify a handle is a valid Source */
492 AL_API ALboolean AL_APIENTRY
alIsSource( ALuint sid
);
495 * Set Source parameters
497 AL_API
void AL_APIENTRY
alSourcef( ALuint sid
, ALenum param
, ALfloat value
);
499 AL_API
void AL_APIENTRY
alSource3f( ALuint sid
, ALenum param
, ALfloat value1
, ALfloat value2
, ALfloat value3
);
501 AL_API
void AL_APIENTRY
alSourcefv( ALuint sid
, ALenum param
, const ALfloat
* values
);
503 AL_API
void AL_APIENTRY
alSourcei( ALuint sid
, ALenum param
, ALint value
);
505 AL_API
void AL_APIENTRY
alSource3i( ALuint sid
, ALenum param
, ALint value1
, ALint value2
, ALint value3
);
507 AL_API
void AL_APIENTRY
alSourceiv( ALuint sid
, ALenum param
, const ALint
* values
);
510 * Get Source parameters
512 AL_API
void AL_APIENTRY
alGetSourcef( ALuint sid
, ALenum param
, ALfloat
* value
);
514 AL_API
void AL_APIENTRY
alGetSource3f( ALuint sid
, ALenum param
, ALfloat
* value1
, ALfloat
* value2
, ALfloat
* value3
);
516 AL_API
void AL_APIENTRY
alGetSourcefv( ALuint sid
, ALenum param
, ALfloat
* values
);
518 AL_API
void AL_APIENTRY
alGetSourcei( ALuint sid
, ALenum param
, ALint
* value
);
520 AL_API
void AL_APIENTRY
alGetSource3i( ALuint sid
, ALenum param
, ALint
* value1
, ALint
* value2
, ALint
* value3
);
522 AL_API
void AL_APIENTRY
alGetSourceiv( ALuint sid
, ALenum param
, ALint
* values
);
526 * Source vector based playback calls
529 /* Play, replay, or resume (if paused) a list of Sources */
530 AL_API
void AL_APIENTRY
alSourcePlayv( ALsizei ns
, const ALuint
*sids
);
532 /* Stop a list of Sources */
533 AL_API
void AL_APIENTRY
alSourceStopv( ALsizei ns
, const ALuint
*sids
);
535 /* Rewind a list of Sources */
536 AL_API
void AL_APIENTRY
alSourceRewindv( ALsizei ns
, const ALuint
*sids
);
538 /* Pause a list of Sources */
539 AL_API
void AL_APIENTRY
alSourcePausev( ALsizei ns
, const ALuint
*sids
);
542 * Source based playback calls
545 /* Play, replay, or resume a Source */
546 AL_API
void AL_APIENTRY
alSourcePlay( ALuint sid
);
549 AL_API
void AL_APIENTRY
alSourceStop( ALuint sid
);
551 /* Rewind a Source (set playback postiton to beginning) */
552 AL_API
void AL_APIENTRY
alSourceRewind( ALuint sid
);
555 AL_API
void AL_APIENTRY
alSourcePause( ALuint sid
);
560 AL_API
void AL_APIENTRY
alSourceQueueBuffers( ALuint sid
, ALsizei numEntries
, const ALuint
*bids
);
562 AL_API
void AL_APIENTRY
alSourceUnqueueBuffers( ALuint sid
, ALsizei numEntries
, ALuint
*bids
);
567 * Buffer objects are storage space for sample data.
568 * Buffers are referred to by Sources. One Buffer can be used
569 * by multiple Sources.
571 * Properties include: -
573 * Frequency (Query only) AL_FREQUENCY ALint
574 * Size (Query only) AL_SIZE ALint
575 * Bits (Query only) AL_BITS ALint
576 * Channels (Query only) AL_CHANNELS ALint
579 /* Create Buffer objects */
580 AL_API
void AL_APIENTRY
alGenBuffers( ALsizei n
, ALuint
* buffers
);
582 /* Delete Buffer objects */
583 AL_API
void AL_APIENTRY
alDeleteBuffers( ALsizei n
, const ALuint
* buffers
);
585 /* Verify a handle is a valid Buffer */
586 AL_API ALboolean AL_APIENTRY
alIsBuffer( ALuint bid
);
588 /* Specify the data to be copied into a buffer */
589 AL_API
void AL_APIENTRY
alBufferData( ALuint bid
, ALenum format
, const ALvoid
* data
, ALsizei size
, ALsizei freq
);
592 * Set Buffer parameters
594 AL_API
void AL_APIENTRY
alBufferf( ALuint bid
, ALenum param
, ALfloat value
);
596 AL_API
void AL_APIENTRY
alBuffer3f( ALuint bid
, ALenum param
, ALfloat value1
, ALfloat value2
, ALfloat value3
);
598 AL_API
void AL_APIENTRY
alBufferfv( ALuint bid
, ALenum param
, const ALfloat
* values
);
600 AL_API
void AL_APIENTRY
alBufferi( ALuint bid
, ALenum param
, ALint value
);
602 AL_API
void AL_APIENTRY
alBuffer3i( ALuint bid
, ALenum param
, ALint value1
, ALint value2
, ALint value3
);
604 AL_API
void AL_APIENTRY
alBufferiv( ALuint bid
, ALenum param
, const ALint
* values
);
607 * Get Buffer parameters
609 AL_API
void AL_APIENTRY
alGetBufferf( ALuint bid
, ALenum param
, ALfloat
* value
);
611 AL_API
void AL_APIENTRY
alGetBuffer3f( ALuint bid
, ALenum param
, ALfloat
* value1
, ALfloat
* value2
, ALfloat
* value3
);
613 AL_API
void AL_APIENTRY
alGetBufferfv( ALuint bid
, ALenum param
, ALfloat
* values
);
615 AL_API
void AL_APIENTRY
alGetBufferi( ALuint bid
, ALenum param
, ALint
* value
);
617 AL_API
void AL_APIENTRY
alGetBuffer3i( ALuint bid
, ALenum param
, ALint
* value1
, ALint
* value2
, ALint
* value3
);
619 AL_API
void AL_APIENTRY
alGetBufferiv( ALuint bid
, ALenum param
, ALint
* values
);
625 AL_API
void AL_APIENTRY
alDopplerFactor( ALfloat value
);
627 AL_API
void AL_APIENTRY
alDopplerVelocity( ALfloat value
);
629 AL_API
void AL_APIENTRY
alSpeedOfSound( ALfloat value
);
631 AL_API
void AL_APIENTRY
alDistanceModel( ALenum distanceModel
);
634 * Pointer-to-function types, useful for dynamically getting AL entry points.
636 typedef void (AL_APIENTRY
*LPALENABLE
)( ALenum capability
);
637 typedef void (AL_APIENTRY
*LPALDISABLE
)( ALenum capability
);
638 typedef ALboolean (AL_APIENTRY
*LPALISENABLED
)( ALenum capability
);
639 typedef const ALchar
* (AL_APIENTRY
*LPALGETSTRING
)( ALenum param
);
640 typedef void (AL_APIENTRY
*LPALGETBOOLEANV
)( ALenum param
, ALboolean
* data
);
641 typedef void (AL_APIENTRY
*LPALGETINTEGERV
)( ALenum param
, ALint
* data
);
642 typedef void (AL_APIENTRY
*LPALGETFLOATV
)( ALenum param
, ALfloat
* data
);
643 typedef void (AL_APIENTRY
*LPALGETDOUBLEV
)( ALenum param
, ALdouble
* data
);
644 typedef ALboolean (AL_APIENTRY
*LPALGETBOOLEAN
)( ALenum param
);
645 typedef ALint (AL_APIENTRY
*LPALGETINTEGER
)( ALenum param
);
646 typedef ALfloat (AL_APIENTRY
*LPALGETFLOAT
)( ALenum param
);
647 typedef ALdouble (AL_APIENTRY
*LPALGETDOUBLE
)( ALenum param
);
648 typedef ALenum (AL_APIENTRY
*LPALGETERROR
)( void );
649 typedef ALboolean (AL_APIENTRY
*LPALISEXTENSIONPRESENT
)(const ALchar
* extname
);
650 typedef void* (AL_APIENTRY
*LPALGETPROCADDRESS
)( const ALchar
* fname
);
651 typedef ALenum (AL_APIENTRY
*LPALGETENUMVALUE
)( const ALchar
* ename
);
652 typedef void (AL_APIENTRY
*LPALLISTENERF
)( ALenum param
, ALfloat value
);
653 typedef void (AL_APIENTRY
*LPALLISTENER3F
)( ALenum param
, ALfloat value1
, ALfloat value2
, ALfloat value3
);
654 typedef void (AL_APIENTRY
*LPALLISTENERFV
)( ALenum param
, const ALfloat
* values
);
655 typedef void (AL_APIENTRY
*LPALLISTENERI
)( ALenum param
, ALint value
);
656 typedef void (AL_APIENTRY
*LPALLISTENER3I
)( ALenum param
, ALint value1
, ALint value2
, ALint value3
);
657 typedef void (AL_APIENTRY
*LPALLISTENERIV
)( ALenum param
, const ALint
* values
);
658 typedef void (AL_APIENTRY
*LPALGETLISTENERF
)( ALenum param
, ALfloat
* value
);
659 typedef void (AL_APIENTRY
*LPALGETLISTENER3F
)( ALenum param
, ALfloat
*value1
, ALfloat
*value2
, ALfloat
*value3
);
660 typedef void (AL_APIENTRY
*LPALGETLISTENERFV
)( ALenum param
, ALfloat
* values
);
661 typedef void (AL_APIENTRY
*LPALGETLISTENERI
)( ALenum param
, ALint
* value
);
662 typedef void (AL_APIENTRY
*LPALGETLISTENER3I
)( ALenum param
, ALint
*value1
, ALint
*value2
, ALint
*value3
);
663 typedef void (AL_APIENTRY
*LPALGETLISTENERIV
)( ALenum param
, ALint
* values
);
664 typedef void (AL_APIENTRY
*LPALGENSOURCES
)( ALsizei n
, ALuint
* sources
);
665 typedef void (AL_APIENTRY
*LPALDELETESOURCES
)( ALsizei n
, const ALuint
* sources
);
666 typedef ALboolean (AL_APIENTRY
*LPALISSOURCE
)( ALuint sid
);
667 typedef void (AL_APIENTRY
*LPALSOURCEF
)( ALuint sid
, ALenum param
, ALfloat value
);
668 typedef void (AL_APIENTRY
*LPALSOURCE3F
)( ALuint sid
, ALenum param
, ALfloat value1
, ALfloat value2
, ALfloat value3
);
669 typedef void (AL_APIENTRY
*LPALSOURCEFV
)( ALuint sid
, ALenum param
, const ALfloat
* values
);
670 typedef void (AL_APIENTRY
*LPALSOURCEI
)( ALuint sid
, ALenum param
, ALint value
);
671 typedef void (AL_APIENTRY
*LPALSOURCE3I
)( ALuint sid
, ALenum param
, ALint value1
, ALint value2
, ALint value3
);
672 typedef void (AL_APIENTRY
*LPALSOURCEIV
)( ALuint sid
, ALenum param
, const ALint
* values
);
673 typedef void (AL_APIENTRY
*LPALGETSOURCEF
)( ALuint sid
, ALenum param
, ALfloat
* value
);
674 typedef void (AL_APIENTRY
*LPALGETSOURCE3F
)( ALuint sid
, ALenum param
, ALfloat
* value1
, ALfloat
* value2
, ALfloat
* value3
);
675 typedef void (AL_APIENTRY
*LPALGETSOURCEFV
)( ALuint sid
, ALenum param
, ALfloat
* values
);
676 typedef void (AL_APIENTRY
*LPALGETSOURCEI
)( ALuint sid
, ALenum param
, ALint
* value
);
677 typedef void (AL_APIENTRY
*LPALGETSOURCE3I
)( ALuint sid
, ALenum param
, ALint
* value1
, ALint
* value2
, ALint
* value3
);
678 typedef void (AL_APIENTRY
*LPALGETSOURCEIV
)( ALuint sid
, ALenum param
, ALint
* values
);
679 typedef void (AL_APIENTRY
*LPALSOURCEPLAYV
)( ALsizei ns
, const ALuint
*sids
);
680 typedef void (AL_APIENTRY
*LPALSOURCESTOPV
)( ALsizei ns
, const ALuint
*sids
);
681 typedef void (AL_APIENTRY
*LPALSOURCEREWINDV
)( ALsizei ns
, const ALuint
*sids
);
682 typedef void (AL_APIENTRY
*LPALSOURCEPAUSEV
)( ALsizei ns
, const ALuint
*sids
);
683 typedef void (AL_APIENTRY
*LPALSOURCEPLAY
)( ALuint sid
);
684 typedef void (AL_APIENTRY
*LPALSOURCESTOP
)( ALuint sid
);
685 typedef void (AL_APIENTRY
*LPALSOURCEREWIND
)( ALuint sid
);
686 typedef void (AL_APIENTRY
*LPALSOURCEPAUSE
)( ALuint sid
);
687 typedef void (AL_APIENTRY
*LPALSOURCEQUEUEBUFFERS
)(ALuint sid
, ALsizei numEntries
, const ALuint
*bids
);
688 typedef void (AL_APIENTRY
*LPALSOURCEUNQUEUEBUFFERS
)(ALuint sid
, ALsizei numEntries
, ALuint
*bids
);
689 typedef void (AL_APIENTRY
*LPALGENBUFFERS
)( ALsizei n
, ALuint
* buffers
);
690 typedef void (AL_APIENTRY
*LPALDELETEBUFFERS
)( ALsizei n
, const ALuint
* buffers
);
691 typedef ALboolean (AL_APIENTRY
*LPALISBUFFER
)( ALuint bid
);
692 typedef void (AL_APIENTRY
*LPALBUFFERDATA
)( ALuint bid
, ALenum format
, const ALvoid
* data
, ALsizei size
, ALsizei freq
);
693 typedef void (AL_APIENTRY
*LPALBUFFERF
)( ALuint bid
, ALenum param
, ALfloat value
);
694 typedef void (AL_APIENTRY
*LPALBUFFER3F
)( ALuint bid
, ALenum param
, ALfloat value1
, ALfloat value2
, ALfloat value3
);
695 typedef void (AL_APIENTRY
*LPALBUFFERFV
)( ALuint bid
, ALenum param
, const ALfloat
* values
);
696 typedef void (AL_APIENTRY
*LPALBUFFERI
)( ALuint bid
, ALenum param
, ALint value
);
697 typedef void (AL_APIENTRY
*LPALBUFFER3I
)( ALuint bid
, ALenum param
, ALint value1
, ALint value2
, ALint value3
);
698 typedef void (AL_APIENTRY
*LPALBUFFERIV
)( ALuint bid
, ALenum param
, const ALint
* values
);
699 typedef void (AL_APIENTRY
*LPALGETBUFFERF
)( ALuint bid
, ALenum param
, ALfloat
* value
);
700 typedef void (AL_APIENTRY
*LPALGETBUFFER3F
)( ALuint bid
, ALenum param
, ALfloat
* value1
, ALfloat
* value2
, ALfloat
* value3
);
701 typedef void (AL_APIENTRY
*LPALGETBUFFERFV
)( ALuint bid
, ALenum param
, ALfloat
* values
);
702 typedef void (AL_APIENTRY
*LPALGETBUFFERI
)( ALuint bid
, ALenum param
, ALint
* value
);
703 typedef void (AL_APIENTRY
*LPALGETBUFFER3I
)( ALuint bid
, ALenum param
, ALint
* value1
, ALint
* value2
, ALint
* value3
);
704 typedef void (AL_APIENTRY
*LPALGETBUFFERIV
)( ALuint bid
, ALenum param
, ALint
* values
);
705 typedef void (AL_APIENTRY
*LPALDOPPLERFACTOR
)( ALfloat value
);
706 typedef void (AL_APIENTRY
*LPALDOPPLERVELOCITY
)( ALfloat value
);
707 typedef void (AL_APIENTRY
*LPALSPEEDOFSOUND
)( ALfloat value
);
708 typedef void (AL_APIENTRY
*LPALDISTANCEMODEL
)( ALenum distanceModel
);
710 #if defined(TARGET_OS_MAC) && TARGET_OS_MAC
714 #if defined(__cplusplus)