summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/i_sound.c82
-rw-r--r--src/i_system.c8
2 files changed, 77 insertions, 13 deletions
diff --git a/src/i_sound.c b/src/i_sound.c
index a2cbf9c5..2075be51 100644
--- a/src/i_sound.c
+++ b/src/i_sound.c
@@ -1,7 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// $Id: i_sound.c 79 2005-09-06 21:40:28Z fraggle $
+// $Id: i_sound.c 80 2005-09-06 22:39:43Z fraggle $
//
// Copyright(C) 1993-1996 Id Software, Inc.
// Copyright(C) 2005 Simon Howard
@@ -22,6 +22,9 @@
// 02111-1307, USA.
//
// $Log$
+// Revision 1.16 2005/09/06 22:39:43 fraggle
+// Restore -nosound, -nosfx, -nomusic
+//
// Revision 1.15 2005/09/06 21:40:28 fraggle
// Setting music volume
//
@@ -80,7 +83,7 @@
//-----------------------------------------------------------------------------
static const char
-rcsid[] = "$Id: i_sound.c 79 2005-09-06 21:40:28Z fraggle $";
+rcsid[] = "$Id: i_sound.c 80 2005-09-06 22:39:43Z fraggle $";
#include <stdio.h>
#include <stdlib.h>
@@ -105,9 +108,10 @@ rcsid[] = "$Id: i_sound.c 79 2005-09-06 21:40:28Z fraggle $";
#define NUM_CHANNELS 16
-static int sound_initialised = 0;
+static boolean sound_initialised = false;
static Mix_Chunk sound_chunks[NUMSFX];
+
static byte *expand_sound_data(byte *data, int samplerate, int length)
{
byte *result = data;
@@ -249,7 +253,12 @@ I_StartSound
int pitch,
int priority )
{
- Mix_Chunk *chunk = getsfx(id);
+ Mix_Chunk *chunk;
+
+ if (!sound_initialised)
+ return 0;
+
+ chunk = getsfx(id);
// play sound
@@ -266,12 +275,17 @@ I_StartSound
void I_StopSound (int handle)
{
+ if (!sound_initialised)
+ return;
Mix_HaltChannel(handle);
}
int I_SoundIsPlaying(int handle)
{
+ if (!sound_initialised)
+ return false;
+
return Mix_Playing(handle);
}
@@ -320,6 +334,9 @@ I_UpdateSoundParams
{
int left, right;
+ if (!sound_initialised)
+ return;
+
left = ((254 - sep) * vol) / 15;
right = ((sep) * vol) / 15;
@@ -340,12 +357,16 @@ void I_ShutdownSound(void)
-
-
-
void
I_InitSound()
{
+ // If music or sound is going to play, we need to at least
+ // initialise SDL
+
+ if (M_CheckParm("-nosound")
+ || (M_CheckParm("-nosfx") && M_CheckParm("-nomusic")))
+ return;
+
if (SDL_Init(SDL_INIT_AUDIO) < 0)
{
fprintf(stderr, "Unable to set up sound.\n");
@@ -359,9 +380,14 @@ I_InitSound()
Mix_AllocateChannels(NUM_CHANNELS);
- sound_initialised = 1;
-
SDL_PauseAudio(0);
+
+ if (M_CheckParm("-nosound") || M_CheckParm("-nosfx"))
+ return;
+
+ sound_initialised = true;
+
+
}
@@ -372,8 +398,21 @@ I_InitSound()
// Still no music done.
// Remains. Dummies.
//
-void I_InitMusic(void) { }
-void I_ShutdownMusic(void) { }
+
+static int music_initialised;
+
+void I_InitMusic(void)
+{
+ if (M_CheckParm("-nomusic") || M_CheckParm("-nosound"))
+ return;
+
+ music_initialised = true;
+}
+
+void I_ShutdownMusic(void)
+{
+ music_initialised = false;
+}
static int looping=0;
static int musicdies=-1;
@@ -383,6 +422,9 @@ void I_PlaySong(void *handle, int looping)
Mix_Music *music = (Mix_Music *) handle;
int loops;
+ if (!music_initialised)
+ return;
+
if (handle == NULL)
return;
@@ -396,16 +438,25 @@ void I_PlaySong(void *handle, int looping)
void I_PauseSong (void *handle)
{
+ if (!music_initialised)
+ return;
+
Mix_PauseMusic();
}
void I_ResumeSong (void *handle)
{
+ if (!music_initialised)
+ return;
+
Mix_ResumeMusic();
}
void I_StopSong(void *handle)
{
+ if (!music_initialised)
+ return;
+
Mix_HaltMusic();
}
@@ -413,6 +464,9 @@ void I_UnRegisterSong(void *handle)
{
Mix_Music *music = (Mix_Music *) handle;
+ if (!music_initialised)
+ return;
+
if (handle == NULL)
return;
@@ -426,6 +480,9 @@ void *I_RegisterSong(void *data, int len)
MIDI *mididata;
UBYTE *mid;
int midlen;
+
+ if (!music_initialised)
+ return NULL;
#ifdef _WIN32
sprintf(filename, "doom.mid");
@@ -475,6 +532,9 @@ void *I_RegisterSong(void *data, int len)
// Is the song playing?
int I_QrySongPlaying(void *handle)
{
+ if (!music_initialised)
+ return false;
+
return Mix_PlayingMusic();
}
diff --git a/src/i_system.c b/src/i_system.c
index 34f46b5e..93824e04 100644
--- a/src/i_system.c
+++ b/src/i_system.c
@@ -1,7 +1,7 @@
// Emacs style mode select -*- C++ -*-
//-----------------------------------------------------------------------------
//
-// $Id: i_system.c 37 2005-08-04 18:42:15Z fraggle $
+// $Id: i_system.c 80 2005-09-06 22:39:43Z fraggle $
//
// Copyright(C) 1993-1996 Id Software, Inc.
// Copyright(C) 2005 Simon Howard
@@ -22,6 +22,9 @@
// 02111-1307, USA.
//
// $Log$
+// Revision 1.8 2005/09/06 22:39:43 fraggle
+// Restore -nosound, -nosfx, -nomusic
+//
// Revision 1.7 2005/08/04 18:42:15 fraggle
// Silence compiler warnings
//
@@ -49,7 +52,7 @@
//-----------------------------------------------------------------------------
static const char
-rcsid[] = "$Id: i_system.c 37 2005-08-04 18:42:15Z fraggle $";
+rcsid[] = "$Id: i_system.c 80 2005-09-06 22:39:43Z fraggle $";
#include <stdlib.h>
@@ -136,6 +139,7 @@ int I_GetTime (void)
void I_Init (void)
{
I_InitSound();
+ I_InitMusic();
// initialise timer