X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Fsound.h;h=16fe71de0a131a36018842ece036583355d5d0f0;hb=228a5718ede5ee00512ed2e333b3cee47baa124c;hp=dada0e89bcba1beefc78c3ed93163a1abc3725ab;hpb=41cfe645942062496cd063eb46e17d677a76c645;p=rocksndiamonds.git diff --git a/src/sound.h b/src/sound.h index dada0e89..16fe71de 100644 --- a/src/sound.h +++ b/src/sound.h @@ -14,45 +14,37 @@ #ifndef SOUND_H #define SOUND_H -#include -#include "main.h" +#include "platform.h" -#ifdef linux -#include -#ifndef VOXWARE -#define VOXWARE -#endif - -#if 0 -/* where is the right declaration for 'ioctl'? */ -extern void ioctl(long, long, void *); -#else #include -#endif - -#endif - -#ifdef __FreeBSD__ -#include -#endif +#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 @@ -90,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 @@ -125,17 +109,17 @@ struct SoundHeader_8SVX char magic_8SVX[4]; }; -struct SoundInfo +struct SampleInfo { char *name; byte *data_ptr; long data_len; -#ifdef MSDOS +#if defined(PLATFORM_MSDOS) SAMPLE *sample_ptr; #endif -#ifdef USE_SDL_LIBRARY +#if defined(TARGET_SDL) Mix_Chunk *mix_chunk; #endif }; @@ -154,16 +138,21 @@ struct SoundControl long playingpos; long data_len; byte *data_ptr; -#ifdef MSDOS + +#if defined(PLATFORM_MSDOS) int voice; #endif }; -/* start sound server */ +/* general sound functions */ +void UnixOpenAudio(struct AudioSystemInfo *); +void UnixCloseAudio(struct AudioSystemInfo *); + +/* sound server functions */ void SoundServer(void); -/* client functions */ -boolean LoadSound(struct SoundInfo *); +/* sound client functions */ +boolean LoadSound(struct SampleInfo *); void PlaySound(int); void PlaySoundStereo(int, int); void PlaySoundLoop(int);