projects
/
rocksndiamonds.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
rnd-20061014-2-src
[rocksndiamonds.git]
/
src
/
game.h
diff --git
a/src/game.h
b/src/game.h
index dadb6735f86859b5aaa45d834090444c74254c80..4532367944b698fb9d1a4396eece66ef9c15d58d 100644
(file)
--- a/
src/game.h
+++ b/
src/game.h
@@
-1,7
+1,7
@@
/***********************************************************
* Rocks'n'Diamonds -- McDuffin Strikes Back! *
*----------------------------------------------------------*
/***********************************************************
* Rocks'n'Diamonds -- McDuffin Strikes Back! *
*----------------------------------------------------------*
-* (c) 1995-200
2
Artsoft Entertainment *
+* (c) 1995-200
6
Artsoft Entertainment *
* Holger Schemel *
* Detmolder Strasse 189 *
* 33604 Bielefeld *
* Holger Schemel *
* Detmolder Strasse 189 *
* 33604 Bielefeld *
@@
-20,8
+20,21
@@
#define MAX_NUM_KEYS 8
#define MAX_NUM_KEYS 8
+struct GamePanelInfo
+{
+ struct XY level;
+ struct XY gems;
+ struct XY inventory;
+ struct XY keys;
+ struct XY score;
+ struct XY time;
+};
+
struct GameInfo
{
struct GameInfo
{
+ /* values for control panel */
+ struct GamePanelInfo panel;
+
/* values for engine initialization */
int default_push_delay_fixed;
int default_push_delay_random;
/* values for engine initialization */
int default_push_delay_fixed;
int default_push_delay_random;
@@
-29,8
+42,8
@@
struct GameInfo
/* constant within running game */
int engine_version;
int emulation;
/* constant within running game */
int engine_version;
int emulation;
- int initial_move_delay;
- int initial_move_delay_value;
+ int initial_move_delay
[MAX_PLAYERS]
;
+ int initial_move_delay_value
[MAX_PLAYERS]
;
int initial_push_delay_value;
/* flags to handle bugs in and changes between different engine versions */
int initial_push_delay_value;
/* flags to handle bugs in and changes between different engine versions */
@@
-54,13
+67,11
@@
struct GameInfo
boolean explosions_delayed;
boolean envelope_active;
boolean explosions_delayed;
boolean envelope_active;
-#if 1
/* values for the new EMC elements */
int lenses_time_left;
int magnify_time_left;
boolean ball_state;
int ball_content_nr;
/* values for the new EMC elements */
int lenses_time_left;
int magnify_time_left;
boolean ball_state;
int ball_content_nr;
-#endif
/* values for player idle animation (no effect on engine) */
int player_boring_delay_fixed;
/* values for player idle animation (no effect on engine) */
int player_boring_delay_fixed;
@@
-75,6
+86,9
@@
struct GameInfo
int centered_player_nr;
int centered_player_nr_next;
boolean set_centered_player;
int centered_player_nr;
int centered_player_nr_next;
boolean set_centered_player;
+
+ /* values for random number generator initialization after snapshot */
+ unsigned long num_random_calls;
};
struct PlayerInfo
};
struct PlayerInfo
@@
-109,10
+123,18
@@
struct PlayerInfo
boolean can_fall_into_acid;
boolean can_fall_into_acid;
+ boolean gravity;
+
boolean LevelSolved, GameOver;
boolean LevelSolved, GameOver;
+ boolean LevelSolved_GameEnd;
+ boolean LevelSolved_SaveTape;
+ boolean LevelSolved_SaveScore;
+
int last_move_dir;
int last_move_dir;
+ boolean is_active;
+
boolean is_waiting;
boolean is_moving;
boolean is_auto_moving;
boolean is_waiting;
boolean is_moving;
boolean is_auto_moving;
@@
-164,6
+186,8
@@
struct PlayerInfo
int step_counter;
int score;
int step_counter;
int score;
+ int score_final;
+
int gems_still_needed;
int sokobanfields_still_needed;
int lights_still_needed;
int gems_still_needed;
int sokobanfields_still_needed;
int lights_still_needed;
@@
-178,9
+202,8
@@
struct PlayerInfo
int inventory_size;
};
int inventory_size;
};
-
extern struct GameInfo game;
extern struct GameInfo game;
-extern struct PlayerInfo stored_player[], *local_player;
+extern struct PlayerInfo stored_player[
MAX_PLAYERS
], *local_player;
#ifdef DEBUG
#ifdef DEBUG
@@
-193,10
+216,11
@@
void DrawGameValue_Time(int);
void DrawGameDoorValues(void);
void InitGameSound();
void DrawGameDoorValues(void);
void InitGameSound();
-void InitGame(
void
);
+void InitGame();
void UpdateEngineValues(int, int);
void GameWon(void);
void UpdateEngineValues(int, int);
void GameWon(void);
+void GameEnd(void);
void InitPlayerGfxAnimation(struct PlayerInfo *, int, int);
void Moving2Blocked(int, int, int *, int *);
void InitPlayerGfxAnimation(struct PlayerInfo *, int, int);
void Moving2Blocked(int, int, int *, int *);
@@
-218,6
+242,14
@@
void RaiseScore(int);
void RaiseScoreElement(int);
void RequestQuitGame(boolean);
void RaiseScoreElement(int);
void RequestQuitGame(boolean);
+unsigned int InitEngineRandom_RND(long);
+unsigned int RND(int);
+
+void FreeEngineSnapshot();
+void LoadEngineSnapshot();
+void SaveEngineSnapshot();
+boolean CheckEngineSnapshot();
+
void CreateGameButtons();
void FreeGameButtons();
void UnmapGameButtons();
void CreateGameButtons();
void FreeGameButtons();
void UnmapGameButtons();