fix permanent smurfs
This commit is contained in:
Enno Rehling 2021-03-18 21:02:22 +01:00
parent 1370b63b8b
commit 16edaf9dba
2 changed files with 23 additions and 18 deletions

View file

@ -287,22 +287,19 @@ struct order *ord)
change_effect(u, itype, 100 * amount);
}
else {
const race *irace = u_irace(u);
if (irace == u_race(u)) {
const race *rcfailure = rc_find("smurf");
if (!rcfailure) {
rcfailure = rc_find("toad");
}
if (rcfailure) {
trigger *trestore = trigger_changerace(u, u_race(u), irace);
if (trestore) {
int duration = 2 + rng_int() % 8;
const race *rcfailure = rc_find("smurf");
if (!rcfailure) {
rcfailure = rc_find("toad");
}
if (rcfailure) {
trigger *trestore = trigger_changerace(u, u_race(u), u->irace);
if (trestore) {
int duration = 2 + rng_int() % 8;
add_trigger(&u->attribs, "timer", trigger_timeout(duration,
trestore));
u->irace = NULL;
u_setrace(u, rcfailure);
}
add_trigger(&u->attribs, "timer", trigger_timeout(duration,
trestore));
u->irace = NULL;
u_setrace(u, rcfailure);
}
}
}

View file

@ -383,11 +383,12 @@ unit *read_unit(gamedata *data)
char obuf[DISPLAYSIZE];
faction *f;
char rname[32];
static const struct race * rc_demon;
static const struct race *rc_demon, *rc_smurf;
static int config;
if (rc_changed(&config)) {
rc_demon = get_race(RC_DAEMON);
rc_smurf = rc_find("smurf");
}
READ_INT(data->store, &n);
@ -529,11 +530,18 @@ unit *read_unit(gamedata *data)
}
read_attribs(data, &u->attribs, u);
if (rc_demon) {
if (u_race(u) == rc_demon) {
const struct race *rc = u_race(u);
if (rc == rc_smurf) {
if (!u->attribs) {
log_error("%s was a %s in a %s faction", unitname(u), rc->_name, u->faction->race->_name);
u->_race = u->faction->race;
}
}
if (rc == rc_demon) {
if (data->version < FIX_SHAPESHIFT_VERSION) {
const char* zRace = get_racename(u->attribs);
if (zRace) {
const struct race* rc = rc_find(zRace);
rc = rc_find(zRace);
if (rc) {
set_racename(&u->attribs, NULL);
u->irace = rc;