X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Fgame_sp%2FDoGameStuff.c;h=d41da8c37157b22de6391797f33366ae4b652282;hb=3b19d917acb541df11a45e0d4b4e40ad4e38a717;hp=27aa1c566c563625b2cb670727fc1a649258440a;hpb=8d3d7d213a9691455a49544624bf380e85f43461;p=rocksndiamonds.git diff --git a/src/game_sp/DoGameStuff.c b/src/game_sp/DoGameStuff.c index 27aa1c56..d41da8c3 100644 --- a/src/game_sp/DoGameStuff.c +++ b/src/game_sp/DoGameStuff.c @@ -25,7 +25,7 @@ int subDoGameStuff() int si, cx, dx, bl; - subAnimateMurphy(MurphyPosIndex); // move Murphy in any direction + subAnimateMurphy(&MurphyPosIndex); // move Murphy in any direction // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - // Build a database of locations and subs-to-call of animatable fields only: @@ -66,16 +66,44 @@ int subDoGameStuff() } // loop locloop_g_22B8 ' until all animatables done } +#if 0 + printf("::: DoGameStuff.c: KillMurphyFlag == %d [%d]\n", + KillMurphyFlag, MurphyMoveCounter); +#endif + // All animations are done now // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - if (KillMurphyFlag == 1 || MurphyMoveCounter == 0) { +#if 1 + if (LeadOutCounter == 0 && !game_sp_info.LevelSolved) +#else if (LeadOutCounter == 0) +#endif { +#if 1 + printf("::: DoGameStuff.c: killing murphy [%d] ...\n", KillMurphyFlag); +#endif + KillMurphyFlag = 0; // no more "kill Murphy" ExplodeFieldSP(MurphyExplodePos); // Explode LeadOutCounter = 0x40; // quit: start lead-out } + +#if 1 + if (KillMurphyFlag == 1 && + !game_sp_info.LevelSolved && + !game_sp_info.GameOver) + { +#if 1 + printf("::: DoGameStuff.c: !!!!!!!!!! GAME OVER !!!!!!!!!!\n"); +#endif + + game_sp_info.GameOver = TRUE; + } +#endif + + } // loc_g_22FB: