Some cleanup around S_PlayMusic() and related functionality.

git-svn-id: https://svn.eduke32.com/eduke32@4585 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2014-09-07 18:10:09 +00:00
parent e8f67a9271
commit 5597f3faab
7 changed files with 48 additions and 59 deletions

View file

@ -8750,22 +8750,22 @@ void G_HandleLocalKeys(void)
{ {
if (i == 5 && g_player[myconnectindex].ps->fta > 0 && g_player[myconnectindex].ps->ftq == QUOTE_MUSIC) if (i == 5 && g_player[myconnectindex].ps->fta > 0 && g_player[myconnectindex].ps->ftq == QUOTE_MUSIC)
{ {
i = (VOLUMEALL?MAXVOLUMES*MAXLEVELS:6); i = VOLUMEALL ? MAXVOLUMES*MAXLEVELS : 6;
g_musicIndex = (g_musicIndex+1)%i;
while (MapInfo[g_musicIndex].musicfn == NULL) do
{ {
g_musicIndex++; g_musicIndex++;
if (g_musicIndex >= i) if (g_musicIndex >= i)
g_musicIndex = 0; g_musicIndex = 0;
} }
if (MapInfo[g_musicIndex].musicfn != NULL) while (MapInfo[g_musicIndex].musicfn == NULL);
{
if (S_PlayMusic(&MapInfo[g_musicIndex].musicfn[0],g_musicIndex)) if (S_PlayMusic(MapInfo[g_musicIndex].musicfn, g_musicIndex))
Bsprintf(ScriptQuotes[QUOTE_MUSIC],"Playing %s",&MapInfo[g_musicIndex].alt_musicfn[0]); Bsprintf(ScriptQuotes[QUOTE_MUSIC],"Playing %s", MapInfo[g_musicIndex].alt_musicfn);
else else
Bsprintf(ScriptQuotes[QUOTE_MUSIC],"Playing %s",&MapInfo[g_musicIndex].musicfn[0]); Bsprintf(ScriptQuotes[QUOTE_MUSIC],"Playing %s", MapInfo[g_musicIndex].musicfn);
P_DoQuote(QUOTE_MUSIC,g_player[myconnectindex].ps); P_DoQuote(QUOTE_MUSIC,g_player[myconnectindex].ps);
}
return; return;
} }
@ -9175,7 +9175,7 @@ static void G_ShowDebugHelp(void)
#endif #endif
} }
static char *S_OggifyFilename(char *outputname, char *newname, const char *origname) static char *S_OggifyFilename(char *outputname, const char *newname, const char *origname)
{ {
if (!origname) if (!origname)
return outputname; return outputname;
@ -9192,34 +9192,27 @@ static char *S_OggifyFilename(char *outputname, char *newname, const char *orign
Bstrcat(outputname, origname); Bstrcat(outputname, origname);
} }
#if 0
// XXX: I don't see why we were previously clobbering the extension regardless of what it is.
if ((newname = Bstrchr(outputname, '.')))
Bstrcpy(newname, ".ogg");
else Bstrcat(outputname, ".ogg");
#endif
if (Bstrchr(outputname, '.') == NULL) if (Bstrchr(outputname, '.') == NULL)
Bstrcat(outputname, ".ogg"); Bstrcat(outputname, ".ogg");
return outputname; return outputname;
} }
static int32_t S_DefineSound(int32_t ID,char *name) static int32_t S_DefineSound(int32_t ID, const char *name)
{ {
if (ID >= MAXSOUNDS) if ((unsigned)ID >= MAXSOUNDS)
return 1; return 1;
g_sounds[ID].filename1 = S_OggifyFilename(g_sounds[ID].filename1, name, g_sounds[ID].filename); g_sounds[ID].filename1 = S_OggifyFilename(g_sounds[ID].filename1, name, g_sounds[ID].filename);
// initprintf("(%s)(%s)(%s)\n",g_sounds[ID].filename1,name,g_sounds[ID].filename); // initprintf("(%s)(%s)(%s)\n",g_sounds[ID].filename1,name,g_sounds[ID].filename);
// S_LoadSound(ID); // S_LoadSound(ID);
return 0; return 0;
} }
static int32_t S_DefineMusic(char *ID,char *name) static int32_t S_DefineMusic(const char *ID, const char *name)
{ {
int32_t lev, ep;
int32_t sel = MAXVOLUMES * MAXLEVELS; int32_t sel = MAXVOLUMES * MAXLEVELS;
char b1, b2;
if (!ID) if (!ID)
return 1; return 1;
@ -9240,9 +9233,13 @@ static int32_t S_DefineMusic(char *ID,char *name)
} }
else else
{ {
sscanf(ID,"%c%d%c%d",&b1,&ep,&b2,&lev); int32_t lev, ep;
char b1, b2;
if (Btoupper(b1) != 'E' || Btoupper(b2) != 'L' || --lev >= MAXLEVELS || --ep >= MAXVOLUMES) int32_t matches = sscanf(ID,"%c%d%c%d",&b1,&ep,&b2,&lev);
if (matches != 4 || Btoupper(b1) != 'E' || Btoupper(b2) != 'L' ||
(unsigned)--lev >= MAXLEVELS || (unsigned)--ep >= MAXVOLUMES)
return 1; return 1;
sel = (ep * MAXLEVELS) + lev; sel = (ep * MAXLEVELS) + lev;
@ -9253,6 +9250,7 @@ static int32_t S_DefineMusic(char *ID,char *name)
// initprintf("%-15s | ",ID); // initprintf("%-15s | ",ID);
// initprintf("%3d %2d %2d | %s\n",sel,ep,lev,MapInfo[sel].alt_musicfn); // initprintf("%3d %2d %2d | %s\n",sel,ep,lev,MapInfo[sel].alt_musicfn);
// S_PlayMusic(ID,sel); // S_PlayMusic(ID,sel);
return 0; return 0;
} }
@ -10384,7 +10382,7 @@ static void G_DisplayLogo(void)
if (logoflags & LOGO_PLAYMUSIC) if (logoflags & LOGO_PLAYMUSIC)
{ {
g_musicIndex = -1; // hack g_musicIndex = -1; // hack
S_PlayMusic(&EnvMusicFilename[0][0],MAXVOLUMES*MAXLEVELS); S_PlayMusic(EnvMusicFilename[0], MAXVOLUMES*MAXLEVELS);
} }
if (!NAM) if (!NAM)

