X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Fsound.h;h=16fe71de0a131a36018842ece036583355d5d0f0;hb=228a5718ede5ee00512ed2e333b3cee47baa124c;hp=47807ddec92d962897a80b4ae46fd76ceb8e3a0d;hpb=0a87fde47bcff35f196024766f8d0d00319a28d1;p=rocksndiamonds.git diff --git a/src/sound.h b/src/sound.h index 47807dde..16fe71de 100644 --- a/src/sound.h +++ b/src/sound.h @@ -14,39 +14,37 @@ #ifndef SOUND_H #define SOUND_H -#include -#include "main.h" - -#ifdef linux -#include -#ifndef VOXWARE -#define VOXWARE -#endif -/* where is the right declaration for 'ioctl'? */ -extern void ioctl(long, long, void *); -#endif +#include "platform.h" -#ifdef __FreeBSD__ -#include -#endif +#include +#include #define SND_BLOCKSIZE 4096 -#ifdef _HPUX_SOURCE +#if defined(PLATFORM_LINUX) +#include +#elif defined(PLATFORM_FREEBSD) +#include +#elif defined(PLATFORM_HPUX) #include #undef SND_BLOCKSIZE #define SND_BLOCKSIZE 32768 -#define HPUX_AUDIO -#endif /* _HPUX_SOURCE */ +#endif + +#include "main.h" + +#if defined(PLATFORM_LINUX) || defined(PLATFORM_FREEBSD) || defined(VOXWARE) +#define AUDIO_STREAMING_DSP +#endif -#ifndef MSDOS +#if !defined(PLATFORM_MSDOS) #define MAX_SOUNDS_PLAYING 16 #else #define MAX_SOUNDS_PLAYING 8 #endif /* some values for PlaySound(), StopSound() and friends */ -#ifndef MSDOS +#if !defined(PLATFORM_MSDOS) #define PSND_SILENCE 0 #define PSND_MAX_VOLUME_BITS 7 #define PSND_MIN_VOLUME 0 @@ -84,22 +82,14 @@ extern void ioctl(long, long, void *); #define SND_PATH "./sounds" #endif -#define DEV_AUDIO "/dev/audio" -#define DEV_DSP "/dev/dsp" +#define DEVICENAME_DSP "/dev/dsp" +#define DEVICENAME_AUDIO "/dev/audio" +#define DEVICENAME_AUDIOCTL "/dev/audioCtl" -#ifdef VOXWARE -#define SOUND_DEVICE DEV_DSP +#if defined(AUDIO_STREAMING_DSP) +#define AUDIO_DEVICE DEVICENAME_DSP #else -#define SOUND_DEVICE DEV_AUDIO -#endif - -#define SOUND_OFF 0 -#define SOUND_AVAILABLE 1 - -#ifdef NO_SOUNDS -#define SOUND_STATUS SOUND_OFF -#else -#define SOUND_STATUS SOUND_AVAILABLE +#define AUDIO_DEVICE DEVICENAME_AUDIO #endif struct SoundHeader_SUN @@ -119,25 +109,19 @@ struct SoundHeader_8SVX char magic_8SVX[4]; }; -struct SoundHeader_WAV -{ - char magic_RIFF[4]; - unsigned long header_size; - char magic_WAVE[4]; - char some_stuff[24]; - char magic_DATA[4]; - unsigned long data_size; -}; - -struct SoundInfo +struct SampleInfo { - unsigned char *name; - unsigned char *file_ptr; - char *data_ptr; - long file_len, data_len; -#ifdef MSDOS + char *name; + byte *data_ptr; + long data_len; + +#if defined(PLATFORM_MSDOS) SAMPLE *sample_ptr; #endif + +#if defined(TARGET_SDL) + Mix_Chunk *mix_chunk; +#endif }; struct SoundControl @@ -153,23 +137,22 @@ struct SoundControl int playingtime; long playingpos; long data_len; - char *data_ptr; -#ifdef MSDOS + byte *data_ptr; + +#if defined(PLATFORM_MSDOS) int voice; #endif }; -/* sound server functions */ +/* general sound functions */ +void UnixOpenAudio(struct AudioSystemInfo *); +void UnixCloseAudio(struct AudioSystemInfo *); + +/* sound server functions */ void SoundServer(void); -void SoundServer_InsertNewSound(struct SoundControl); -void SoundServer_StopSound(int); -void SoundServer_StopAllSounds(void); -void HPUX_Audio_Control(void); -unsigned char linear_to_ulaw(int); -int ulaw_to_linear(unsigned char); - -/* application functions */ -boolean LoadSound(struct SoundInfo *); + +/* sound client functions */ +boolean LoadSound(struct SampleInfo *); void PlaySound(int); void PlaySoundStereo(int, int); void PlaySoundLoop(int);