Durch GIB "leer" gewordene Schiffe können nicht sinken.

This commit is contained in:
Enno Rehling 2020-06-27 10:09:30 +02:00
parent 48e4caf496
commit ed0b7f8af2
3 changed files with 30 additions and 17 deletions

View file

@ -302,7 +302,12 @@ static void transfer_ships(ship *s1, ship *s2, int n)
if (s1->coast != NODIRECTION) { if (s1->coast != NODIRECTION) {
s2->coast = s1->coast; s2->coast = s1->coast;
} }
scale_ship(s1, s1->number - n); if (n == s1->number) {
s1->number = 0;
}
else {
scale_ship(s1, s1->number - n);
}
} }
static void transfer_units(ship *s1, ship *s2) static void transfer_units(ship *s1, ship *s2)

View file

@ -510,12 +510,15 @@ void ship_update_owner(ship * sh) {
unit *ship_owner(const ship * sh) unit *ship_owner(const ship * sh)
{ {
unit *owner = sh->_owner; if (sh->number > 0) {
if (!owner || (owner->ship != sh || owner->number <= 0)) { unit *owner = sh->_owner;
unit * heir = ship_owner_ex(sh, owner ? owner->faction : 0); if (!owner || (owner->ship != sh || owner->number <= 0)) {
return (heir && heir->number > 0) ? heir : 0; unit * heir = ship_owner_ex(sh, owner ? owner->faction : 0);
return (heir && heir->number > 0) ? heir : 0;
}
return owner;
} }
return owner; return NULL;
} }
void write_ship_reference(const struct ship *sh, struct storage *store) void write_ship_reference(const struct ship *sh, struct storage *store)

View file

@ -2584,22 +2584,27 @@ void sinkships(struct region * r)
while (*shp) { while (*shp) {
ship *sh = *shp; ship *sh = *shp;
if (!sh->type->construction || sh->size >= sh->type->construction->maxsize) { if (sh->number > 0) {
if (fval(r->terrain, SEA_REGION)) { if (!sh->type->construction || sh->size >= sh->type->construction->maxsize) {
if (!ship_crewed(sh)) { if (fval(r->terrain, SEA_REGION)) {
/* ship is at sea, but not enough people to control it */ if (!ship_crewed(sh)) {
double dmg = config_get_flt("rules.ship.damage.nocrewocean", 0.3); /* ship is at sea, but not enough people to control it */
double dmg = config_get_flt("rules.ship.damage.nocrewocean", 0.3);
damage_ship(sh, dmg);
}
}
else if (!ship_owner(sh)) {
/* any ship lying around without an owner slowly rots */
double dmg = config_get_flt("rules.ship.damage.nocrew", 0.05);
damage_ship(sh, dmg); damage_ship(sh, dmg);
} }
} }
else if (!ship_owner(sh)) { if (sh->damage >= sh->size * DAMAGE_SCALE) {
/* any ship lying around without an owner slowly rots */ sink_ship(sh);
double dmg = config_get_flt("rules.ship.damage.nocrew", 0.05); remove_ship(shp, sh);
damage_ship(sh, dmg);
} }
} }
if (sh->damage >= sh->size * DAMAGE_SCALE) { else {
sink_ship(sh);
remove_ship(shp, sh); remove_ship(shp, sh);
} }
if (*shp == sh) if (*shp == sh)