X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Flibgame%2Ftoons.c;h=01229f019b0b7285fe295fdc135bce184504246a;hb=4bd981e9a75290ad6178c167ce8e02635ca7fa53;hp=c8c71e3a96c6f7ac6323ae12dea69b10c1197a75;hpb=29fc833ae1b5e46a429a9fa82098e8ad94f6f400;p=rocksndiamonds.git diff --git a/src/libgame/toons.c b/src/libgame/toons.c index c8c71e3a..01229f01 100644 --- a/src/libgame/toons.c +++ b/src/libgame/toons.c @@ -64,10 +64,10 @@ int getAnimationFrame(int num_frames, int delay, int mode, int start_frame, { /* note: expect different frames for the same delay cycle! */ - if (anim.random_frame < 0) + if (gfx.anim_random_frame < 0) frame = SimpleRND(num_frames); else - frame = anim.random_frame % num_frames; + frame = gfx.anim_random_frame % num_frames; } if (mode & ANIM_REVERSE) /* use reverse animation direction */ @@ -85,6 +85,7 @@ static int get_toon_direction(char *direction_raw) { static char *direction = NULL; + /* !!! MEMORY LEAK HERE! FIX IT! !!! */ setString(&direction, getStringToLower(direction_raw)); return (strcmp(direction, "left") == 0 ? MV_LEFT : @@ -317,6 +318,10 @@ void HandleAnimation(int mode) if (!setup.toons) return; + /* this may happen after reloading graphics and redefining "num_toons" */ + if (toon_nr >= screen_info.num_toons) + anim_restart = TRUE; + switch(mode) { case ANIM_START: @@ -359,7 +364,7 @@ void HandleAnimation(int mode) toon_nr = SimpleRND(screen_info.num_toons); } - anim_restart = reset_delay = AnimateToon(toon_nr,anim_restart); + anim_restart = reset_delay = AnimateToon(toon_nr, anim_restart); } void InitAnimation()