mirror of
https://github.com/libretro/scummvm.git
synced 2025-01-05 17:20:30 +00:00
Use souStreamUsed to distinguish between 'stream' and 'streamSou' usage
svn-id: r30257
This commit is contained in:
parent
c9a8d02f6e
commit
8b12998c72
@ -277,7 +277,8 @@ void IMuseDigital::callback() {
|
|||||||
if (track->volGroupId == 3)
|
if (track->volGroupId == 3)
|
||||||
type = Audio::Mixer::kMusicSoundType;
|
type = Audio::Mixer::kMusicSoundType;
|
||||||
|
|
||||||
if (track->stream) {
|
if (!track->souStreamUsed) {
|
||||||
|
assert(track->stream);
|
||||||
byte *tmpSndBufferPtr = NULL;
|
byte *tmpSndBufferPtr = NULL;
|
||||||
int32 curFeedSize = 0;
|
int32 curFeedSize = 0;
|
||||||
|
|
||||||
@ -357,7 +358,8 @@ void IMuseDigital::callback() {
|
|||||||
feedSize -= curFeedSize;
|
feedSize -= curFeedSize;
|
||||||
assert(feedSize >= 0);
|
assert(feedSize >= 0);
|
||||||
} while (feedSize != 0);
|
} while (feedSize != 0);
|
||||||
} else if (track->streamSou) {
|
} else {
|
||||||
|
assert(track->streamSou);
|
||||||
if (_mixer->isReady()) {
|
if (_mixer->isReady()) {
|
||||||
// FIXME: Can't we replace track->mixerStreamRunning by
|
// FIXME: Can't we replace track->mixerStreamRunning by
|
||||||
// _mixer->isSoundHandleActive(track->mixChanHandle) ?
|
// _mixer->isSoundHandleActive(track->mixChanHandle) ?
|
||||||
|
@ -165,7 +165,8 @@ void IMuseDigital::parseScriptCmds(int cmd, int b, int c, int d, int e, int f, i
|
|||||||
|
|
||||||
void IMuseDigital::flushTrack(Track *track) {
|
void IMuseDigital::flushTrack(Track *track) {
|
||||||
track->toBeRemoved = true;
|
track->toBeRemoved = true;
|
||||||
if (track->stream) {
|
if (!track->souStreamUsed) {
|
||||||
|
assert(track->stream);
|
||||||
// Finalize the appendable stream
|
// Finalize the appendable stream
|
||||||
track->stream->finish();
|
track->stream->finish();
|
||||||
// There might still be some data left in the buffers of the
|
// There might still be some data left in the buffers of the
|
||||||
@ -179,7 +180,8 @@ void IMuseDigital::flushTrack(Track *track) {
|
|||||||
track->soundDesc = NULL;
|
track->soundDesc = NULL;
|
||||||
track->used = false;
|
track->used = false;
|
||||||
}
|
}
|
||||||
} else if (track->streamSou) {
|
} else {
|
||||||
|
assert(track->streamSou);
|
||||||
_mixer->stopHandle(track->mixChanHandle);
|
_mixer->stopHandle(track->mixChanHandle);
|
||||||
delete track->streamSou;
|
delete track->streamSou;
|
||||||
track->streamSou = NULL;
|
track->streamSou = NULL;
|
||||||
@ -397,13 +399,15 @@ void IMuseDigital::stopAllSounds() {
|
|||||||
// Stop the sound output, *now*. No need to use toBeRemoved etc.
|
// Stop the sound output, *now*. No need to use toBeRemoved etc.
|
||||||
// as we are protected by a mutex, and this method is never called
|
// as we are protected by a mutex, and this method is never called
|
||||||
// from IMuseDigital::callback either.
|
// from IMuseDigital::callback either.
|
||||||
if (track->stream) {
|
if (!track->souStreamUsed) {
|
||||||
|
assert(track->stream);
|
||||||
_mixer->stopHandle(track->mixChanHandle);
|
_mixer->stopHandle(track->mixChanHandle);
|
||||||
delete track->stream;
|
delete track->stream;
|
||||||
track->stream = NULL;
|
track->stream = NULL;
|
||||||
_sound->closeSound(track->soundDesc);
|
_sound->closeSound(track->soundDesc);
|
||||||
track->soundDesc = NULL;
|
track->soundDesc = NULL;
|
||||||
} else if (track->streamSou) {
|
} else if (track->streamSou) {
|
||||||
|
assert(track->streamSou);
|
||||||
_mixer->stopHandle(track->mixChanHandle);
|
_mixer->stopHandle(track->mixChanHandle);
|
||||||
delete track->streamSou;
|
delete track->streamSou;
|
||||||
track->streamSou = NULL;
|
track->streamSou = NULL;
|
||||||
|
@ -114,13 +114,16 @@ void IMuseDigital::startSound(int soundId, const char *soundName, int soundType,
|
|||||||
|
|
||||||
int bits = 0, freq = 0, channels = 0;
|
int bits = 0, freq = 0, channels = 0;
|
||||||
|
|
||||||
if (input) {
|
track->souStreamUsed = (input != 0);
|
||||||
|
|
||||||
|
if (track->souStreamUsed) {
|
||||||
track->feedSize = 0;
|
track->feedSize = 0;
|
||||||
track->souStreamUsed = true;
|
|
||||||
track->soundName[0] = 0;
|
track->soundName[0] = 0;
|
||||||
track->soundDesc = NULL;
|
track->soundDesc = NULL;
|
||||||
|
track->streamSou = input;
|
||||||
|
track->stream = NULL;
|
||||||
|
track->mixerStreamRunning = false;
|
||||||
} else {
|
} else {
|
||||||
track->souStreamUsed = false;
|
|
||||||
strcpy(track->soundName, soundName);
|
strcpy(track->soundName, soundName);
|
||||||
track->soundDesc = _sound->openSound(soundId, soundName, soundType, volGroupId, -1);
|
track->soundDesc = _sound->openSound(soundId, soundName, soundType, volGroupId, -1);
|
||||||
|
|
||||||
@ -162,13 +165,7 @@ void IMuseDigital::startSound(int soundId, const char *soundName, int soundType,
|
|||||||
if (track->sndDataExtComp)
|
if (track->sndDataExtComp)
|
||||||
track->mixerFlags |= kFlagLittleEndian;
|
track->mixerFlags |= kFlagLittleEndian;
|
||||||
#endif
|
#endif
|
||||||
}
|
|
||||||
|
|
||||||
if (input) {
|
|
||||||
track->streamSou = input;
|
|
||||||
track->stream = NULL;
|
|
||||||
track->mixerStreamRunning = false;
|
|
||||||
} else {
|
|
||||||
const int pan = (track->pan != 64) ? 2 * track->pan - 127 : 0;
|
const int pan = (track->pan != 64) ? 2 * track->pan - 127 : 0;
|
||||||
const int vol = track->vol / 1000;
|
const int vol = track->vol / 1000;
|
||||||
Audio::Mixer::SoundType type = Audio::Mixer::kPlainSoundType;
|
Audio::Mixer::SoundType type = Audio::Mixer::kPlainSoundType;
|
||||||
|
Loading…
Reference in New Issue
Block a user