GIB unit n SCHIFF implementiert.

This commit is contained in:
Enno Rehling 2019-10-07 21:45:49 +02:00
parent 39e3001a50
commit f4011af784
7 changed files with 90 additions and 18 deletions

View file

@ -2768,6 +2768,12 @@ msgstr "\"$unit($unit) verspeiste $int($amount) Bauern.\""
msgid "error320"
msgstr "\"$unit($unit) in $region($region): '$order($command)' - Die Einheit kann nicht bewachen, da sie versucht zu fliehen.\""
msgid "error321"
msgstr "\"$unit($unit) in $region($region): '$order($command)' - Die Einheit gehört nicht zu unserer Partei.\""
msgid "error322"
msgstr "\"$unit($unit) in $region($region): '$order($command)' - Die Einheit ist bereits auf einem Schiff.\""
msgid "dissolve_units_2"
msgstr "\"$unit($unit) in $region($region): $int($number) $race($race,$number) $if($eq($number,1),\"wurde zum Baum\", \"wurden zu Bäumen\").\""

View file

@ -190,3 +190,38 @@ function test_give_ship_merge()
assert_equal(1, u1.ship.number)
assert_equal(2, u2.ship.number)
end
function test_give_ship_max()
local r = region.create(1, 0, 'plain')
local f = faction.create("human")
local u1 = unit.create(f, r, 1)
local u2 = unit.create(f, r, 1)
local sh = ship.create(r, 'boat')
sh.number = 3
sh.damage = 9
sh.size = 12
u1.ship = sh
u1:add_order("GIB " .. itoa36(u2.id) .. " 4 SCHIFF")
process_orders()
assert_equal(1, u1.ship.number)
assert_equal(3, u1.ship.damage)
assert_equal(4, u1.ship.size)
assert_equal(2, u2.ship.number)
assert_equal(6, u2.ship.damage)
assert_equal(8, u2.ship.size)
end
function test_give_ship_self_only()
local r = region.create(1, 0, 'plain')
local f1 = faction.create("human")
local f2 = faction.create("human")
local u1 = unit.create(f1, r, 1)
local u2 = unit.create(f2, r, 1)
local sh = ship.create(r, 'boat')
sh.number = 2
u1.ship = sh
u1:add_order("GIB " .. itoa36(u2.id) .. " 1 SCHIFF")
process_orders()
assert_equal(2, u1.ship.number)
assert_equal(nil, u2.ship)
end

View file

@ -49,8 +49,7 @@ static int tolua_ship_set_number(lua_State * L)
{
ship *sh = (ship *)tolua_tousertype(L, 1, NULL);
int n = (int)tolua_tonumber(L, 2, 0);
sh->number = n;
sh->size += sh->type->construction->maxsize;
scale_ship(sh, n);
return 0;
}

View file

@ -293,8 +293,40 @@ bool rule_transfermen(void)
return rule != 0;
}
message * give_ship(unit *u, unit *u2, int n, order *ord) {
static void transfer_ships(ship *s1, ship *s2, int n)
{
assert(n < s1->number);
s2->damage += s1->damage * n / s1->number;
s2->size += s1->size * n / s1->number;
s2->number += n;
scale_ship(s1, s1->number - n);
}
message * give_ship(unit *u, unit *u2, int n, order *ord)
{
assert(u->ship);
assert(n > 0 && n < u->ship->number);
if (u->faction != u2->faction) {
return msg_error(u, ord, 321);
}
if (u2->ship) {
if (u2->ship->type != u->ship->type) {
return msg_error(u, ord, 322);
}
transfer_ships(u->ship, u2->ship, n);
}
else{
if (fval(u_race(u2), RCF_CANSAIL)) {
ship * sh = new_ship(u->ship->type, u->region, u->faction->locale);
scale_ship(sh, 0);
u_set_ship(u2, sh);
transfer_ships(u->ship, sh, n);
}
else {
return msg_error(u, ord, 233);
}
}
if (u->ship->number < n) {
n = u->ship->number;
}
@ -661,18 +693,7 @@ static void give_all_items(unit *u, unit *u2, order *ord) {
}
else {
param_t p = findparam(s, u->faction->locale);
if (p == P_SHIP) {
if (u->ship) {
message * msg = give_ship(u, u2, u->ship->number, ord);
if (msg) {
ADDMSG(&u->faction->msgs, msg);
}
}
else {
cmistake(u, ord, 144, MSG_COMMERCE);
}
}
else if (p == P_PERSON) {
if (p == P_PERSON) {
if (!(u_race(u)->ec_flags & ECF_GIVEPERSON)) {
ADDMSG(&u->faction->msgs,
msg_feedback(u, ord, "race_noregroup", "race", u_race(u)));
@ -838,7 +859,11 @@ void give_cmd(unit * u, order * ord)
p = findparam(s, u->faction->locale);
if (p == P_SHIP) {
if (u->ship) {
message * msg = give_ship(u, u2, n, ord);
message * msg;
if (n >= u->ship->number) {
n = u->ship->number - 1;
}
msg = give_ship(u, u2, n, ord);
if (msg) {
ADDMSG(&u->faction->msgs, msg);
}

View file

@ -932,8 +932,7 @@ static void build_ship(unit * u, ship * sh, int want)
msg_message("buildship", "ship unit size", sh, u, n));
}
void
create_ship(unit * u, const struct ship_type *newtype, int want,
void create_ship(unit * u, const struct ship_type *newtype, int want,
order * ord)
{
ship *sh;

View file

@ -424,6 +424,13 @@ bool ship_crewed(const ship *sh) {
return (capskill >= ship_captain_minskill(sh)) && (sumskill >= sh->type->sumskill * sh->number);
}
void scale_ship(ship *sh, int n)
{
sh->size = sh->size * n / sh->number;
sh->damage = sh->damage * n / sh->number;
sh->number = n;
}
int ship_capacity(const ship * sh)
{
if (ship_finished(sh)) {

View file

@ -122,6 +122,7 @@ extern "C" {
int ship_captain_minskill(const struct ship *sh);
int ship_damage_percent(const struct ship *sh);
void scale_ship(struct ship *sh, int n);
#ifdef __cplusplus
}
#endif