aboutsummaryrefslogtreecommitdiff
path: root/engines
diff options
context:
space:
mode:
authorFilippos Karapetis2010-01-04 19:39:33 +0000
committerFilippos Karapetis2010-01-04 19:39:33 +0000
commitb9c8e6edb82ff398ecc699bd964143cd430c9c89 (patch)
treeabf001934fe1fe42acb01d948d240e7dbfd7516f /engines
parent590a687ce14964ab06f34830f2e8f8bfedefbce1 (diff)
downloadscummvm-rg350-b9c8e6edb82ff398ecc699bd964143cd430c9c89.tar.gz
scummvm-rg350-b9c8e6edb82ff398ecc699bd964143cd430c9c89.tar.bz2
scummvm-rg350-b9c8e6edb82ff398ecc699bd964143cd430c9c89.zip
Code optimization: removed unneeded string comparisons when executing a sound command (including cmdUpdateCues, which is executed very often)
svn-id: r46983
Diffstat (limited to 'engines')
-rw-r--r--engines/sci/sfx/soundcmd.cpp16
-rw-r--r--engines/sci/sfx/soundcmd.h1
2 files changed, 7 insertions, 10 deletions
diff --git a/engines/sci/sfx/soundcmd.cpp b/engines/sci/sfx/soundcmd.cpp
index 453ff33757..f42ecc1099 100644
--- a/engines/sci/sfx/soundcmd.cpp
+++ b/engines/sci/sfx/soundcmd.cpp
@@ -154,6 +154,7 @@ SoundCommandParser::SoundCommandParser(ResourceManager *resMan, SegManager *segM
SOUNDCOMMAND(cmdFadeSound);
SOUNDCOMMAND(cmdGetPolyphony);
SOUNDCOMMAND(cmdStopAllSounds);
+ _cmdUpdateCuesIndex = -1;
break;
case SCI_VERSION_1_EARLY:
SOUNDCOMMAND(cmdMasterVolume);
@@ -171,6 +172,7 @@ SoundCommandParser::SoundCommandParser(ResourceManager *resMan, SegManager *segM
SOUNDCOMMAND(cmdSendMidi);
SOUNDCOMMAND(cmdReverb);
SOUNDCOMMAND(cmdSetSoundHold);
+ _cmdUpdateCuesIndex = 11;
break;
case SCI_VERSION_1_LATE:
SOUNDCOMMAND(cmdMasterVolume);
@@ -194,6 +196,7 @@ SoundCommandParser::SoundCommandParser(ResourceManager *resMan, SegManager *segM
SOUNDCOMMAND(cmdSendMidi);
SOUNDCOMMAND(cmdReverb);
SOUNDCOMMAND(cmdUpdateSound);
+ _cmdUpdateCuesIndex = 17;
break;
default:
warning("Sound command parser: unknown sound version %d", _soundVersion);
@@ -212,13 +215,6 @@ reg_t SoundCommandParser::parseCommand(int argc, reg_t *argv, reg_t acc) {
_argc = argc;
_argv = argv;
- // cmdMuteSound and cmdMasterVolume do not operate on an object, but need the number of
- // arguments passed. We load this in the value
- if (!strcmp(_soundCommands[command]->desc, "cmdMuteSound") ||
- !strcmp(_soundCommands[command]->desc, "cmdMasterVolume")) {
- value = argc - 1; // minus the command
- }
-
if (argc == 6) { // cmdSendMidi
byte channel = argv[2].toUint16() & 0xf;
byte midiCmd = argv[3].toUint16() & 0xff;
@@ -230,7 +226,7 @@ reg_t SoundCommandParser::parseCommand(int argc, reg_t *argv, reg_t acc) {
}
if (command < _soundCommands.size()) {
- if (strcmp(_soundCommands[command]->desc, "cmdUpdateCues")) {
+ if (command != _cmdUpdateCuesIndex) {
//printf("%s, object %04x:%04x\n", _soundCommands[command]->desc, PRINT_REG(obj)); // debug
debugC(2, kDebugLevelSound, "%s, object %04x:%04x", _soundCommands[command]->desc, PRINT_REG(obj));
}
@@ -600,7 +596,7 @@ void SoundCommandParser::cmdResumeSound(reg_t obj, int16 value) {
void SoundCommandParser::cmdMuteSound(reg_t obj, int16 value) {
#ifndef USE_OLD_MUSIC_FUNCTIONS
- if (value > 0)
+ if (_argc > 1) // the first parameter is the sound command
_music->soundSetSoundOn(obj.toUint16());
_acc = make_reg(0, _music->soundGetSoundOn());
#endif
@@ -614,7 +610,7 @@ void SoundCommandParser::cmdMasterVolume(reg_t obj, int16 value) {
_acc = make_reg(0, _state->sfx_getVolume());
#else
debugC(2, kDebugLevelSound, "cmdMasterVolume: %d", value);
- if (value > 0)
+ if (_argc > 1) // the first parameter is the sound command
_music->soundSetMasterVolume(obj.toSint16());
_acc = make_reg(0, _music->soundGetMasterVolume());
#endif
diff --git a/engines/sci/sfx/soundcmd.h b/engines/sci/sfx/soundcmd.h
index 20ddc077a3..548dcf3889 100644
--- a/engines/sci/sfx/soundcmd.h
+++ b/engines/sci/sfx/soundcmd.h
@@ -87,6 +87,7 @@ private:
reg_t *_argv; // for cmdFadeSound
uint32 _midiCommand; // for cmdSendMidi
reg_t _acc;
+ int _cmdUpdateCuesIndex;
void cmdInitSound(reg_t obj, int16 value);
void cmdPlaySound(reg_t obj, int16 value);