diff options
Diffstat (limited to 'saga')
-rw-r--r-- | saga/actor.cpp | 11 | ||||
-rw-r--r-- | saga/actor.h | 2 | ||||
-rw-r--r-- | saga/puzzle.cpp | 8 | ||||
-rw-r--r-- | saga/resnames.h | 9 | ||||
-rw-r--r-- | saga/script.h | 2 | ||||
-rw-r--r-- | saga/sthread.cpp | 2 |
6 files changed, 21 insertions, 13 deletions
diff --git a/saga/actor.cpp b/saga/actor.cpp index f0af7df1be..6b029ec47d 100644 --- a/saga/actor.cpp +++ b/saga/actor.cpp @@ -1178,7 +1178,11 @@ void Actor::handleActions(int msec, bool setup) { } -int Actor::direct(int msec) { +void Actor::direct(int msec) { + + if (_vm->_scene->_entryList.entryListCount == 0) { + return; + } // FIXME: HACK. This should be turned into cycle event. _lastTickMsec += msec; @@ -1191,7 +1195,6 @@ int Actor::direct(int msec) { //process speech handleSpeech(msec); - return SUCCESS; } @@ -1315,6 +1318,10 @@ void Actor::drawActors() { return; } + if (_vm->_scene->_entryList.entryListCount == 0) { + return; + } + CommonObjectOrderList::iterator drawOrderIterator; CommonObjectDataPointer drawObject; int frameNumber; diff --git a/saga/actor.h b/saga/actor.h index e1ebbb61cb..2c5ac3cc5a 100644 --- a/saga/actor.h +++ b/saga/actor.h @@ -487,7 +487,7 @@ public: return (objectType == kGameObjectObject) ? getObj(id)->flags : getActor(id)->flags; } - int direct(int msec); + void direct(int msec); void drawActors(); void updateActorsScene(int actorsEntrance); // calls from scene loading to update Actors info diff --git a/saga/puzzle.cpp b/saga/puzzle.cpp index bc3b2fb5e3..6fcfd815fd 100644 --- a/saga/puzzle.cpp +++ b/saga/puzzle.cpp @@ -242,7 +242,7 @@ void Puzzle::exitPuzzle(void) { } void Puzzle::initPieces(void) { - ActorData *puzzle = _vm->_actor->getActor(_vm->_actor->actorIndexToId(RID_ITE_ACTOR_PUZZLE)); + ActorData *puzzle = _vm->_actor->getActor(_vm->_actor->actorIndexToId(ITE_ACTOR_PUZZLE)); SpriteInfo *spI; for (int i = 0; i < PUZZLE_PIECES; i++) { @@ -260,7 +260,7 @@ void Puzzle::initPieces(void) { } void Puzzle::showPieces(void) { - ActorData *puzzle = _vm->_actor->getActor(_vm->_actor->actorIndexToId(RID_ITE_ACTOR_PUZZLE)); + ActorData *puzzle = _vm->_actor->getActor(_vm->_actor->actorIndexToId(ITE_ACTOR_PUZZLE)); SURFACE *backBuffer = _vm->_gfx->getBackBuffer(); for (int j = PUZZLE_PIECES - 1 ; j >= 0; j--) { @@ -273,7 +273,7 @@ void Puzzle::showPieces(void) { } void Puzzle::drawCurrentPiece() { - ActorData *puzzle = _vm->_actor->getActor(_vm->_actor->actorIndexToId(RID_ITE_ACTOR_PUZZLE)); + ActorData *puzzle = _vm->_actor->getActor(_vm->_actor->actorIndexToId(ITE_ACTOR_PUZZLE)); SURFACE *backBuffer = _vm->_gfx->getBackBuffer(); _vm->_sprite->draw(backBuffer, puzzle->spriteList, _puzzlePiece, @@ -402,7 +402,7 @@ void Puzzle::dropPiece(Point mousePt) { // if the center is within the box quantize within // else move it back to its original start point if (mousePt.x >= boxx && mousePt.x < boxw && mousePt.y >= boxy && mousePt.y <= boxh) { - ActorData *puzzle = _vm->_actor->getActor(_vm->_actor->actorIndexToId(RID_ITE_ACTOR_PUZZLE)); + ActorData *puzzle = _vm->_actor->getActor(_vm->_actor->actorIndexToId(ITE_ACTOR_PUZZLE)); SpriteInfo *spI; int newx = mousePt.x - _pieceInfo[_puzzlePiece].offX; int newy = mousePt.y - _pieceInfo[_puzzlePiece].offY; diff --git a/saga/resnames.h b/saga/resnames.h index 17290e97f4..cd362d7ea3 100644 --- a/saga/resnames.h +++ b/saga/resnames.h @@ -43,10 +43,15 @@ namespace Saga { //obj names #define ITE_OBJ_MAP 14 +//actor names +#define ITE_ACTOR_PUZZLE 176 + // SCENES #define ITE_SCENE_INV -1 #define ITE_SCENE_PUZZLE 26 #define ITE_SCENE_LODGE 21 +#define ITE_SCENE_ENDCREDIT1 295 + #define ITE_DEFAULT_SCENE 32 #define IHNM_DEFAULT_SCENE 152 @@ -114,10 +119,6 @@ namespace Saga { #define RID_ITE_INTRO_IMG_3 1561 #define RID_ITE_INTRO_IMG_4 1565 -#define RID_ITE_ENDCREDIT_SCENE_1 1802 - -#define RID_ITE_ACTOR_PUZZLE 176 - // ITE_VOICES #define RID_CAVE_VOICE_0 0 #define RID_CAVE_VOICE_1 1 diff --git a/saga/script.h b/saga/script.h index 722052e32c..5969664be7 100644 --- a/saga/script.h +++ b/saga/script.h @@ -521,7 +521,7 @@ private: void sfScriptClimb(SCRIPTFUNC_PARAMS); void sfSetDoorState(SCRIPTFUNC_PARAMS); void sfSetActorZ(SCRIPTFUNC_PARAMS); - void SF_text(SCRIPTFUNC_PARAMS); + void sfScriptText(SCRIPTFUNC_PARAMS); void sfGetActorX(SCRIPTFUNC_PARAMS); void sfGetActorY(SCRIPTFUNC_PARAMS); void sfEraseDelta(SCRIPTFUNC_PARAMS); diff --git a/saga/sthread.cpp b/saga/sthread.cpp index 42cba6bda6..19cbbdb91f 100644 --- a/saga/sthread.cpp +++ b/saga/sthread.cpp @@ -341,7 +341,7 @@ bool Script::runThread(ScriptThread *thread, uint instructionLimit) { error("Script::runThread() Invalid script function number (%d)", functionNumber); } - debug(8, "Calling 0x%X %s", functionNumber, _scriptFunctionsList[functionNumber].scriptFunctionName); + debug(8, "Calling 0x%X %s argCount=%i", functionNumber, _scriptFunctionsList[functionNumber].scriptFunctionName, argumentsCount); scriptFunction = _scriptFunctionsList[functionNumber].scriptFunction; checkStackTopIndex = thread->_stackTopIndex + argumentsCount; |