diff --git a/polymer/eduke32/source/sounds.c b/polymer/eduke32/source/sounds.c index 3d5342d1a..84ba90b64 100644 --- a/polymer/eduke32/source/sounds.c +++ b/polymer/eduke32/source/sounds.c @@ -766,38 +766,47 @@ void S_Pan3D(void) while (j--); } -void S_TestSoundCallback(uint32_t num) -{ - if ((int32_t)num == MUSIC_ID) - return; - - if ((int32_t)num < 0) - { - if (lumplockbyte[-(int32_t)num] >= 200) - lumplockbyte[-(int32_t)num]--; - return; - } - - { - int32_t j = 0; - - while (j < g_sounds[num].num) - { - if (!FX_SoundActive(g_sounds[num].SoundOwner[j].voice)) - { - int32_t i = g_sounds[num].SoundOwner[j].i; - - g_sounds[num].num--; - // OSD_Printf("removing sound %d from spr %d\n",num,i); - if (sprite[i].picnum == MUSICANDSFX && sector[sprite[i].sectnum].lotag < 3 && sprite[i].lotag < 999) - ActorExtra[i].temp_data[0] = 0; - Bmemmove(&g_sounds[num].SoundOwner[j], &g_sounds[num].SoundOwner[j+1], sizeof(SOUNDOWNER) * (SOUNDMAX-j-1)); - break; - } - j++; - } - } - g_soundlocks[num]--; +void S_TestSoundCallback(uint32_t num) +{ + int32_t tempi,tempj,tempk; + + if ((int32_t) num == MUSIC_ID) + { + return; + } + + if((int32_t)num < 0) + { + if(lumplockbyte[-(int32_t)num] >= 200) + lumplockbyte[-(int32_t)num]--; + return; + } + + tempk = g_sounds[num].num; + + if (tempk > 0) + { + if ((g_sounds[num].m&16) == 0) + for (tempj=0; tempj