d->time, d->goal, d->score, d->balls, d->times);
}
-/* Open a demo file, fill the demo information structure. If success, return
- * the file pointer positioned after the header. If fail, return NULL. */
-
-FILE *demo_header_read(const char *filename, struct demo *d)
+static int demo_header_read(FILE *fp, struct demo *d)
{
- FILE *fp;
+ int magic;
+ int version;
+ int t;
- char *basename;
- char buf[MAXSTR];
-
- if ((fp = fopen(filename, FMODE_RB)))
- {
- int magic;
- int version;
- int t;
-
- get_index(fp, &magic);
- get_index(fp, &version);
-
- get_index(fp, &t);
-
- if (magic == MAGIC && version == DEMO_VERSION && t)
- {
- d->timer = t;
- strncpy(d->filename, filename, PATHMAX);
+ get_index(fp, &magic);
+ get_index(fp, &version);
- /* Remove the directory delimiter */
+ get_index(fp, &t);
- basename = strrchr(filename, '/');
-
-#ifdef _WIN32
- if (!basename)
- basename = strrchr(filename, '\\');
- else
- {
- char *tmp;
- if ((tmp = strrchr(basename, '\\')))
- basename = tmp;
- }
-#endif
- strncpy(buf, basename ? basename + 1 : filename, MAXSTR);
-
- /* Remove the extension */
- t = strlen(buf) - strlen(REPLAY_EXT);
- if ((t > 1) && (strcmp(buf + t, REPLAY_EXT) == 0))
- buf[t] = '\0';
- strncpy(d->name, buf, PATHMAX);
- d->name[PATHMAX - 1] = '\0';
+ if (magic == MAGIC && version == DEMO_VERSION && t)
+ {
+ d->timer = t;
- get_index (fp, &d->coins);
- get_index (fp, &d->state);
- get_index (fp, &d->mode);
- get_index (fp, (int *) &d->date);
+ get_index (fp, &d->coins);
+ get_index (fp, &d->state);
+ get_index (fp, &d->mode);
+ get_index (fp, (int *) &d->date);
- fread(d->player, 1, MAXNAM, fp);
+ fread(d->player, 1, MAXNAM, fp);
- fread(d->shot, 1, PATHMAX, fp);
- fread(d->file, 1, PATHMAX, fp);
- fread(d->back, 1, PATHMAX, fp);
- fread(d->grad, 1, PATHMAX, fp);
- fread(d->song, 1, PATHMAX, fp);
+ fread(d->shot, 1, PATHMAX, fp);
+ fread(d->file, 1, PATHMAX, fp);
+ fread(d->back, 1, PATHMAX, fp);
+ fread(d->grad, 1, PATHMAX, fp);
+ fread(d->song, 1, PATHMAX, fp);
- get_index (fp, &d->time);
- get_index (fp, &d->goal);
- get_index (fp, &d->score);
- get_index (fp, &d->balls);
- get_index (fp, &d->times);
+ get_index(fp, &d->time);
+ get_index(fp, &d->goal);
+ get_index(fp, &d->score);
+ get_index(fp, &d->balls);
+ get_index(fp, &d->times);
- fread(d->nb_version, 1, 20, fp);
+ fread(d->nb_version, 1, 20, fp);
- return fp;
- }
- fclose(fp);
+ return 1;
}
- return NULL;
+ return 0;
}
/* Create a new demo file, write the demo information structure. If success,
static void demo_scan_file(const char *filename)
{
FILE *fp;
- if ((fp = demo_header_read(config_user(filename), &demos[count])))
+ struct demo *d = &demos[count];
+
+ if ((fp = fopen(config_user(filename), FMODE_RB)))
{
- count++;
+ if (demo_header_read(fp, d))
+ {
+ char buf[PATHMAX];
+ int l;
+
+ strncpy(d->filename, config_user(filename), MAXSTR);
+
+ strncpy(buf, filename, PATHMAX);
+ l = strlen(buf) - strlen(REPLAY_EXT);
+
+ if ((l > 1) && (strcmp(buf + l, REPLAY_EXT) == 0))
+ buf[l] = '\0';
+
+ strncpy(d->name, buf, PATHMAX);
+ d->name[PATHMAX - 1] = '\0';
+
+ count++;
+ }
fclose(fp);
}
}
return (n > 0) ? demos[(rand() >> 4) % n].filename : NULL;
}
-const struct demo *get_demo(int i)
+const struct demo *demo_get(int i)
{
return (0 <= i && i < count) ? &demos[i] : NULL;
}
memset(&demo, 0, sizeof (demo));
- strncpy(demo.filename, config_user(name), PATHMAX);
+ strncpy(demo.filename, config_user(name), MAXSTR);
strcat(demo.filename, REPLAY_EXT);
demo.mode = lg->mode;
/*---------------------------------------------------------------------------*/
static int demo_load_level(const struct demo *demo, struct level *level)
-/* Load the level of the demo and fill the level structure */
{
if (level_load(demo->file, level))
{
level->goal = demo->goal;
return 1;
}
- else
- return 0;
+ return 0;
}
static struct demo demo_replay; /* The current demo */
int demo_replay_init(const char *name, struct level_game *lg)
{
- if ((demo_fp = demo_header_read(name, &demo_replay)))
+ demo_fp = fopen(name, FMODE_RB);
+
+ if (demo_fp && demo_header_read(demo_fp, &demo_replay))
{
+ strncpy(demo_replay.filename, name, MAXSTR);
+
if (!demo_load_level(&demo_replay, &demo_level_replay))
return 0;
return game_init(&demo_level_replay, demo_replay.time,
demo_replay.goal);
}
- else /* A title screen demo */
+ else /* A title screen demo */
return game_init(&demo_level_replay, demo_replay.time, 0);
}
-
return 0;
}
break;
default:
- if (level_replay(get_demo(i)->filename))
+ if (level_replay(demo_get(i)->filename))
demo_play_goto(0);
return goto_state(&st_demo_play);
}
if ((jd = gui_vstack(id)))
{
gui_space(jd);
+ gui_image(jd, demo_get(i)->shot, w / 6, h / 6);
- gui_image(jd, get_demo(i)->shot, w / 6, h / 6);
nam[MAXNAM - 1] = '\0';
- strncpy(nam, get_demo(i)->name, MAXNAM);
+ strncpy(nam, demo_get(i)->name, MAXNAM);
if (nam[MAXNAM - 1] != '\0')
{
nam[MAXNAM - 2] = '.';
}
}
+#if 0
static int name_id;
+#endif
static int time_id;
static int coin_id;
static int date_id;
}
if ((md = gui_vstack(ld)))
{
+#if 0
name_id = gui_label(md, (d ? d->name : noname),
GUI_SML, GUI_RGT, 0, 0);
+#endif
time_id = gui_clock(md, (d ? d->timer : 35000),
GUI_SML, GUI_RGT);
mode_id = gui_label(md, mode, GUI_SML, GUI_RGT, 0, 0);
}
if ((kd = gui_vstack(jd)))
{
+#if 0
gui_label(kd, _("Replay"), GUI_SML, GUI_LFT, gui_wht, gui_wht);
+#endif
gui_label(kd, _("Time"), GUI_SML, GUI_LFT, gui_wht, gui_wht);
gui_label(kd, _("Mode"), GUI_SML, GUI_LFT, gui_wht, gui_wht);
gui_label(kd, _("Level"), GUI_SML, GUI_LFT, gui_wht, gui_wht);
static void gui_demo_update_status(int i)
{
- const struct demo *d = get_demo(i);
+ const struct demo *d = demo_get(i);
+#if 0
gui_set_label(name_id, d->name);
+#endif
gui_set_label(date_id, date_to_str(d->date));
gui_set_label(level_id, d->file);
gui_set_label(player_id, d->player);
{
int jd = shared_stick_basic(id, a, v);
int i = gui_token(jd);
+
if (jd && i >= 0)
gui_demo_update_status(i);
}