View file

@ -2440,14 +2440,7 @@ static void M_MenuEntryLinkActivate(MenuGroup_t *group, MenuEntry_t *entry)
S_ClearSoundLocks(); S_ClearSoundLocks();
if (ud.config.MusicToggle == 1) if (ud.config.MusicToggle == 1)
{ S_RestartMusic();
if (ud.recstat != 2 && g_player[myconnectindex].ps->gm&MODE_GAME)
{
if (MapInfo[g_musicIndex].musicfn != NULL)
S_PlayMusic(&MapInfo[g_musicIndex].musicfn[0],g_musicIndex);
}
else S_PlayMusic(&EnvMusicFilename[0][0],MAXVOLUMES*MAXLEVELS);
}
} }
else if (entry == &ME_COLCORR_RESET) else if (entry == &ME_COLCORR_RESET)
{ {
@ -2562,13 +2555,7 @@ static int32_t M_MenuEntryOptionModify(MenuGroup_t* group, MenuEntry_t *entry, i
S_PauseMusic(1); S_PauseMusic(1);
else else
{ {
if (ud.recstat != 2 && g_player[myconnectindex].ps->gm&MODE_GAME) S_RestartMusic();
{
if (MapInfo[g_musicIndex].musicfn != NULL)
S_PlayMusic(&MapInfo[g_musicIndex].musicfn[0], g_musicIndex);
}
else S_PlayMusic(&EnvMusicFilename[0][0], MAXVOLUMES*MAXLEVELS);
S_PauseMusic(0); S_PauseMusic(0);
} }
} }

View file

@ -379,14 +379,7 @@ static int32_t osdcmd_restartsound(const osdfuncparm_t *parm)
S_ClearSoundLocks(); S_ClearSoundLocks();
if (ud.config.MusicToggle == 1) if (ud.config.MusicToggle == 1)
{ S_RestartMusic();
if (ud.recstat != 2 && g_player[myconnectindex].ps->gm&MODE_GAME)
{
if (MapInfo[g_musicIndex].musicfn != NULL)
S_PlayMusic(&MapInfo[g_musicIndex].musicfn[0],g_musicIndex);
}
else S_PlayMusic(&EnvMusicFilename[0][0],MAXVOLUMES*MAXLEVELS);
}
return OSDCMD_OK; return OSDCMD_OK;
} }

View file

