[Scummvm-cvs-logs] CVS: scummvm/scumm/imuse_digi dimuse_track.cpp,1.36,1.37
Max Horn
fingolfin at users.sourceforge.net
Wed Nov 24 06:40:01 CET 2004
Update of /cvsroot/scummvm/scummvm/scumm/imuse_digi
In directory sc8-pr-cvs1.sourceforge.net:/tmp/cvs-serv30016
Modified Files:
dimuse_track.cpp
Log Message:
(Partial) fix for bug #1035690 (COMI: cannon shooting uses a lot of performance) -- remember, busy waiting is almost always bad, esp. when waiting for another thread...
Index: dimuse_track.cpp
===================================================================
RCS file: /cvsroot/scummvm/scummvm/scumm/imuse_digi/dimuse_track.cpp,v
retrieving revision 1.36
retrieving revision 1.37
diff -u -d -r1.36 -r1.37
--- dimuse_track.cpp 24 Nov 2004 09:47:32 -0000 1.36
+++ dimuse_track.cpp 24 Nov 2004 10:00:02 -0000 1.37
@@ -77,10 +77,12 @@
Track *track = _track[l];
while (track->used) {
-#if defined(_WIN32_WCE) || defined (__PALM_OS__)
- _vm->parseEvents(); // timers are events, we need to consume them
-#endif
+ // The designated track is not yet available. So, we call flushTracks()
+ // to get it processed (and thus made ready for us). Since the actual
+ // processing is done by another thread, we also call parseEvents to
+ // give it some time (and to avoid busy waiting/looping).
flushTracks();
+ _vm->parseEvents();
}
track->pan = 64;
More information about the Scummvm-git-logs
mailing list