+#else
+ return FALSE;
+#endif
+}
+
+int LoadMusic(void)
+{
+ DIR *dir;
+ struct dirent *dir_entry;
+ char *music_directory = getPath2(options.ro_base_directory, MUSIC_DIRECTORY);
+ int num_wav_music = 0;
+ int num_mod_music = 0;
+
+ if ((dir = opendir(music_directory)) == NULL)
+ {
+ Error(ERR_WARN, "cannot read music directory '%s'", music_directory);
+ audio.music_available = FALSE;
+ free(music_directory);
+ return 0;
+ }
+
+ while ((dir_entry = readdir(dir)) != NULL) /* loop until last dir entry */
+ {
+ char *filename = dir_entry->d_name;
+
+ if (strlen(filename) > 4 &&
+ strcmp(&filename[strlen(filename) - 4], ".wav") == 0)
+ {
+ if (LoadSoundExt(filename, TRUE))
+ num_wav_music++;
+ }
+ else if (strlen(filename) > 4 &&
+ (strcmp(&filename[strlen(filename) - 4], ".mod") == 0 ||
+ strcmp(&filename[strlen(filename) - 4], ".MOD") == 0 ||
+ strncmp(filename, "mod.", 4) == 0 ||
+ strncmp(filename, "MOD.", 4) == 0))
+ {
+ if (LoadMod(filename))
+ num_mod_music++;
+ }
+ }
+
+ closedir(dir);
+
+ if (num_wav_music == 0 && num_mod_music == 0)
+ Error(ERR_WARN, "cannot find any valid music files in directory '%s'",
+ music_directory);
+
+ free(music_directory);
+
+ num_music = (num_mod_music > 0 ? num_mod_music : num_wav_music);
+
+ audio.mods_available = (num_mod_music > 0);
+ audio.music_available = (num_music > 0);
+
+ return num_music;
+}
+
+void PlayMusic(int nr)
+{
+ if (!audio.music_available)
+ return;
+
+ if (!audio.mods_available)
+ nr = num_sounds - num_music + nr;
+
+#if defined(TARGET_SDL)
+ if (audio.mods_available) /* play MOD music */
+ {
+ Mix_VolumeMusic(SOUND_MAX_VOLUME);
+ Mix_PlayMusic(Mod[nr].mix_music, -1);
+ }
+ else /* play WAV music loop */
+ {
+ Mix_Volume(audio.music_channel, SOUND_MAX_VOLUME);
+ Mix_PlayChannel(audio.music_channel, Sound[nr].mix_chunk, -1);
+ }
+#else
+ audio.music_nr = nr;
+ PlaySoundLoop(nr);
+#endif