@ -439,7 +439,7 @@ void G_CacheMapData(void)
if (MapInfo[MAXVOLUMES*MAXLEVELS+2].alt_musicfn) if (MapInfo[MAXVOLUMES*MAXLEVELS+2].alt_musicfn)
{ {
S_StopMusic(); S_StopMusic();
S_PlayMusic(&EnvMusicFilename[2][0],MAXVOLUMES*MAXLEVELS+2); // loadmus S_PlayMusic(EnvMusicFilename[2], MAXVOLUMES*MAXLEVELS+2); // loadmus
} }
starttime = getticks(); starttime = getticks();
@ -1382,7 +1382,7 @@ void G_NewGame(int32_t vn, int32_t ln, int32_t sk)
if (ln == 0 && vn == 3 && (!g_netServer && ud.multimode < 2) && ud.lockout == 0 if (ln == 0 && vn == 3 && (!g_netServer && ud.multimode < 2) && ud.lockout == 0
&& (G_GetLogoFlags() & LOGO_NOE4CUTSCENE)==0) && (G_GetLogoFlags() & LOGO_NOE4CUTSCENE)==0)
{ {
S_PlayMusic(&EnvMusicFilename[1][0],MAXVOLUMES*MAXLEVELS+1); S_PlayMusic(EnvMusicFilename[1], MAXVOLUMES*MAXLEVELS+1);
flushperms(); flushperms();
setview(0,0,xdim-1,ydim-1); setview(0,0,xdim-1,ydim-1);

View file

@ -1957,7 +1957,7 @@ static void postloadplayer(int32_t savegamep)
(i != g_musicIndex || MapInfo[MAXVOLUMES*MAXLEVELS+2].alt_musicfn)) (i != g_musicIndex || MapInfo[MAXVOLUMES*MAXLEVELS+2].alt_musicfn))
{ {
S_StopMusic(); S_StopMusic();
S_PlayMusic(&MapInfo[g_musicIndex].musicfn[0], g_musicIndex); S_PlayMusic(MapInfo[g_musicIndex].musicfn, g_musicIndex);
} }
S_PauseMusic(0); S_PauseMusic(0);

View file

@ -166,6 +166,16 @@ void S_MusicVolume(int32_t volume)
MUSIC_SetVolume(volume); MUSIC_SetVolume(volume);
} }
void S_RestartMusic(void)
{
if (ud.recstat != 2 && g_player[myconnectindex].ps->gm&MODE_GAME)
{
if (MapInfo[g_musicIndex].musicfn != NULL)
S_PlayMusic(MapInfo[g_musicIndex].musicfn, g_musicIndex);
}
else S_PlayMusic(EnvMusicFilename[0], MAXVOLUMES*MAXLEVELS);
}
void S_MenuSound(void) void S_MenuSound(void)
{ {
static int32_t SoundNum=0; static int32_t SoundNum=0;
@ -195,7 +205,8 @@ void S_MenuSound(void)
int32_t S_PlayMusic(const char *fn, const int32_t sel) int32_t S_PlayMusic(const char *fn, const int32_t sel)
{ {
char *ofn = (char *)fn, *testfn, *extension; const char *const ofn = fn;
char *testfn, *extension;
int32_t fp, MusicLen; int32_t fp, MusicLen;
const char *alt = 0; const char *alt = 0;
@ -216,15 +227,14 @@ int32_t S_PlayMusic(const char *fn, const int32_t sel)
// we've been asked to load a .mid file, but first let's see // we've been asked to load a .mid file, but first let's see
// if there's a flac or an ogg with the same base name lying around // if there's a flac or an ogg with the same base name lying around
strcpy(extension, ".flac"); strcpy(extension, ".flac");
extension[5] = '\0';
fp = kopen4loadfrommod(testfn, 0); fp = kopen4loadfrommod(testfn, 0);
if (fp >= 0) if (fp >= 0)
{ {
Bfree(testfn); Bfree(testfn);
break; break;
} }
strcpy(extension, ".ogg"); strcpy(extension, ".ogg");
extension[4] = '\0';
fp = kopen4loadfrommod(testfn, 0); fp = kopen4loadfrommod(testfn, 0);
if (fp >= 0) if (fp >= 0)
{ {
@ -236,7 +246,7 @@ int32_t S_PlayMusic(const char *fn, const int32_t sel)
Bfree(testfn); Bfree(testfn);
// just use what we've been given // just use what we've been given
fp = kopen4loadfrommod((char *)fn, 0); fp = kopen4loadfrommod(fn, 0);
if (alt && fp < 0) if (alt && fp < 0)
fp = kopen4loadfrommod(ofn, 0); fp = kopen4loadfrommod(ofn, 0);

View file

@ -89,6 +89,7 @@ void S_MenuSound(void);
void S_MusicShutdown(void); void S_MusicShutdown(void);
void S_MusicStartup(void); void S_MusicStartup(void);
void S_MusicVolume(int32_t volume); void S_MusicVolume(int32_t volume);
void S_RestartMusic(void);
void S_PauseMusic(int32_t onf); void S_PauseMusic(int32_t onf);
int32_t S_PlayMusic(const char *fn,const int32_t sel); int32_t S_PlayMusic(const char *fn,const int32_t sel);
int32_t S_PlaySound(int32_t num); int32_t S_PlaySound(int32_t num);