bill@newbreedsoftware.com
http://www.newbreedsoftware.com/supertux/
- April 11, 2000 - December 9, 2003
+ April 11, 2000 - December 28, 2003
*/
#include <stdio.h>
#include "setup.h"
#include "high_scores.h"
#include "menu.h"
-
+#include "badguy.h"
+#include "world.h"
+#include "player.h"
/* Sound files: */
floating_score_type floating_scores[NUM_FLOATING_SCORES];
upgrade_type upgrades[NUM_UPGRADES];
bullet_type bullets[NUM_BULLETS];
-char song_title[20];
-char levelname[20];
-char leveltheme[20];
-char str[10];
+char song_title[60];
+char levelname[60];
+char leveltheme[60];
+char str[60];
+
/* Local function prototypes: */
game_pause = 1;
}
}
- else if (key == SDLK_TAB)
+ else if (key == SDLK_TAB && debug_mode == YES)
{
tux_size = !tux_size;
}
- else if (key == SDLK_END)
+ else if (key == SDLK_END && debug_mode == YES)
{
distros += 50;
}
- else if (key == SDLK_SPACE)
+ else if (key == SDLK_SPACE && debug_mode == YES)
{
next_level = 1;
}
/* Keep tux in bounds: */
-
if (tux_x < 0)
tux_x = 0;
- else if (tux_x > 320 && scroll_x < ((level_width * 32) - 640))
+ else if (tux_x < 160 && scroll_x > 0 && debug_mode == YES)
+ {
+ scroll_x = scroll_x - ( 160 - tux_x);
+ tux_x = 160;
+
+ if(scroll_x < 0)
+ scroll_x = 0;
+
+ }
+ else if (tux_x > 320 && scroll_x < ((level_width * 32) - 640))
{
/* Scroll the screen in past center: */
current_music = LEVEL_MUSIC;
halt_music();
}
+
if (!playing_music())
- play_music( level_song, 1 );
+ {
+ if (time_left <= TIME_WARNING)
+ play_music( level_song_fast, 1 );
+ else
+ play_music( level_song, 1 );
+ }
+
if (tux_invincible_time > 0)
tux_invincible_time--;
}
drawtext("HIGH", 0, 20, letters_blue, NO_UPDATE);
drawtext(str, 96, 20, letters_gold, NO_UPDATE);
- if (time_left >= 50 || (frame % 10) < 5)
+ if (time_left >= TIME_WARNING || (frame % 10) < 5)
{
sprintf(str, "%d", time_left);
drawtext("TIME", 224, 0, letters_blue, NO_UPDATE);
{
drawimage(tux_life,565+(18*i),20,NO_UPDATE);
}
- /*drawtext(str, 608, 0, letters_gold, NO_UPDATE);*/
-
+
if(game_pause)
drawcenteredtext("PAUSE",230,letters_red, NO_UPDATE);
switch (current_music)
{
case LEVEL_MUSIC:
- play_music(level_song, 1);
+ if (time_left <= TIME_WARNING)
+ play_music(level_song_fast, 1);
+ else
+ play_music(level_song, 1);
break;
case HERRING_MUSIC:
play_music(herring_song, 1);
now_time = SDL_GetTicks();
if (now_time < last_time + FPS)
- SDL_Delay(last_time + FPS - now_time);
+ SDL_Delay(last_time + FPS - now_time);
/* Handle time: */
{
time_left--;
+ /* Stop the music; it will start again, faster! */
+ if (time_left == TIME_WARNING)
+ halt_music();
+
if (time_left <= 0)
killtux(KILL);
}
time_left = atoi(str);
/* (Song file for this level) */
- fgets(str, 20, fi);
+ fgets(str, sizeof(song_title), fi);
strcpy(song_title, str);
song_title[strlen(song_title)-1] = '\0';
{
char * song_path;
+ char * song_subtitle;
song_path = (char *) malloc(sizeof(char) * (strlen(DATA_PREFIX) +
strlen(song_title) + 8));
-
sprintf(song_path, "%s/music/%s", DATA_PREFIX, song_title);
-
level_song = load_song(song_path);
+ free(song_path);
+
+ song_path = (char *) malloc(sizeof(char) * (strlen(DATA_PREFIX) +
+ strlen(song_title) + 8 + 5));
+ song_subtitle = strdup(song_title);
+ strcpy(strstr(song_subtitle, "."), "\0");
+ sprintf(song_path, "%s/music/%s-fast%s", DATA_PREFIX, song_subtitle, strstr(song_title, "."));
+ level_song_fast = load_song(song_path);
+ free(song_subtitle);
free(song_path);
}
/* Sound effects: */
- /* if (use_sound) // this can help speeding up a little, but
- we shouldn't take care about "use_sound" here, it's load_sound's job
- / Send a mail to neoneurone@users.sf.net, if you have another opinion. :)
- */
+ /* if (use_sound) // this will introduce SERIOUS bugs here ! because "load_sound"
+ // initialize sounds[i] with the correct pointer's value:
+ // NULL or something else. And it will be dangerous to
+ // play with not-initialized pointers.
+ // This is also true with if (use_music)
+ Send a mail to me: neoneurone@users.sf.net, if you have another opinion. :)
+ */
for (i = 0; i < NUM_SOUNDS; i++)
sounds[i] = load_sound(soundfilenames[i]);