Merge pull request #67 from badgerman/version-cleanup

eliminating support for old datafile versions, prior to binary formats
This commit is contained in:
Enno Rehling 2014-12-13 13:26:23 +01:00
commit fcffb3d8e1
14 changed files with 300 additions and 580 deletions

View file

@ -104,12 +104,7 @@ static int lc_read(struct attrib *a, void *owner, struct storage *store)
building_action *data = (building_action *)a->data.v; building_action *data = (building_action *)a->data.v;
int result = int result =
read_reference(&data->b, store, read_building_reference, resolve_building); read_reference(&data->b, store, read_building_reference, resolve_building);
if (global.data_version < UNICODE_VERSION) {
READ_STR(store, name, sizeof(name));
}
else {
READ_TOK(store, name, sizeof(name)); READ_TOK(store, name, sizeof(name));
}
if (strcmp(name, "tunnel_action") == 0) { if (strcmp(name, "tunnel_action") == 0) {
/* E2: Weltentor has a new module, doesn't need this any longer */ /* E2: Weltentor has a new module, doesn't need this any longer */
result = 0; result = 0;
@ -118,27 +113,17 @@ static int lc_read(struct attrib *a, void *owner, struct storage *store)
else { else {
data->fname = _strdup(name); data->fname = _strdup(name);
} }
if (global.data_version >= BACTION_VERSION) {
if (global.data_version < UNICODE_VERSION) {
READ_STR(store, name, sizeof(name));
}
else {
READ_TOK(store, name, sizeof(name)); READ_TOK(store, name, sizeof(name));
if (strcmp(name, "tnnL") == 0) { if (strcmp(name, "tnnL") == 0) {
/* tunnel_action was the old Weltentore, their code has changed. ignore this object */ /* tunnel_action was the old Weltentore, their code has changed. ignore this object */
result = 0; result = 0;
data->b = 0; data->b = 0;
} }
}
if (strcmp(name, NULLSTRING) == 0) if (strcmp(name, NULLSTRING) == 0)
data->param = 0; data->param = 0;
else { else {
data->param = _strdup(name); data->param = _strdup(name);
} }
}
else {
data->param = 0;
}
if (result == 0 && !data->b) { if (result == 0 && !data->b) {
return AT_READ_FAIL; return AT_READ_FAIL;
} }

View file

@ -231,10 +231,8 @@ int LongHunger(const struct unit *u)
if (u != NULL) { if (u != NULL) {
if (!fval(u, UFL_HUNGER)) if (!fval(u, UFL_HUNGER))
return false; return false;
#ifdef NEW_DAEMONHUNGER_RULE
if (u_race(u) == get_race(RC_DAEMON)) if (u_race(u) == get_race(RC_DAEMON))
return false; return false;
#endif
} }
if (rule < 0 || gamecookie != global.cookie) { if (rule < 0 || gamecookie != global.cookie) {
gamecookie = global.cookie; gamecookie = global.cookie;

View file

@ -195,14 +195,8 @@ int curse_read(attrib * a, void *owner, struct storage *store)
READ_TOK(store, cursename, sizeof(cursename)); READ_TOK(store, cursename, sizeof(cursename));
READ_INT(store, &flags); READ_INT(store, &flags);
READ_INT(store, &c->duration); READ_INT(store, &c->duration);
if (global.data_version >= CURSEVIGOURISFLOAT_VERSION) {
READ_FLT(store, &flt); READ_FLT(store, &flt);
c->vigour = flt; c->vigour = flt;
}
else {
READ_INT(store, &n);
c->vigour = (float)n;
}
if (global.data_version < INTPAK_VERSION) { if (global.data_version < INTPAK_VERSION) {
ur = read_reference(&c->magician, store, read_int, resolve_unit); ur = read_reference(&c->magician, store, read_int, resolve_unit);
} }
@ -226,12 +220,7 @@ int curse_read(attrib * a, void *owner, struct storage *store)
assert(result == 0); assert(result == 0);
return AT_READ_FAIL; return AT_READ_FAIL;
} }
if (global.data_version < CURSEFLAGS_VERSION) {
c_setflag(c, flags);
}
else {
c->flags = flags; c->flags = flags;
}
c_clearflag(c, CURSE_ISNEW); c_clearflag(c, CURSE_ISNEW);
if (c->type->read) if (c->type->read)

View file

@ -236,8 +236,6 @@ void read_groups(struct storage *store, faction * f)
READ_INT(store, &fid.i); READ_INT(store, &fid.i);
if (fid.i <= 0) if (fid.i <= 0)
break; break;
if (global.data_version < STORAGE_VERSION && fid.i == 0)
break;
a = ally_add(pa, findfaction(fid.i)); a = ally_add(pa, findfaction(fid.i));
READ_INT(store, &a->status); READ_INT(store, &a->status);
if (!a->faction) if (!a->faction)

View file

@ -428,10 +428,6 @@ static void read_alliances(struct storage *store)
{ {
char pbuf[8]; char pbuf[8];
int id, terminator = 0; int id, terminator = 0;
if (global.data_version < SAVEALLIANCE_VERSION) {
if (!AllianceRestricted() && !AllianceAuto())
return;
}
if (global.data_version < ALLIANCELEADER_VERSION) { if (global.data_version < ALLIANCELEADER_VERSION) {
terminator = atoi36("end"); terminator = atoi36("end");
READ_STR(store, pbuf, sizeof(pbuf)); READ_STR(store, pbuf, sizeof(pbuf));
@ -645,36 +641,10 @@ unit *read_unit(struct gamedata *data)
READ_INT(data->store, &n); READ_INT(data->store, &n);
u->age = (short)n; u->age = (short)n;
if (data->version < STORAGE_VERSION) {
char *space;
READ_STR(data->store, rname, sizeof(rname));
space = strchr(rname, ' ');
if (space != NULL) {
char *inc = space + 1;
char *outc = space;
do {
while (*inc == ' ')
++inc;
while (*inc) {
*outc++ = *inc++;
if (*inc == ' ')
break;
}
} while (*inc);
*outc = 0;
}
}
else {
READ_TOK(data->store, rname, sizeof(rname)); READ_TOK(data->store, rname, sizeof(rname));
}
u_setrace(u, rc_find(rname)); u_setrace(u, rc_find(rname));
if (data->version < STORAGE_VERSION) {
READ_STR(data->store, rname, sizeof(rname));
}
else {
READ_TOK(data->store, rname, sizeof(rname)); READ_TOK(data->store, rname, sizeof(rname));
}
if (rname[0] && skill_enabled(SK_STEALTH)) if (rname[0] && skill_enabled(SK_STEALTH))
u->irace = rc_find(rname); u->irace = rc_find(rname);
else else
@ -756,14 +726,6 @@ unit *read_unit(struct gamedata *data)
} }
READ_STR(data->store, obuf, sizeof(obuf)); READ_STR(data->store, obuf, sizeof(obuf));
} }
if (data->version < NOLASTORDER_VERSION) {
order *ord;
READ_STR(data->store, obuf, sizeof(obuf));
ord = parse_order(obuf, u->faction->locale);
if (ord != NULL) {
addlist(&u->orders, ord);
}
}
set_order(&u->thisorder, NULL); set_order(&u->thisorder, NULL);
assert(u_race(u)); assert(u_race(u));
@ -869,13 +831,11 @@ static region *readregion(struct gamedata *data, int x, int y)
{ {
region *r = findregion(x, y); region *r = findregion(x, y);
const terrain_type *terrain; const terrain_type *terrain;
char token[32]; char name[NAMESIZE];
int uid = 0; int uid = 0;
int n; int n;
if (data->version >= UID_VERSION) {
READ_INT(data->store, &uid); READ_INT(data->store, &uid);
}
if (r == NULL) { if (r == NULL) {
plane *pl = findplane(x, y); plane *pl = findplane(x, y);
@ -906,31 +866,18 @@ static region *readregion(struct gamedata *data, int x, int y)
region_setinfo(r, info); region_setinfo(r, info);
} }
if (data->version < TERRAIN_VERSION) {
int ter;
READ_INT(data->store, &ter);
terrain = newterrain((terrain_t)ter);
if (terrain == NULL) {
log_error("while reading datafile from pre-TERRAIN_VERSION, could not find terrain #%d.\n", ter);
terrain = newterrain(T_PLAIN);
}
}
else {
char name[64];
READ_STR(data->store, name, sizeof(name)); READ_STR(data->store, name, sizeof(name));
terrain = get_terrain(name); terrain = get_terrain(name);
if (terrain == NULL) { if (terrain == NULL) {
log_error("Unknown terrain '%s'\n", name); log_error("Unknown terrain '%s'\n", name);
assert(!"unknown terrain"); assert(!"unknown terrain");
} }
}
r->terrain = terrain; r->terrain = terrain;
READ_INT(data->store, &r->flags); READ_INT(data->store, &r->flags);
READ_INT(data->store, &n); READ_INT(data->store, &n);
r->age = (unsigned short)n; r->age = (unsigned short)n;
if (fval(r->terrain, LAND_REGION)) { if (fval(r->terrain, LAND_REGION)) {
char name[NAMESIZE];
r->land = calloc(1, sizeof(land_region)); r->land = calloc(1, sizeof(land_region));
READ_STR(data->store, name, sizeof(name)); READ_STR(data->store, name, sizeof(name));
r->land->name = _strdup(name); r->land->name = _strdup(name);
@ -963,13 +910,13 @@ static region *readregion(struct gamedata *data, int x, int y)
assert(*pres == NULL); assert(*pres == NULL);
for (;;) { for (;;) {
rawmaterial *res; rawmaterial *res;
READ_STR(data->store, token, sizeof(token)); READ_STR(data->store, name, sizeof(name));
if (strcmp(token, "end") == 0) if (strcmp(name, "end") == 0)
break; break;
res = malloc(sizeof(rawmaterial)); res = malloc(sizeof(rawmaterial));
res->type = rmt_find(token); res->type = rmt_find(name);
if (res->type == NULL) { if (res->type == NULL) {
log_error("invalid resourcetype %s in data.\n", token); log_error("invalid resourcetype %s in data.\n", name);
} }
assert(res->type != NULL); assert(res->type != NULL);
READ_INT(data->store, &n); READ_INT(data->store, &n);
@ -990,9 +937,9 @@ static region *readregion(struct gamedata *data, int x, int y)
} }
*pres = NULL; *pres = NULL;
READ_STR(data->store, token, sizeof(token)); READ_STR(data->store, name, sizeof(name));
if (strcmp(token, "noherb") != 0) { if (strcmp(name, "noherb") != 0) {
const resource_type *rtype = rt_find(token); const resource_type *rtype = rt_find(name);
assert(rtype && rtype->itype && fval(rtype->itype, ITF_HERB)); assert(rtype && rtype->itype && fval(rtype->itype, ITF_HERB));
rsetherbtype(r, rtype->itype); rsetherbtype(r, rtype->itype);
} }
@ -1016,17 +963,15 @@ static region *readregion(struct gamedata *data, int x, int y)
int n; int n;
for (;;) { for (;;) {
const struct resource_type *rtype; const struct resource_type *rtype;
READ_STR(data->store, token, sizeof(token)); READ_STR(data->store, name, sizeof(name));
if (!strcmp(token, "end")) if (!strcmp(name, "end"))
break; break;
rtype = rt_find(token); rtype = rt_find(name);
assert(rtype && rtype->ltype); assert(rtype && rtype->ltype);
READ_INT(data->store, &n); READ_INT(data->store, &n);
r_setdemand(r, rtype->ltype, n); r_setdemand(r, rtype->ltype, n);
} }
if (data->version >= REGIONITEMS_VERSION) {
read_items(data->store, &r->land->items); read_items(data->store, &r->land->items);
}
if (data->version >= REGIONOWNER_VERSION) { if (data->version >= REGIONOWNER_VERSION) {
READ_INT(data->store, &n); READ_INT(data->store, &n);
r->land->morale = (short)n; r->land->morale = (short)n;
@ -1088,10 +1033,8 @@ void writeregion(struct gamedata *data, const region * r)
WRITE_INT(data->store, demand->value); WRITE_INT(data->store, demand->value);
} }
WRITE_TOK(data->store, "end"); WRITE_TOK(data->store, "end");
#if RELEASE_VERSION>=REGIONITEMS_VERSION
write_items(data->store, r->land->items); write_items(data->store, r->land->items);
WRITE_SECTION(data->store); WRITE_SECTION(data->store);
#endif
#if RELEASE_VERSION>=REGIONOWNER_VERSION #if RELEASE_VERSION>=REGIONOWNER_VERSION
WRITE_INT(data->store, r->land->morale); WRITE_INT(data->store, r->land->morale);
write_owner(data, r->land->ownership); write_owner(data, r->land->ownership);
@ -1163,16 +1106,6 @@ void read_spellbook(spellbook **bookp, struct storage *store, int(*get_level)(co
char spname[64]; char spname[64];
int level = 0; int level = 0;
if (global.data_version < SPELLNAME_VERSION) {
int i;
READ_INT(store, &i);
if (i < 0)
break;
if (bookp) {
sp = find_spellbyid((unsigned int)i);
}
}
else {
READ_TOK(store, spname, sizeof(spname)); READ_TOK(store, spname, sizeof(spname));
if (strcmp(spname, "end") == 0) if (strcmp(spname, "end") == 0)
break; break;
@ -1182,7 +1115,6 @@ void read_spellbook(spellbook **bookp, struct storage *store, int(*get_level)(co
log_error("read_spells: could not find spell '%s'\n", spname); log_error("read_spells: could not find spell '%s'\n", spname);
} }
} }
}
if (global.data_version >= SPELLBOOK_VERSION) { if (global.data_version >= SPELLBOOK_VERSION) {
READ_INT(store, &level); READ_INT(store, &level);
} }
@ -1313,9 +1245,7 @@ faction *readfaction(struct gamedata * data)
} }
a_read(data->store, &f->attribs, f); a_read(data->store, &f->attribs, f);
if (data->version >= CLAIM_VERSION) {
read_items(data->store, &f->items); read_items(data->store, &f->items);
}
for (;;) { for (;;) {
READ_TOK(data->store, name, sizeof(name)); READ_TOK(data->store, name, sizeof(name));
if (strcmp("end", name) == 0) if (strcmp("end", name) == 0)
@ -1342,28 +1272,9 @@ faction *readfaction(struct gamedata * data)
} }
sfp = &f->allies; sfp = &f->allies;
if (data->version < ALLIANCES_VERSION) {
int p;
READ_INT(data->store, &p);
while (--p >= 0) {
int aid, state;
READ_INT(data->store, &aid);
READ_INT(data->store, &state);
sfp = addally(f, sfp, aid, state);
}
}
else {
for (;;) { for (;;) {
int aid = 0; int aid = 0;
if (data->version < STORAGE_VERSION) {
READ_TOK(data->store, name, sizeof(name));
if (strcmp(name, "end") != 0) {
aid = atoi36(name);
}
}
else {
READ_INT(data->store, &aid); READ_INT(data->store, &aid);
}
if (aid > 0) { if (aid > 0) {
int state; int state;
READ_INT(data->store, &state); READ_INT(data->store, &state);
@ -1373,7 +1284,6 @@ faction *readfaction(struct gamedata * data)
break; break;
} }
} }
}
read_groups(data->store, f); read_groups(data->store, f);
f->spellbook = 0; f->spellbook = 0;
if (data->version >= REGIONOWNER_VERSION) { if (data->version >= REGIONOWNER_VERSION) {
@ -1445,7 +1355,7 @@ void writefaction(struct gamedata *data, const faction * f)
int readgame(const char *filename, int backup) int readgame(const char *filename, int backup)
{ {
int i, n, p, nread; int n, p, nread;
faction *f, **fp; faction *f, **fp;
region *r; region *r;
building *b, **bp; building *b, **bp;
@ -1503,9 +1413,8 @@ int readgame(const char *filename, int backup)
getchar(); getchar();
} }
} }
else if (gdata.version >= SAVEXMLNAME_VERSION) { else {
char basefile[32]; READ_STR(&store, NULL, 0);
READ_STR(&store, basefile, sizeof(basefile));
} }
a_read(&store, &global.attribs, NULL); a_read(&store, &global.attribs, NULL);
READ_INT(&store, &turn); READ_INT(&store, &turn);
@ -1576,9 +1485,7 @@ int readgame(const char *filename, int backup)
} }
/* Read factions */ /* Read factions */
if (gdata.version >= ALLIANCES_VERSION) {
read_alliances(&store); read_alliances(&store);
}
READ_INT(&store, &nread); READ_INT(&store, &nread);
log_printf(stdout, " - Einzulesende Parteien: %d\n", nread); log_printf(stdout, " - Einzulesende Parteien: %d\n", nread);
fp = &factions; fp = &factions;
@ -1594,14 +1501,6 @@ int readgame(const char *filename, int backup)
} }
*fp = 0; *fp = 0;
/* ignore the obsolete list of "used" faction ids */
if (gdata.version < STORAGE_VERSION) {
READ_INT(&store, &i);
while (i--) {
READ_INT(&store, &n);
}
}
/* Regionen */ /* Regionen */
READ_INT(&store, &nread); READ_INT(&store, &nread);
@ -1878,9 +1777,7 @@ int writegame(const char *filename)
} }
/* Write factions */ /* Write factions */
#if RELEASE_VERSION>=ALLIANCES_VERSION
write_alliances(&gdata); write_alliances(&gdata);
#endif
n = listlen(factions); n = listlen(factions);
WRITE_INT(&store, n); WRITE_INT(&store, n);
WRITE_SECTION(&store); WRITE_SECTION(&store);
@ -1975,9 +1872,6 @@ void a_writeint(const attrib * a, const void *owner, struct storage *store)
int a_readshorts(attrib * a, void *owner, struct storage *store) int a_readshorts(attrib * a, void *owner, struct storage *store)
{ {
int n; int n;
if (global.data_version < ATTRIBREAD_VERSION) {
return a_readint(a, store, owner);
}
READ_INT(store, &n); READ_INT(store, &n);
a->data.sa[0] = (short)n; a->data.sa[0] = (short)n;
READ_INT(store, &n); READ_INT(store, &n);
@ -1994,9 +1888,6 @@ void a_writeshorts(const attrib * a, const void *owner, struct storage *store)
int a_readchars(attrib * a, void *owner, struct storage *store) int a_readchars(attrib * a, void *owner, struct storage *store)
{ {
int i; int i;
if (global.data_version < ATTRIBREAD_VERSION) {
return a_readint(a, store, owner);
}
for (i = 0; i != 4; ++i) { for (i = 0; i != 4; ++i) {
int n; int n;
READ_INT(store, &n); READ_INT(store, &n);
@ -2016,9 +1907,6 @@ void a_writechars(const attrib * a, const void *owner, struct storage *store)
int a_readvoid(attrib * a, void *owner, struct storage *store) int a_readvoid(attrib * a, void *owner, struct storage *store)
{ {
if (global.data_version < ATTRIBREAD_VERSION) {
return a_readint(a, store, owner);
}
return AT_READ_OK; return AT_READ_OK;
} }

View file

@ -10,52 +10,6 @@
without prior permission by the authors of Eressea. without prior permission by the authors of Eressea.
*/ */
/* changes from->to: 72->73: struct unit::lock entfernt.
* 73->74: struct unit::flags eingeführt.
* 74->75: parteitarnung als flag.
* 75->76: #ifdef NEW_HP: hp
* 76->77: ship->damage
* 77->78: neue Message-Option "Orkvermehrung" (MAX_MSG +1)
* 78->79: showdata nicht mehr speichern
* 79->HEX_VERSION: hex
* 80->82: ATTRIB_VERSION
* 90: Ebenen
* 92: Magiegebiet-Auswahl f->magiegebiet
* 94: f->attribs wird gespeichert
* 100: NEWMAGIC, neue Message-Option "Zauber" (MAX_MSG +1)
* 108: Speichern von Timeouts
* 193: curse bekommen id aus struct unit-nummernraum
*/
/*
#define HEX_VERSION 81
#define GROWTREE_VERSION 305
#define RANDOMIZED_RESOURCES_VERSION 306
#define NEWRACE_VERSION 307
#define INTERIM_VERSION 309
#define NEWSKILL_VERSION 309
#define WATCHERS_VERSION 310
#define OVERRIDE_VERSION 311
*/
#define CURSETYPE_VERSION 312 /* turn 287 */
#define ALLIANCES_VERSION 313
#define DBLINK_VERSION 314
#define CURSEVIGOURISFLOAT_VERSION 315
#define SAVEXMLNAME_VERSION 316
#define SAVEALLIANCE_VERSION 317
#define CLAIM_VERSION 318
/* 319 is the HSE4 data version */
#define BACTION_VERSION 319 /* building action gets a param string */
#define NOLASTORDER_VERSION 320 /* do not use lastorder */
#define SPELLNAME_VERSION 321 /* reference spells by name */
#define TERRAIN_VERSION 322 /* terrains are a full type and saved by name */
#define REGIONITEMS_VERSION 323 /* regions have items */
#define ATTRIBREAD_VERSION 324 /* remove a_readint */
#define CURSEFLAGS_VERSION 325 /* remove a_readint */
#define UNICODE_VERSION 326 /* 2007-06-27 everything is stored as UTF8 */
#define UID_VERSION 327 /* regions have a unique id */
#define STORAGE_VERSION 328 /* with storage.h, some things are stored smarter (ids as base36, fractions as float) */
#define INTPAK_VERSION 329 /* in binary, ints can get packed */ #define INTPAK_VERSION 329 /* in binary, ints can get packed */
#define NOZEROIDS_VERSION 330 /* 2008-05-16 zero is not a valid ID for anything (including factions) */ #define NOZEROIDS_VERSION 330 /* 2008-05-16 zero is not a valid ID for anything (including factions) */
#define NOBORDERATTRIBS_VERSION 331 /* 2008-05-17 connection::attribs has been moved to userdata */ #define NOBORDERATTRIBS_VERSION 331 /* 2008-05-17 connection::attribs has been moved to userdata */
@ -74,6 +28,7 @@
#define SAVEGAMEID_VERSION 343 /* instead of XMLNAME, save the game.id parameter from the config */ #define SAVEGAMEID_VERSION 343 /* instead of XMLNAME, save the game.id parameter from the config */
#define BUILDNO_VERSION 344 /* storing the build number in the save */ #define BUILDNO_VERSION 344 /* storing the build number in the save */
#define AUTO_RACENAME_VERSION 345 /* NPC units with name==NULL will automatically get their race for a name */ #define AUTO_RACENAME_VERSION 345 /* NPC units with name==NULL will automatically get their race for a name */
#define MIN_VERSION INTPAK_VERSION /* minimal datafile we support */ #define MIN_VERSION INTPAK_VERSION /* minimal datafile we support */
#define RELEASE_VERSION AUTO_RACENAME_VERSION /* current datafile */ #define RELEASE_VERSION AUTO_RACENAME_VERSION /* current datafile */

View file

@ -151,7 +151,6 @@ static void age_unit(region * r, unit * u)
u_race(u)->age(u); u_race(u)->age(u);
} }
} }
#ifdef ASTRAL_ITEM_RESTRICTIONS
if (u->region && is_astral(u->region)) { if (u->region && is_astral(u->region)) {
item **itemp = &u->items; item **itemp = &u->items;
while (*itemp) { while (*itemp) {
@ -168,7 +167,6 @@ static void age_unit(region * r, unit * u)
itemp = &itm->next; itemp = &itm->next;
} }
} }
#endif
} }
static void live(region * r) static void live(region * r)
@ -3606,11 +3604,7 @@ void monthly_healing(void)
p *= heal_factor(u); p *= heal_factor(u);
if (u->hp < umhp) { if (u->hp < umhp) {
#ifdef NEW_DAEMONHUNGER_RULE
double maxheal = _max(u->number, umhp / 20.0); double maxheal = _max(u->number, umhp / 20.0);
#else
double maxheal = _max(u->number, umhp / 10.0);
#endif
int addhp; int addhp;
struct building *b = inside_building(u); struct building *b = inside_building(u);
const struct building_type *btype = b ? b->type : NULL; const struct building_type *btype = b ? b->type : NULL;

View file

@ -229,14 +229,6 @@ struct storage *store)
spell *sp; spell *sp;
char spname[64]; char spname[64];
if (global.data_version < SPELLNAME_VERSION) {
int i;
READ_INT(store, &i);
if (i < 0)
break;
sp = find_spellbyid((unsigned int)i);
}
else {
READ_TOK(store, spname, sizeof(spname)); READ_TOK(store, spname, sizeof(spname));
if (strcmp(spname, "end") == 0) if (strcmp(spname, "end") == 0)
break; break;
@ -244,7 +236,6 @@ struct storage *store)
if (!sp) { if (!sp) {
log_error("read_spells: could not find spell '%s' in school '%s'\n", spname, magic_school[mtype]); log_error("read_spells: could not find spell '%s' in school '%s'\n", spname, magic_school[mtype]);
} }
}
if (sp) { if (sp) {
add_spell(slistp, sp); add_spell(slistp, sp);
} }
@ -272,15 +263,6 @@ static int read_mage(attrib * a, void *owner, struct storage *store)
for (i = 0; i != MAXCOMBATSPELLS; ++i) { for (i = 0; i != MAXCOMBATSPELLS; ++i) {
spell *sp = NULL; spell *sp = NULL;
int level = 0; int level = 0;
if (global.data_version < SPELLNAME_VERSION) {
int spid;
READ_INT(store, &spid);
READ_INT(store, &level);
if (spid >= 0) {
sp = find_spellbyid((unsigned int)spid);
}
}
else {
READ_TOK(store, spname, sizeof(spname)); READ_TOK(store, spname, sizeof(spname));
READ_INT(store, &level); READ_INT(store, &level);
@ -290,7 +272,6 @@ static int read_mage(attrib * a, void *owner, struct storage *store)
log_error("read_mage: could not find combat spell '%s' in school '%s'\n", spname, magic_school[mage->magietyp]); log_error("read_mage: could not find combat spell '%s' in school '%s'\n", spname, magic_school[mage->magietyp]);
} }
} }
}
if (sp && level >= 0) { if (sp && level >= 0) {
int slot = -1; int slot = -1;
if (sp->sptyp & PRECOMBATSPELL) if (sp->sptyp & PRECOMBATSPELL)

View file

@ -24,14 +24,11 @@
#define NEWATSROI 0 #define NEWATSROI 0
/* Vermehrungsrate Bauern in 1/10000. /* Vermehrungsrate Bauern in 1/10000.
* Evt. Berechnungsfehler, reale Vermehrungsraten scheinen höher. */ * TODO: Evt. Berechnungsfehler, reale Vermehrungsraten scheinen höher. */
#define PEASANTGROWTH 10 #define PEASANTGROWTH 10
#define BATTLE_KILLS_PEASANTS 20 #define BATTLE_KILLS_PEASANTS 20
#define PEASANTLUCK 10 #define PEASANTLUCK 10
#define ASTRAL_ITEM_RESTRICTIONS /* keine grossen dinge im astralraum */
#define NEW_DAEMONHUNGER_RULE
#define NEW_COMBATSKILLS_RULE
#define ROW_FACTOR 3 /* factor for combat row advancement rule */ #define ROW_FACTOR 3 /* factor for combat row advancement rule */
/* optional game components. TODO: These should either be /* optional game components. TODO: These should either be
@ -42,14 +39,5 @@
#define MUSEUM_MODULE 1 #define MUSEUM_MODULE 1
#define ARENA_MODULE 1 #define ARENA_MODULE 1
#define CHANGED_CROSSBOWS 0 /* use the WTF_ARMORPIERCING flag */ #define CHANGED_CROSSBOWS 0 /* use the WTF_ARMORPIERCING flag */
#undef GLOBAL_WARMING /* number of turns before global warming sets in */
#if defined(BINDINGS_LUABIND)
# undef BINDINGS_TOLUA
#elif defined(BINDINGS_TOLUA)
# undef BINDINGS_LUABIND
#else
# define BINDINGS_TOLUA /* new default */
#endif
#undef REGIONOWNERS /* (WIP) region-owner uses HELP_TRAVEL to control entry to region */ #undef REGIONOWNERS /* (WIP) region-owner uses HELP_TRAVEL to control entry to region */

View file

@ -174,17 +174,8 @@ static void wall_read(connection * b, storage * store)
{ {
static wall_data dummy; static wall_data dummy;
wall_data *fd = b->data.v ? (wall_data *) b->data.v : &dummy; wall_data *fd = b->data.v ? (wall_data *) b->data.v : &dummy;
variant mno;
if (global.data_version < STORAGE_VERSION) {
READ_INT(store, &mno.i);
fd->mage = findunit(mno.i);
if (!fd->mage && b->data.v) {
ur_add(mno, &fd->mage, resolve_unit);
}
} else {
read_reference(&fd->mage, store, read_unit_reference, resolve_unit); read_reference(&fd->mage, store, read_unit_reference, resolve_unit);
}
READ_INT(store, &fd->force); READ_INT(store, &fd->force);
if (global.data_version >= NOBORDERATTRIBS_VERSION) { if (global.data_version >= NOBORDERATTRIBS_VERSION) {
READ_INT(store, &fd->countdown); READ_INT(store, &fd->countdown);

View file

@ -53,7 +53,8 @@ static message *cinfo_auraboost(const void *obj, objtype_t typ, const curse * c,
if (self != 0) { if (self != 0) {
if (curse_geteffect(c) > 100) { if (curse_geteffect(c) > 100) {
return msg_message("curseinfo::auraboost_0", "unit id", u, c->no); return msg_message("curseinfo::auraboost_0", "unit id", u, c->no);
} else { }
else {
return msg_message("curseinfo::auraboost_1", "unit id", u, c->no); return msg_message("curseinfo::auraboost_1", "unit id", u, c->no);
} }
} }
@ -312,12 +313,7 @@ static struct curse_type ct_magicresistance = {
static int read_skill(struct storage *store, curse * c, void *target) static int read_skill(struct storage *store, curse * c, void *target)
{ {
int skill; int skill;
if (global.data_version < CURSETYPE_VERSION) {
READ_INT(store, &skill); READ_INT(store, &skill);
READ_INT(store, 0); /* men, ignored */
} else {
READ_INT(store, &skill);
}
c->data.i = skill; c->data.i = skill;
return 0; return 0;
} }
@ -339,7 +335,8 @@ static message *cinfo_skillmod(const void *obj, objtype_t typ, const curse * c,
int sk = c->data.i; int sk = c->data.i;
if (c->effect > 0) { if (c->effect > 0) {
return msg_message("curseinfo::skill_1", "unit skill id", u, sk, c->no); return msg_message("curseinfo::skill_1", "unit skill id", u, sk, c->no);
} else if (c->effect < 0) { }
else if (c->effect < 0) {
return msg_message("curseinfo::skill_2", "unit skill id", u, sk, c->no); return msg_message("curseinfo::skill_2", "unit skill id", u, sk, c->no);
} }
} }

View file

@ -328,13 +328,8 @@ int teach_cmd(unit * u, struct order *ord)
} while (sk != NOSKILL); } while (sk != NOSKILL);
while (teaching && student) { while (teaching && student) {
if (student->faction == u->faction) { if (student->faction == u->faction) {
#ifdef NEW_DAEMONHUNGER_RULE
if (LongHunger(student)) if (LongHunger(student))
continue; continue;
#else
if (fval(student, UFL_HUNGER))
continue;
#endif
if (getkeyword(student->thisorder) == K_STUDY) { if (getkeyword(student->thisorder) == K_STUDY) {
/* Input ist nun von student->thisorder !! */ /* Input ist nun von student->thisorder !! */
init_order(student->thisorder); init_order(student->thisorder);
@ -358,13 +353,8 @@ int teach_cmd(unit * u, struct order *ord)
while (teaching && student) { while (teaching && student) {
if (student->faction != u->faction if (student->faction != u->faction
&& alliedunit(u, student->faction, HELP_GUARD)) { && alliedunit(u, student->faction, HELP_GUARD)) {
#ifdef NEW_DAEMONHUNGER_RULE
if (LongHunger(student)) if (LongHunger(student))
continue; continue;
#else
if (fval(student, UFL_HUNGER))
continue;
#endif
if (getkeyword(student->thisorder) == K_STUDY) { if (getkeyword(student->thisorder) == K_STUDY) {
/* Input ist nun von student->thisorder !! */ /* Input ist nun von student->thisorder !! */
init_order(student->thisorder); init_order(student->thisorder);

View file

@ -73,7 +73,8 @@ static int createcurse_handle(trigger * t, void *data)
if (td->mage && td->target && td->mage->number && td->target->number) { if (td->mage && td->target && td->mage->number && td->target->number) {
create_curse(td->mage, &td->target->attribs, create_curse(td->mage, &td->target->attribs,
td->type, td->vigour, td->duration, td->effect, td->men); td->type, td->vigour, td->duration, td->effect, td->men);
} else { }
else {
log_error("could not perform createcurse::handle()\n"); log_error("could not perform createcurse::handle()\n");
} }
unused_arg(data); unused_arg(data);
@ -100,18 +101,6 @@ static int createcurse_read(trigger * t, struct storage *store)
read_reference(&td->mage, store, read_unit_reference, resolve_unit); read_reference(&td->mage, store, read_unit_reference, resolve_unit);
read_reference(&td->target, store, read_unit_reference, resolve_unit); read_reference(&td->target, store, read_unit_reference, resolve_unit);
if (global.data_version < CURSETYPE_VERSION) {
int id1, id2, n;
READ_INT(store, &id1);
READ_INT(store, &id2);
assert(id2 == 0);
READ_FLT(store, &td->vigour);
READ_INT(store, &td->duration);
READ_INT(store, &n);
td->effect = (float)n;
READ_INT(store, &td->men);
td->type = ct_find(oldcursename(id1));
} else {
READ_TOK(store, zText, sizeof(zText)); READ_TOK(store, zText, sizeof(zText));
td->type = ct_find(zText); td->type = ct_find(zText);
READ_FLT(store, &td->vigour); READ_FLT(store, &td->vigour);
@ -120,11 +109,11 @@ static int createcurse_read(trigger * t, struct storage *store)
int n; int n;
READ_INT(store, &n); READ_INT(store, &n);
td->effect = (float)n; td->effect = (float)n;
} else { }
else {
READ_FLT(store, &td->effect); READ_FLT(store, &td->effect);
} }
READ_INT(store, &td->men); READ_INT(store, &td->men);
}
return AT_READ_OK; return AT_READ_OK;
} }

View file

@ -74,39 +74,16 @@ static int a_agedirection(attrib * a)
static int a_readdirection(attrib * a, void *owner, struct storage *store) static int a_readdirection(attrib * a, void *owner, struct storage *store)
{ {
spec_direction *d = (spec_direction *)(a->data.v); spec_direction *d = (spec_direction *)(a->data.v);
char lbuf[32];
(void) owner; (void) owner;
READ_INT(store, &d->x); READ_INT(store, &d->x);
READ_INT(store, &d->y); READ_INT(store, &d->y);
READ_INT(store, &d->duration); READ_INT(store, &d->duration);
if (global.data_version < UNICODE_VERSION) {
char lbuf[16];
dir_lookup *dl = dir_name_lookup;
READ_TOK(store, NULL, 0);
READ_TOK(store, lbuf, sizeof(lbuf));
untilde(lbuf);
for (; dl; dl = dl->next) {
if (strcmp(lbuf, dl->oldname) == 0) {
d->keyword = _strdup(dl->name);
_snprintf(lbuf, sizeof(lbuf), "%s_desc", d->keyword);
d->desc = _strdup(dl->name);
break;
}
}
if (dl == NULL) {
log_error("unknown spec_direction '%s'\n", lbuf);
assert(!"not implemented");
}
}
else {
char lbuf[32];
READ_TOK(store, lbuf, sizeof(lbuf)); READ_TOK(store, lbuf, sizeof(lbuf));
d->desc = _strdup(lbuf); d->desc = _strdup(lbuf);
READ_TOK(store, lbuf, sizeof(lbuf)); READ_TOK(store, lbuf, sizeof(lbuf));
d->keyword = _strdup(lbuf); d->keyword = _strdup(lbuf);
}
d->active = true; d->active = true;
return AT_READ_OK; return AT_READ_OK;
} }