mirror of
https://github.com/ZDoom/raze-gles.git
synced 2025-01-26 00:40:56 +00:00
Remove some outdated/incorrect code that was causing some issues when multiple copies of a single sound were playing and just one of them needed to be stopped.
git-svn-id: https://svn.eduke32.com/eduke32@3080 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
parent
901b1bff0f
commit
7e248dcc49
1 changed files with 6 additions and 13 deletions
|
@ -406,6 +406,8 @@ static int32_t S_TakeSlot(int32_t num)
|
||||||
uint32_t dist = 0, clock = UINT32_MAX;
|
uint32_t dist = 0, clock = UINT32_MAX;
|
||||||
int32_t i = 0, j = 0;
|
int32_t i = 0, j = 0;
|
||||||
|
|
||||||
|
S_Cleanup();
|
||||||
|
|
||||||
while (j < MAXSOUNDINSTANCES && g_sounds[num].SoundOwner[j].voice > 0)
|
while (j < MAXSOUNDINSTANCES && g_sounds[num].SoundOwner[j].voice > 0)
|
||||||
{
|
{
|
||||||
if (g_sounds[num].SoundOwner[j].sndist > dist ||
|
if (g_sounds[num].SoundOwner[j].sndist > dist ||
|
||||||
|
@ -767,18 +769,11 @@ void S_StopEnvSound(int32_t num, int32_t i)
|
||||||
{
|
{
|
||||||
if (i >= 0 && g_sounds[num].SoundOwner[j].voice <= FX_Ok)
|
if (i >= 0 && g_sounds[num].SoundOwner[j].voice <= FX_Ok)
|
||||||
initprintf(OSD_ERROR "S_StopEnvSound(): bad voice %d for sound ID %d index %d!\n", g_sounds[num].SoundOwner[j].voice, num, j);
|
initprintf(OSD_ERROR "S_StopEnvSound(): bad voice %d for sound ID %d index %d!\n", g_sounds[num].SoundOwner[j].voice, num, j);
|
||||||
else if (g_sounds[num].SoundOwner[j].voice > FX_Ok && FX_SoundActive(g_sounds[num].SoundOwner[j].voice))
|
else if (g_sounds[num].SoundOwner[j].voice > FX_Ok)
|
||||||
|
{
|
||||||
FX_StopSound(g_sounds[num].SoundOwner[j].voice);
|
FX_StopSound(g_sounds[num].SoundOwner[j].voice);
|
||||||
|
return;
|
||||||
// FX_SoundActive returning false could mean one of two things: we asked to stop the sound
|
}
|
||||||
// right when it was done playing, or we lost track of a voice somewhere (didn't get the callback)
|
|
||||||
// the first scenario resolves itself, and this addresses the second
|
|
||||||
|
|
||||||
mutex_lock(&s_mutex);
|
|
||||||
dq[dnum++] = (num * MAXSOUNDINSTANCES) + j;
|
|
||||||
mutex_unlock(&s_mutex);
|
|
||||||
S_Cleanup();
|
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -883,10 +878,8 @@ void S_ClearSoundLocks(void)
|
||||||
int32_t i;
|
int32_t i;
|
||||||
|
|
||||||
for (i=g_maxSoundPos; i >= 0 ; i--)
|
for (i=g_maxSoundPos; i >= 0 ; i--)
|
||||||
{
|
|
||||||
if (g_soundlocks[i] >= 200)
|
if (g_soundlocks[i] >= 200)
|
||||||
g_soundlocks[i] = 199;
|
g_soundlocks[i] = 199;
|
||||||
}
|
|
||||||
|
|
||||||
for (i=0; i<11; i++)
|
for (i=0; i<11; i++)
|
||||||
if (rts_lumplockbyte[i] >= 200)
|
if (rts_lumplockbyte[i] >= 200)
|
||||||
|
|
Loading…
Reference in a new issue