[Scummvm-git-logs] scummvm master -> 54c57bb23e882f1dcabdc540d4ed59cd8a748673

tag2015 noreply at scummvm.org
Wed Oct 18 23:56:57 UTC 2023


This automated email contains information about 1 new commit which have been
pushed to the 'scummvm' repo located at https://github.com/scummvm/scummvm .

Summary:
54c57bb23e AGS: Fix wrong detection of mod audio and enable IT playback


Commit: 54c57bb23e882f1dcabdc540d4ed59cd8a748673
    https://github.com/scummvm/scummvm/commit/54c57bb23e882f1dcabdc540d4ed59cd8a748673
Author: Walter Agazzi (walter.agazzi at protonmail.com)
Date: 2023-10-19T01:46:08+02:00

Commit Message:
AGS: Fix wrong detection of mod audio and enable IT playback

* Look for file extension inside the filename, instead of the
asset category (and always failing)
* Enable playback of ImpulseTracker streams using mikmod (if available)

Fixes TRAC #14437 and enables music playback in Heatwave and Death
Wore Endless Feathers

Changed paths:
    engines/ags/engine/media/audio/sound.cpp


diff --git a/engines/ags/engine/media/audio/sound.cpp b/engines/ags/engine/media/audio/sound.cpp
index ad53a2d4469..03018e85744 100644
--- a/engines/ags/engine/media/audio/sound.cpp
+++ b/engines/ags/engine/media/audio/sound.cpp
@@ -30,6 +30,7 @@
 #include "ags/engine/media/audio/sound_clip.h"
 #include "ags/engine/media/audio/clip_my_midi.h"
 #include "ags/shared/core/asset_manager.h"
+#include "audio/mods/impulsetracker.h"
 #include "audio/mods/mod_xm_s3m.h"
 #include "audio/mods/protracker.h"
 #include "audio/decoders/mp3.h"
@@ -98,27 +99,31 @@ SOUNDCLIP *my_load_mod(const AssetPath &asset_name, bool loop) {
 	Common::SeekableReadStream *data = _GP(AssetMgr)->OpenAssetStream(asset_name.Name, asset_name.Filter);
 	if (data) {
 		// determine the file extension
-		size_t lastDot = asset_name.Filter.FindCharReverse('.');
-		if (lastDot == AGS::Shared::String::NoIndex || lastDot == asset_name.Filter.GetLength() - 1) {
+		size_t lastDot = asset_name.Name.FindCharReverse('.');
+		if (lastDot == AGS::Shared::String::NoIndex || lastDot == asset_name.Name.GetLength() - 1) {
 			delete data;
 			return nullptr;
 		}
-		// get the first char of the extensin
-		char charAfterDot = toupper(asset_name.Filter[lastDot + 1]);
+		// get the first char of the extension
+		char charAfterDot = toupper(asset_name.Name[lastDot + 1]);
 
 		// use the appropriate loader
 		Audio::AudioStream *audioStream = nullptr;
 		if (charAfterDot == 'I') {
 			// Impulse Tracker
-			warning("Impulse Tracker MOD files not yet supported");
+#ifdef USE_MIKMOD
+			audioStream = Audio::makeImpulseTrackerStream(data, DisposeAfterUse::YES);
+#else
+			warning("MIKMOD support was not compiled in! Skipping Impulse Tracker audio");
+			audioStream = Audio::makeSilentAudioStream(22050, true);
 			delete data;
-			return nullptr;
+#endif
 		} else if (charAfterDot == 'X') {
 			audioStream = Audio::makeModXmS3mStream(data, DisposeAfterUse::YES);
 		} else if (charAfterDot == 'S') {
 			audioStream = Audio::makeModXmS3mStream(data, DisposeAfterUse::YES);
 		} else if (charAfterDot == 'M') {
-			audioStream = Audio::makeProtrackerStream(data, DisposeAfterUse::YES);
+			audioStream = Audio::makeProtrackerStream(data);
 		} else {
 			warning("MOD file format not recognized");
 			delete data;




More information about the Scummvm-git-logs mailing list