2002-03-03 16:16:28 +01:00
|
|
|
/* vi: set ts=2:
|
|
|
|
+-------------------+ Christian Schlittchen <corwin@amber.kn-bremen.de>
|
|
|
|
| | Enno Rehling <enno@eressea-pbem.de>
|
|
|
|
| Eressea PBEM host | Katja Zedel <katze@felidae.kn-bremen.de>
|
2003-07-29 11:48:03 +02:00
|
|
|
| (c) 1998 - 2003 | Henning Peters <faroul@beyond.kn-bremen.de>
|
2002-03-03 16:16:28 +01:00
|
|
|
| | Ingo Wilken <Ingo.Wilken@informatik.uni-oldenburg.de>
|
|
|
|
+-------------------+ Stefan Reich <reich@halbling.de>
|
|
|
|
|
|
|
|
This program may not be used, modified or distributed
|
|
|
|
without prior permission by the authors of Eressea.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
#include <eressea.h>
|
|
|
|
|
|
|
|
/* kernel includes */
|
|
|
|
#include <faction.h>
|
|
|
|
#include <unit.h>
|
|
|
|
#include <region.h>
|
|
|
|
#include <save.h>
|
|
|
|
|
|
|
|
/* util includes */
|
|
|
|
#include <base36.h>
|
|
|
|
|
|
|
|
/* libc includes */
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
static FILE * log;
|
|
|
|
|
|
|
|
void
|
2002-03-03 16:43:53 +01:00
|
|
|
log_read(const char * filename)
|
2002-03-03 16:16:28 +01:00
|
|
|
{
|
2002-03-03 16:43:53 +01:00
|
|
|
FILE * log = fopen(filename, "r");
|
2002-03-03 16:16:28 +01:00
|
|
|
faction **fp = &factions;
|
|
|
|
char buf[64];
|
|
|
|
|
|
|
|
while (*fp) fp=&(*fp)->next;
|
2002-04-14 10:00:49 +02:00
|
|
|
fscanf(log, "LOGVERSION %u\n", &global.data_version);
|
2002-03-03 16:16:28 +01:00
|
|
|
while (!feof(log)) {
|
2002-03-03 17:22:24 +01:00
|
|
|
if(fscanf(log, "%s", buf) == EOF) break;
|
2002-03-03 16:16:28 +01:00
|
|
|
if (strcmp(buf, "UNIT")==0) {
|
2005-07-27 13:48:16 +02:00
|
|
|
short x, y;
|
2002-03-03 16:16:28 +01:00
|
|
|
unit * u;
|
|
|
|
region * r;
|
2005-07-27 13:48:16 +02:00
|
|
|
fscanf(log, "%s %hd %hd", buf, &x, &y);
|
2002-03-03 16:16:28 +01:00
|
|
|
u = readunit(log);
|
|
|
|
r = findregion(x, y);
|
2002-04-03 01:42:07 +02:00
|
|
|
if (r==NULL) {
|
|
|
|
r = new_region(x, y);
|
|
|
|
terraform(r, T_PLAIN);
|
|
|
|
}
|
2002-03-03 16:16:28 +01:00
|
|
|
if (u->region!=r) move_unit(u, r, NULL);
|
2002-03-03 16:52:54 +01:00
|
|
|
} else if (strcmp(buf, "REGION")==0) {
|
2005-07-27 13:48:16 +02:00
|
|
|
short x, y;
|
|
|
|
fscanf(log, "%hd %hd", &x, &y);
|
2002-03-03 16:16:28 +01:00
|
|
|
readregion(log, x, y);
|
2002-03-03 16:52:54 +01:00
|
|
|
} else if (strcmp(buf, "FACTION")==0) {
|
2002-03-03 16:16:28 +01:00
|
|
|
faction * f;
|
|
|
|
fscanf(log, "%s", buf);
|
|
|
|
f = findfaction(atoi36(buf));
|
|
|
|
if (f) {
|
|
|
|
readfaction(log);
|
|
|
|
} else {
|
|
|
|
*fp = readfaction(log);
|
2002-03-03 17:04:57 +01:00
|
|
|
fp=&(*fp)->next;
|
2002-03-03 16:16:28 +01:00
|
|
|
}
|
2002-03-03 16:52:54 +01:00
|
|
|
} else assert(0);
|
2002-03-03 16:16:28 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
log_faction(const struct faction * f)
|
|
|
|
{
|
2002-03-03 16:43:53 +01:00
|
|
|
fprintf(log, "FACTION %s\n", factionid(f));
|
2002-03-03 16:16:28 +01:00
|
|
|
writefaction(log, f);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
log_unit(const struct unit * u)
|
|
|
|
{
|
2002-03-03 16:43:53 +01:00
|
|
|
fprintf(log, "UNIT %s %d %d\n", unitid(u), u->region->x, u->region->y);
|
2002-03-03 16:16:28 +01:00
|
|
|
writeunit(log, u);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
log_region(const struct region * r)
|
|
|
|
{
|
|
|
|
fprintf(log, "REGION %d %d\n", r->x, r->y);
|
|
|
|
writeregion(log, r);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
log_start(const char * filename)
|
|
|
|
{
|
|
|
|
log = fopen(filename, "w+");
|
|
|
|
fprintf(log, "LOGVERSION %d\n", RELEASE_VERSION);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
log_stop(void)
|
|
|
|
{
|
|
|
|
fclose(log);
|
|
|
|
log = NULL;
|
2002-03-03 16:43:53 +01:00
|
|
|
}
|