Lua unit:cast_spell should only cast spells the unit knows.

do not allow payment for spells cast at level <= 0
This commit is contained in:
Enno Rehling 2012-05-29 20:50:20 -07:00
parent 44e5c60c96
commit 3e67e7fb4e
3 changed files with 29 additions and 19 deletions

View file

@ -34,8 +34,8 @@ function test_spell_not_found_no_payment()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("spell_fails_no_payment@eressea.de", "human", "de") local f = faction.create("spell_fails_no_payment@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u:set_skill("magic", 12)
u.magic = "gwyrrd" -- calls create_mage u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 12)
local permaura = u:get_pooled("permaura") local permaura = u:get_pooled("permaura")
u:add_item("money", 3000) u:add_item("money", 3000)
@ -55,6 +55,7 @@ function test_create_firesword()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("create_firesword@eressea.de", "human", "de") local f = faction.create("create_firesword@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 12) u:set_skill("magic", 12)
u:add_spell("create_firesword") u:add_spell("create_firesword")
@ -66,8 +67,10 @@ function test_create_roi()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("create_roi@eressea.de", "human", "de") local f = faction.create("create_roi@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 10) u:set_skill("magic", 10)
u:add_spell('create_roi')
u:cast_spell('create_roi') u:cast_spell('create_roi')
assert_equal(1, u:get_item("roi")) assert_equal(1, u:get_item("roi"))
end end
@ -76,8 +79,10 @@ function test_create_roqf()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("create_roqf@eressea.de", "human", "de") local f = faction.create("create_roqf@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 10) u:set_skill("magic", 10)
u:add_spell('create_roqf')
u:cast_spell('create_roqf') u:cast_spell('create_roqf')
assert_equal(1, u:get_item("roqf")) assert_equal(1, u:get_item("roqf"))
end end
@ -86,8 +91,10 @@ function test_create_aots()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("create_aots@eressea.de", "human", "de") local f = faction.create("create_aots@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 10) u:set_skill("magic", 10)
u:add_spell('create_aots')
u:cast_spell('create_aots') u:cast_spell('create_aots')
assert_equal(1, u:get_item("aots")) assert_equal(1, u:get_item("aots"))
end end
@ -96,8 +103,10 @@ function test_create_ror()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("create_ror@eressea.de", "human", "de") local f = faction.create("create_ror@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 10) u:set_skill("magic", 10)
u:add_spell('create_ror')
u:cast_spell('create_ror') u:cast_spell('create_ror')
assert_equal(1, u:get_item("ror")) assert_equal(1, u:get_item("ror"))
end end
@ -106,8 +115,10 @@ function test_create_magicherbbag()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("create_magicherbbag@eressea.de", "human", "de") local f = faction.create("create_magicherbbag@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 10) u:set_skill("magic", 10)
u:add_spell('create_magicherbbag')
u:cast_spell('create_magicherbbag') u:cast_spell('create_magicherbbag')
assert_equal(1, u:get_item("magicherbbag")) assert_equal(1, u:get_item("magicherbbag"))
end end
@ -116,8 +127,10 @@ function test_create_trollbelt()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("create_trollbelt@eressea.de", "human", "de") local f = faction.create("create_trollbelt@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 10) u:set_skill("magic", 10)
u:add_spell('create_trollbelt')
u:cast_spell('create_trollbelt') u:cast_spell('create_trollbelt')
assert_equal(1, u:get_item("trollbelt")) assert_equal(1, u:get_item("trollbelt"))
end end
@ -126,8 +139,10 @@ function test_create_dreameye()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("create_dreameye@eressea.de", "human", "de") local f = faction.create("create_dreameye@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 10) u:set_skill("magic", 10)
u:add_spell('create_dreameye')
u:cast_spell('create_dreameye') u:cast_spell('create_dreameye')
assert_equal(1, u:get_item("dreameye")) assert_equal(1, u:get_item("dreameye"))
end end
@ -136,8 +151,10 @@ function test_create_antimagic()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("create_antimagic@eressea.de", "human", "de") local f = faction.create("create_antimagic@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 10) u:set_skill("magic", 10)
u:add_spell('create_antimagic')
u:cast_spell('create_antimagic') u:cast_spell('create_antimagic')
assert_equal(1, u:get_item("antimagic")) assert_equal(1, u:get_item("antimagic"))
end end
@ -146,8 +163,10 @@ function test_create_runesword()
local r = region.create(0,0, "plain") local r = region.create(0,0, "plain")
local f = faction.create("create_runesword@eressea.de", "human", "de") local f = faction.create("create_runesword@eressea.de", "human", "de")
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u.magic = "gwyrrd" -- calls create_mage
u:set_skill("magic", 10) u:set_skill("magic", 10)
u:add_spell('create_runesword')
u:cast_spell('create_runesword') u:cast_spell('create_runesword')
assert_equal(1, u:get_item("runesword")) assert_equal(1, u:get_item("runesword"))
end end
@ -158,6 +177,7 @@ function test_create_rop()
local u = unit.create(f, r, 1) local u = unit.create(f, r, 1)
u:set_skill("magic", 10) u:set_skill("magic", 10)
u:add_spell('create_rop')
u:cast_spell('create_rop') u:cast_spell('create_rop')
assert_equal(1, u:get_item("rop")) assert_equal(1, u:get_item("rop"))
end end

View file

@ -32,6 +32,7 @@ without prior permission by the authors of Eressea.
#include <kernel/pool.h> #include <kernel/pool.h>
#include <kernel/race.h> #include <kernel/race.h>
#include <kernel/region.h> #include <kernel/region.h>
#include <kernel/spellbook.h>
#include <kernel/ship.h> #include <kernel/ship.h>
#include <kernel/skill.h> #include <kernel/skill.h>
#include <kernel/spell.h> #include <kernel/spell.h>
@ -455,12 +456,11 @@ static int tolua_unit_addnotice(lua_State * L)
static void unit_castspell(unit * u, const char *name, int level) static void unit_castspell(unit * u, const char *name, int level)
{ {
quicklist *ql = spells; spell *sp = find_spell(name);
int qi;
for (ql = spells, qi = 0; ql; ql_advance(&ql, &qi, 1)) { if (sp) {
spell *sp = (spell *) ql_get(ql, qi); spellbook *book = unit_get_spellbook(u);
if (strcmp(name, sp->sname) == 0) { if (spellbook_get(book, sp)) {
if (!sp->cast) { if (!sp->cast) {
log_error("spell '%s' has no function.\n", sp->sname); log_error("spell '%s' has no function.\n", sp->sname);
} else { } else {

View file

@ -152,19 +152,9 @@ void test_pay_spell_failure(CuTest * tc)
CuAssertIntEquals(tc, 3, change_resource(u, rt_find("aura"), 3)); CuAssertIntEquals(tc, 3, change_resource(u, rt_find("aura"), 3));
CuAssertIntEquals(tc, 2, change_resource(u, rt_find("horse"), 1)); CuAssertIntEquals(tc, 2, change_resource(u, rt_find("horse"), 1));
level = eff_spelllevel(u, sp, 3, 1); CuAssertIntEquals(tc, 0, eff_spelllevel(u, sp, 3, 1));
CuAssertIntEquals(tc, 0, level); CuAssertIntEquals(tc, 0, change_resource(u, rt_find("money"), -1));
pay_spell(u, sp, level, 1); CuAssertIntEquals(tc, 0, eff_spelllevel(u, sp, 2, 1));
CuAssertIntEquals(tc, 0, get_resource(u, rt_find("money"))); /* seems we even pay this at level 0 */
CuAssertIntEquals(tc, 3, get_resource(u, rt_find("aura")));
CuAssertIntEquals(tc, 2, get_resource(u, rt_find("horse")));
level = eff_spelllevel(u, sp, 2, 1);
CuAssertIntEquals(tc, 0, level);
pay_spell(u, sp, level, 1);
CuAssertIntEquals(tc, 0, get_resource(u, rt_find("money")));
CuAssertIntEquals(tc, 3, get_resource(u, rt_find("aura")));
CuAssertIntEquals(tc, 2, get_resource(u, rt_find("horse")));
} }
void test_getspell_unit(CuTest * tc) void test_getspell_unit(CuTest * tc)