boolean level_editor_test_game = FALSE;
boolean network_playing = FALSE;
+#if defined(TARGET_SDL)
+boolean network_server = FALSE;
+SDL_Thread *server_thread;
+#endif
+
int key_joystick_mapping = 0;
boolean redraw[MAX_BUF_XSIZE][MAX_BUF_YSIZE];
unsigned long ChangeEvent[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
short WasJustMoving[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
short WasJustFalling[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
+short CheckCollision[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
short AmoebaNr[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
short AmoebaCnt[MAX_NUM_AMOEBA];
short AmoebaCnt2[MAX_NUM_AMOEBA];
-short ExplodePhase[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
short ExplodeField[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
+short ExplodePhase[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
+short ExplodeDelay[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
+int RunnerVisit[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
+int PlayerVisit[MAX_LEV_FIELDX][MAX_LEV_FIELDY];
unsigned long Properties[MAX_NUM_ELEMENTS][NUM_EP_BITFIELDS];
int ExitX, ExitY;
int AllPlayersGone;
-int TimeFrames, TimePlayed, TimeLeft;
+int TimeFrames, TimePlayed, TimeLeft, TapeTime;
boolean network_player_action_received = FALSE;
struct SoundInfo *sound_info = NULL;
struct MusicInfo *music_info = NULL;
struct MusicFileInfo *music_file_info = NULL;
-struct InfoAnimationInfo *info_animation_info = NULL;
+struct HelpAnimInfo *helpanim_info = NULL;
+SetupFileHash *helptext_info = NULL;
/* ------------------------------------------------------------------------- */
/* element definitions */
/* ------------------------------------------------------------------------- */
-struct ElementInfo element_info[MAX_NUM_ELEMENTS + 1] =
+struct ElementInfo element_info[MAX_NUM_ELEMENTS + 1];
+
+/* this contains predefined structure elements to initialize "element_info" */
+struct ElementNameInfo element_name_info[MAX_NUM_ELEMENTS + 1] =
{
/* keyword to start parser: "ELEMENT_INFO_START" <-- do not change! */
"invisible steel wall"
},
{
- "unused_63",
- "unused",
- "(not used)"
+ "sokoban_field_player",
+ "sokoban",
+ "sokoban field with player"
},
{
"dynabomb_increase_number",
{
"black_orb",
"black_orb",
- "bomb"
+ "black orb bomb"
},
{
"amoeba_to_diamond",
"envelope",
"mail envelope 4"
},
+ {
+ "group_1",
+ "group",
+ "group element 1"
+ },
+ {
+ "group_2",
+ "group",
+ "group element 2"
+ },
+ {
+ "group_3",
+ "group",
+ "group element 3"
+ },
+ {
+ "group_4",
+ "group",
+ "group element 4"
+ },
+ {
+ "group_5",
+ "group",
+ "group element 5"
+ },
+ {
+ "group_6",
+ "group",
+ "group element 6"
+ },
+ {
+ "group_7",
+ "group",
+ "group element 7"
+ },
+ {
+ "group_8",
+ "group",
+ "group element 8"
+ },
+ {
+ "group_9",
+ "group",
+ "group element 9"
+ },
+ {
+ "group_10",
+ "group",
+ "group element 10"
+ },
+ {
+ "group_11",
+ "group",
+ "group element 11"
+ },
+ {
+ "group_12",
+ "group",
+ "group element 12"
+ },
+ {
+ "group_13",
+ "group",
+ "group element 13"
+ },
+ {
+ "group_14",
+ "group",
+ "group element 14"
+ },
+ {
+ "group_15",
+ "group",
+ "group element 15"
+ },
+ {
+ "group_16",
+ "group",
+ "group element 16"
+ },
+ {
+ "group_17",
+ "group",
+ "group element 17"
+ },
+ {
+ "group_18",
+ "group",
+ "group element 18"
+ },
+ {
+ "group_19",
+ "group",
+ "group element 19"
+ },
+ {
+ "group_20",
+ "group",
+ "group element 20"
+ },
+ {
+ "group_21",
+ "group",
+ "group element 21"
+ },
+ {
+ "group_22",
+ "group",
+ "group element 22"
+ },
+ {
+ "group_23",
+ "group",
+ "group element 23"
+ },
+ {
+ "group_24",
+ "group",
+ "group element 24"
+ },
+ {
+ "group_25",
+ "group",
+ "group element 25"
+ },
+ {
+ "group_26",
+ "group",
+ "group element 26"
+ },
+ {
+ "group_27",
+ "group",
+ "group element 27"
+ },
+ {
+ "group_28",
+ "group",
+ "group element 28"
+ },
+ {
+ "group_29",
+ "group",
+ "group element 29"
+ },
+ {
+ "group_30",
+ "group",
+ "group element 30"
+ },
+ {
+ "group_31",
+ "group",
+ "group element 31"
+ },
+ {
+ "group_32",
+ "group",
+ "group element 32"
+ },
+ {
+ "unknown",
+ "unknown",
+ "unknown element"
+ },
+ {
+ "trigger_element",
+ "trigger",
+ "element triggering change"
+ },
+ {
+ "trigger_player",
+ "trigger",
+ "player triggering change"
+ },
+ {
+ "sp_gravity_on_port_right",
+ "sp_port",
+ "gravity on port (leading right)"
+ },
+ {
+ "sp_gravity_on_port_down",
+ "sp_port",
+ "gravity on port (leading down)"
+ },
+ {
+ "sp_gravity_on_port_left",
+ "sp_port",
+ "gravity on port (leading left)"
+ },
+ {
+ "sp_gravity_on_port_up",
+ "sp_port",
+ "gravity on port (leading up)"
+ },
+ {
+ "sp_gravity_off_port_right",
+ "sp_port",
+ "gravity off port (leading right)"
+ },
+ {
+ "sp_gravity_off_port_down",
+ "sp_port",
+ "gravity off port (leading down)"
+ },
+ {
+ "sp_gravity_off_port_left",
+ "sp_port",
+ "gravity off port (leading left)"
+ },
+ {
+ "sp_gravity_off_port_up",
+ "sp_port",
+ "gravity off port (leading up)"
+ },
+ {
+ "balloon_switch_none",
+ "balloon_switch",
+ "stop moving balloon"
+ },
+ {
+ "emc_level_border",
+ "wall",
+ "level border steelwall",
+ },
+ {
+ "emc_android",
+ "emc_android",
+ "android",
+ },
+ {
+ "emc_android_right",
+ "emc_android",
+ "android",
+ },
+ {
+ "emc_android_up",
+ "emc_android",
+ "android",
+ },
+ {
+ "emc_android_left",
+ "emc_android",
+ "android",
+ },
+ {
+ "emc_android_down",
+ "emc_android",
+ "android",
+ },
+ {
+ "emc_android_left_up",
+ "emc_android",
+ "android",
+ },
+ {
+ "emc_android_left_down",
+ "emc_android",
+ "android",
+ },
+ {
+ "emc_android_right_up",
+ "emc_android",
+ "android",
+ },
+ {
+ "emc_android_right_down",
+ "emc_android",
+ "android",
+ },
+ {
+ "emc_grass",
+ "emc_grass",
+ "grass",
+ },
+ {
+ "emc_generator_ball",
+ "emc_generator_ball",
+ "generator ball",
+ },
+ {
+ "emc_gate_1",
+ "gate",
+ "door 1 (EMC style)",
+ },
+ {
+ "emc_gate_2",
+ "gate",
+ "door 2 (EMC style)",
+ },
+ {
+ "emc_gate_3",
+ "gate",
+ "door 3 (EMC style)",
+ },
+ {
+ "emc_gate_4",
+ "gate",
+ "door 4 (EMC style)",
+ },
+ {
+ "emc_gate_5",
+ "gate",
+ "door 5 (EMC style)",
+ },
+ {
+ "emc_gate_6",
+ "gate",
+ "door 6 (EMC style)",
+ },
+ {
+ "emc_gate_7",
+ "gate",
+ "door 7 (EMC style)",
+ },
+ {
+ "emc_gate_8",
+ "gate",
+ "door 8 (EMC style)",
+ },
+ {
+ "emc_gate_1_gray",
+ "gate",
+ "gray door (EMC style, key 1)",
+ },
+ {
+ "emc_gate_2_gray",
+ "gate",
+ "gray door (EMC style, key 2)",
+ },
+ {
+ "emc_gate_3_gray",
+ "gate",
+ "gray door (EMC style, key 3)",
+ },
+ {
+ "emc_gate_4_gray",
+ "gate",
+ "gray door (EMC style, key 4)",
+ },
+ {
+ "emc_gate_5_gray",
+ "gate",
+ "gray door (EMC style, key 5)",
+ },
+ {
+ "emc_gate_6_gray",
+ "gate",
+ "gray door (EMC style, key 6)",
+ },
+ {
+ "emc_gate_7_gray",
+ "gate",
+ "gray door (EMC style, key 7)",
+ },
+ {
+ "emc_gate_8_gray",
+ "gate",
+ "gray door (EMC style, key 8)",
+ },
+ {
+ "emc_key_1",
+ "key",
+ "key 1 (EMC style)",
+ },
+ {
+ "emc_key_2",
+ "key",
+ "key 2 (EMC style)",
+ },
+ {
+ "emc_key_3",
+ "key",
+ "key 3 (EMC style)",
+ },
+ {
+ "emc_key_4",
+ "key",
+ "key 4 (EMC style)",
+ },
+ {
+ "emc_key_5",
+ "key",
+ "key 5 (EMC style)",
+ },
+ {
+ "emc_key_6",
+ "key",
+ "key 6 (EMC style)",
+ },
+ {
+ "emc_key_7",
+ "key",
+ "key 7 (EMC style)",
+ },
+ {
+ "emc_key_8",
+ "key",
+ "key 8 (EMC style)",
+ },
+ {
+ "emc_bumper",
+ "emc_bumper",
+ "bumper",
+ },
+ {
+ "emc_plant",
+ "emc_plant",
+ "plant",
+ },
+ {
+ "emc_lenses",
+ "emc_lenses",
+ "lenses",
+ },
+ {
+ "emc_magnifier",
+ "emc_magnifier",
+ "magnifier",
+ },
/* ----------------------------------------------------------------------- */
/* "real" (and therefore drawable) runtime elements */
"-",
"-"
},
+ {
+ "player_is_exploding_1",
+ "-",
+ "-"
+ },
+ {
+ "player_is_exploding_2",
+ "-",
+ "-"
+ },
+ {
+ "player_is_exploding_3",
+ "-",
+ "-"
+ },
+ {
+ "player_is_exploding_4",
+ "-",
+ "-"
+ },
{
"quicksand.filling",
"quicksand",
"-"
},
{
- "dummy",
- "dummy",
+ "internal_clipboard_custom",
+ "internal",
+ "empty custom element"
+ },
+ {
+ "internal_clipboard_change",
+ "internal",
+ "empty change page"
+ },
+ {
+ "internal_clipboard_group",
+ "internal",
+ "empty group element"
+ },
+ {
+ "internal_dummy",
+ "internal",
"-"
},
{ ".boring[6]", ACTION_BORING_6, FALSE },
{ ".boring[7]", ACTION_BORING_7, FALSE },
{ ".boring[8]", ACTION_BORING_8, FALSE },
+ { ".boring[9]", ACTION_BORING_9, FALSE },
+ { ".boring[10]", ACTION_BORING_10, FALSE },
{ ".sleeping", ACTION_SLEEPING, FALSE },
{ ".sleeping[1]", ACTION_SLEEPING_1, FALSE },
{ ".sleeping[2]", ACTION_SLEEPING_2, FALSE },
{ ".sleeping[3]", ACTION_SLEEPING_3, FALSE },
+ { ".awakening", ACTION_AWAKENING, FALSE },
{ ".dying", ACTION_DYING, FALSE },
{ ".turning", ACTION_TURNING, FALSE },
{ ".turning_from_left", ACTION_TURNING_FROM_LEFT, FALSE },
" --serveronly only start network server\n"
" -v, --verbose verbose mode\n"
" --debug display debugging information\n"
- " -e, --execute COMMAND execute batch COMMAND:\n"
+ " -e, --execute COMMAND execute batch COMMAND\n"
"\n"
"Valid commands for '--execute' option:\n"
" \"print graphicsinfo.conf\" print default graphics config\n"
" \"print soundsinfo.conf\" print default sounds config\n"
" \"print musicinfo.conf\" print default music config\n"
" \"print editorsetup.conf\" print default editor config\n"
+ " \"print helpanim.conf\" print default helpanim config\n"
+ " \"print helptext.conf\" print default helptext config\n"
" \"dump level FILE\" dump level data from FILE\n"
" \"dump tape FILE\" dump tape data from FILE\n"
- " \"autoplay LEVELDIR\" play level tapes for LEVELDIR\n"
+ " \"autoplay LEVELDIR [NR]\" play level tapes for LEVELDIR\n"
+ " \"convert LEVELDIR [NR]\" convert levels in LEVELDIR\n"
"\n",
program.command_basename);
}