// rights reserved.
#include "quakedef.h"
+#include "snd_main.h"
+
+#define MAXTRACKS 256
// Prototypes of the system dependent functions
extern void CDAudio_SysEject (void);
static qboolean initialized = false;
static qboolean enabled = false;
static float cdvolume;
-static qbyte remap[100];
+static qbyte remap[MAXTRACKS];
static qbyte maxTrack;
static int faketrack = -1;
return;
}
- if (cdPlaying && cdPlayTrack == track)
+ if (cdPlaying && cdPlayTrack == track && faketrack == -1)
return;
CDAudio_Stop ();
// Try playing a fake track (sound file) first
- sfx = S_PrecacheSound (va ("cdtracks/track%02u.wav", track), false, true);
+ sfx = S_PrecacheSound (va ("cdtracks/track%02u.wav", track), false, false);
+ // FIXME: perhaps force it to be always %03u (but for compatibility?):
+ if (sfx == NULL || sfx->fetcher == NULL)
+ sfx = S_PrecacheSound (va ("cdtracks/track%03u.wav", track), false, false);
if (sfx != NULL)
{
faketrack = S_StartSound (-1, 0, sfx, vec3_origin, cdvolume, 0);
if (faketrack != -1)
{
if (looping)
- S_LoopChannel (faketrack, true);
+ S_SetChannelFlag (faketrack, CHANNELFLAG_FORCELOOP, true);
+ S_SetChannelFlag (faketrack, CHANNELFLAG_FULLVOLUME, true);
Con_DPrintf ("Fake CD track %u playing...\n", track);
}
}
return;
if (faketrack != -1)
- S_PauseChannel (faketrack, true);
+ S_SetChannelFlag (faketrack, CHANNELFLAG_PAUSED, true);
else if (CDAudio_SysPause() == -1)
return;
return;
if (faketrack != -1)
- S_PauseChannel (faketrack, false);
+ S_SetChannelFlag (faketrack, CHANNELFLAG_PAUSED, false);
else if (CDAudio_SysResume() == -1)
return;
cdPlaying = true;
enabled = true;
if (cdPlaying)
CDAudio_Stop();
- for (n = 0; n < 100; n++)
+ for (n = 0; n < MAXTRACKS; n++)
remap[n] = n;
CDAudio_GetAudioDiskInfo();
return;
ret = Cmd_Argc() - 2;
if (ret <= 0)
{
- for (n = 1; n < 100; n++)
+ for (n = 1; n < MAXTRACKS; n++)
if (remap[n] != n)
Con_Printf(" %u -> %u\n", n, remap[n]);
return;
CDAudio_SysInit();
- for (i = 0; i < 100; i++)
+ for (i = 0; i < MAXTRACKS; i++)
remap[i] = i;
Cvar_RegisterVariable(&cdaudioinitialized);