return 0;
}
-static FILE *demo_header_open(const char *filename, struct demo *d)
+static char *bname(const char *name, const char *suffix)
{
- FILE *fp;
-
- if ((fp = fopen(filename, FMODE_RB)))
- {
- if (demo_header_read(fp, d))
- {
- char buf[MAXSTR];
- char *basename;
- int l;
+ static char buf[MAXSTR];
- strncpy(d->filename, filename, MAXSTR);
+ char *base;
+ size_t l;
- /* Remove the directory delimiter */
+ /* Remove the directory delimiter */
- basename = strrchr(filename, '/');
+ base = strrchr(name, '/');
#ifdef _WIN32
- if (!basename)
- basename = strrchr(filename, '\\');
- else
- {
- char *tmp;
- if ((tmp = strrchr(basename, '\\')))
- basename = tmp;
- }
+ if (!base)
+ base = strrchr(name, '\\');
+ else
+ {
+ char *tmp;
+ if ((tmp = strrchr(base, '\\')))
+ base = tmp;
+ }
#endif
- strncpy(buf, basename ? basename + 1 : filename, MAXSTR);
+ strncpy(buf, base ? base + 1 : name, MAXSTR);
- /* Remove the extension */
+ /* Remove the extension */
- l = strlen(buf) - strlen(REPLAY_EXT);
- if ((l > 1) && (strcmp(buf + l, REPLAY_EXT) == 0))
- buf[l] = '\0';
+ l = strlen(buf) - strlen(suffix);
+ if ((l > 1) && (strcmp(buf + l, suffix) == 0))
+ buf[l] = '\0';
- strncpy(d->name, buf, PATHMAX);
- d->name[PATHMAX - 1] = '\0';
-
- return fp;
- }
- fclose(fp);
- }
- return NULL;
+ return buf;
}
static void demo_header_write(FILE *fp, struct demo *d)
FILE *fp;
struct demo *d = &demos[count];
- if ((fp = demo_header_open(config_user(filename), d)))
+ if ((fp = fopen(config_user(filename), FMODE_RB)))
{
- count++;
+ if (demo_header_read(fp, d))
+ {
+ strncpy(d->filename, config_user(filename), MAXSTR);
+ strncpy(d->name, bname(filename, REPLAY_EXT), PATHMAX);
+ d->name[PATHMAX - 1] = '\0';
+
+ count++;
+ }
fclose(fp);
}
}
int demo_replay_init(const char *name, struct level_game *lg)
{
- demo_fp = demo_header_open(name, &demo_replay);
+ demo_fp = fopen(name, FMODE_RB);
- if (demo_fp)
+ if (demo_fp && demo_header_read(demo_fp, &demo_replay))
{
+ strncpy(demo_replay.filename, name, MAXSTR);
+ strncpy(demo_replay.name, bname(name, REPLAY_EXT), PATHMAX);
+
if (!demo_load_level(&demo_replay, &demo_level_replay))
return 0;