diff options
author | Paul Gilbert | 2017-09-24 10:48:04 -0400 |
---|---|---|
committer | Paul Gilbert | 2017-09-24 10:48:04 -0400 |
commit | 947894ce1f71c12cc904b1c2fd82aa827df8574f (patch) | |
tree | 9bda091aea8344d5975a0d744bf192c90e412109 | |
parent | b724ea65301ff2259e1638426da99c94a9966d65 (diff) | |
download | scummvm-rg350-947894ce1f71c12cc904b1c2fd82aa827df8574f.tar.gz scummvm-rg350-947894ce1f71c12cc904b1c2fd82aa827df8574f.tar.bz2 scummvm-rg350-947894ce1f71c12cc904b1c2fd82aa827df8574f.zip |
TITANIC: Free any active wave files on exit
-rw-r--r-- | engines/titanic/sound/qmixer.cpp | 9 | ||||
-rw-r--r-- | engines/titanic/sound/qmixer.h | 3 |
2 files changed, 11 insertions, 1 deletions
diff --git a/engines/titanic/sound/qmixer.cpp b/engines/titanic/sound/qmixer.cpp index a3c06da2f8..a1091a9763 100644 --- a/engines/titanic/sound/qmixer.cpp +++ b/engines/titanic/sound/qmixer.cpp @@ -29,6 +29,10 @@ namespace Titanic { QMixer::QMixer(Audio::Mixer *mixer) : _mixer(mixer) { } +QMixer::~QMixer() { + _channels.clear(); +} + bool QMixer::qsWaveMixInitEx(const QMIXCONFIG &config) { assert(_channels.empty()); assert(config.iChannels > 0 && config.iChannels < 256); @@ -237,6 +241,11 @@ void QMixer::qsWaveMixPump() { /*------------------------------------------------------------------------*/ +QMixer::ChannelEntry::~ChannelEntry() { + for (Common::List<SoundEntry>::iterator i = _sounds.begin(); i != _sounds.end(); ++i) + delete (*i)._waveFile; +} + byte QMixer::ChannelEntry::getRawVolume() const { // Emperically decided adjustment divisor for distances const double ADJUSTMENT_FACTOR = 5.0; diff --git a/engines/titanic/sound/qmixer.h b/engines/titanic/sound/qmixer.h index 17ca441e83..c6d7fcd520 100644 --- a/engines/titanic/sound/qmixer.h +++ b/engines/titanic/sound/qmixer.h @@ -204,6 +204,7 @@ class QMixer { ChannelEntry() : _volume(0), _panRate(0), _volumeChangeStart(0), _volumeChangeEnd(0), _volumeStart(0), _volumeEnd(0), _distance(0.0), _resetDistance(true) {} + ~ChannelEntry(); /** * Calculates the raw volume level to pass to ScummVM playStream, taking @@ -217,7 +218,7 @@ protected: Audio::Mixer *_mixer; public: QMixer(Audio::Mixer *mixer); - virtual ~QMixer() {} + virtual ~QMixer(); /** * Initializes the mixer |