projects
/
rocksndiamonds.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
added flags for "level solved" and "game over" to EM engine
[rocksndiamonds.git]
/
src
/
game_em
/
cave.c
diff --git
a/src/game_em/cave.c
b/src/game_em/cave.c
index ab8e5c346fa76cba403bac73d3f45c7dd877f164..b89c42f3adeba2c430f76c47166e80569b5ded94 100644
(file)
--- a/
src/game_em/cave.c
+++ b/
src/game_em/cave.c
@@
-45,7
+45,6
@@
void setLevelInfoToDefaults_EM(void)
for (i = 0; i < TILE_MAX; i++)
lev.android_array[i] = Xblank;
for (i = 0; i < TILE_MAX; i++)
lev.android_array[i] = Xblank;
-#if 1
/* initial number of players in this level */
lev.home_initial = 0;
/* initial number of players in this level */
lev.home_initial = 0;
@@
-54,16
+53,6
@@
void setLevelInfoToDefaults_EM(void)
ply[i].exists = 0;
ply[i].alive_initial = FALSE;
}
ply[i].exists = 0;
ply[i].alive_initial = FALSE;
}
-#else
- /* initial number of players in this level */
- lev.home_initial = (setup.team_mode ? 2 : 1);
-
- for (i = 0; i < MAX_PLAYERS; i++)
- {
- ply[i].exists = 0;
- ply[i].alive_initial = (lev.home_initial > i ? TRUE : FALSE);
- }
-#endif
}
}
@@
-74,26
+63,27
@@
void setLevelInfoToDefaults_EM(void)
#define MAX_EM_LEVEL_SIZE 16384
#define MAX_EM_LEVEL_SIZE 16384
-boolean LoadNativeLevel_EM(char *filename)
+boolean LoadNativeLevel_EM(char *filename
, boolean level_info_only
)
{
unsigned char raw_leveldata[MAX_EM_LEVEL_SIZE];
int raw_leveldata_length;
int file_version;
{
unsigned char raw_leveldata[MAX_EM_LEVEL_SIZE];
int raw_leveldata_length;
int file_version;
- F
ILE
*file;
+ F
ile
*file;
/* always start with reliable default values */
setLevelInfoToDefaults_EM();
/* always start with reliable default values */
setLevelInfoToDefaults_EM();
- if (!(file =
fopen
(filename, MODE_READ)))
+ if (!(file =
openFile
(filename, MODE_READ)))
{
{
- Error(ERR_WARN, "cannot open level '%s' -- using empty level", filename);
+ if (!level_info_only)
+ Error(ERR_WARN, "cannot open level '%s' -- using empty level", filename);
return FALSE;
}
return FALSE;
}
- raw_leveldata_length =
fread(raw_leveldata, 1, MAX_EM_LEVEL_SIZE, file
);
+ raw_leveldata_length =
readFile(file, raw_leveldata, 1, MAX_EM_LEVEL_SIZE
);
-
fclos
e(file);
+
closeFil
e(file);
if (raw_leveldata_length <= 0)
{
if (raw_leveldata_length <= 0)
{
@@
-102,7
+92,9
@@
boolean LoadNativeLevel_EM(char *filename)
return FALSE;
}
return FALSE;
}
- if (!(file_version = cleanup_em_level(raw_leveldata, raw_leveldata_length)))
+ file_version = cleanup_em_level(raw_leveldata, raw_leveldata_length,filename);
+
+ if (file_version == FILE_VERSION_EM_UNKNOWN)
{
Error(ERR_WARN, "unknown EM level '%s' -- using empty level", filename);
{
Error(ERR_WARN, "unknown EM level '%s' -- using empty level", filename);