forked from github/server
Bugfix 1922 entering of RF_BLOCKED regions with ships
This commit is contained in:
parent
d2cee21af5
commit
74ddb1f881
2 changed files with 46 additions and 1 deletions
|
@ -917,6 +917,50 @@ function test_parser()
|
||||||
assert_not_equal(0, u:get_skill("melee"))
|
assert_not_equal(0, u:get_skill("melee"))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function test_bug_1922()
|
||||||
|
-- see http://bugs.eressea.de/view.php?id=1922
|
||||||
|
local r = region.create(0, 0, "ocean")
|
||||||
|
local r2 = region.create(1, 0, "plain")
|
||||||
|
r2:set_flag(2) -- region should not be accessible
|
||||||
|
|
||||||
|
local f = faction.create("noreply@eressea.de", "human", "de")
|
||||||
|
local u = unit.create(f, r, 1)
|
||||||
|
|
||||||
|
local s = _test_create_ship(r)
|
||||||
|
|
||||||
|
settings.set("rules.ship.drifting","0") -- ships are not drifting
|
||||||
|
settings.set("rules.economy.food","4") -- does not need silver
|
||||||
|
|
||||||
|
u.ship = s
|
||||||
|
u:clear_orders()
|
||||||
|
u:add_order("NACH O")
|
||||||
|
u:set_skill("sailing",120) -- supadupa captain able to drive a trireme
|
||||||
|
process_orders()
|
||||||
|
assert_not_equal(r2,u.region) -- unit should not reach r2.
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function test_bug_1922_by_foot()
|
||||||
|
-- see http://bugs.eressea.de/view.php?id=1922
|
||||||
|
local r = region.create(0, 0, "plain")
|
||||||
|
local r2 = region.create(1, 0, "plain")
|
||||||
|
r2:set_flag(2) -- region should not be accessible
|
||||||
|
|
||||||
|
local f = faction.create("noreply@eressea.de", "human", "de")
|
||||||
|
local u = unit.create(f, r, 1)
|
||||||
|
|
||||||
|
settings.set("rules.economy.food","4") -- does not need silver
|
||||||
|
|
||||||
|
u:clear_orders()
|
||||||
|
u:add_order("NACH O")
|
||||||
|
|
||||||
|
process_orders()
|
||||||
|
assert_not_equal(r2,u.region) -- unit should not reach r2.
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
function test_bug_1814()
|
function test_bug_1814()
|
||||||
-- see http://bugs.eressea.de/view.php?id=1814
|
-- see http://bugs.eressea.de/view.php?id=1814
|
||||||
local r = region.create(0, 0, "mountain")
|
local r = region.create(0, 0, "mountain")
|
||||||
|
|
|
@ -704,6 +704,7 @@ static float damage_drift(void)
|
||||||
static void drifting_ships(region * r)
|
static void drifting_ships(region * r)
|
||||||
{
|
{
|
||||||
direction_t d;
|
direction_t d;
|
||||||
|
if (get_param_int(global.parameters, "rules.ship.drifting", 1)==0) return;
|
||||||
|
|
||||||
if (fval(r->terrain, SEA_REGION)) {
|
if (fval(r->terrain, SEA_REGION)) {
|
||||||
ship **shp = &r->ships;
|
ship **shp = &r->ships;
|
||||||
|
@ -1718,7 +1719,7 @@ sail(unit * u, order * ord, boolean move_on_land, region_list ** routep)
|
||||||
|
|
||||||
assert(sh == u->ship || !"ship has sunk, but we didn't notice it");
|
assert(sh == u->ship || !"ship has sunk, but we didn't notice it");
|
||||||
|
|
||||||
if (fval(next_point->terrain, FORBIDDEN_REGION)) {
|
if (fval(next_point->terrain, FORBIDDEN_REGION)||fval(next_point,RF_BLOCKED)) {
|
||||||
ADDMSG(&f->msgs, msg_message("sailforbidden",
|
ADDMSG(&f->msgs, msg_message("sailforbidden",
|
||||||
"ship region", sh, next_point));
|
"ship region", sh, next_point));
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue