forked from github/server
spells.lua is a bad file for example and meropis, it tests things that not every game has.
lua_pushinteger() must be new, I've never used it before. all tests in meropis and example pass.
This commit is contained in:
parent
916e5389c7
commit
cc9e95a2ab
2 changed files with 72 additions and 62 deletions
|
@ -13,52 +13,57 @@ function test_roi()
|
|||
u.race = "elf"
|
||||
u:set_skill("magic", 10)
|
||||
u:add_item("money", 3010)
|
||||
u:add_item("roi", 1)
|
||||
assert_equal(1, u:get_item("roi"))
|
||||
u.magic = "tybied"
|
||||
u.aura = 200
|
||||
u.ship = s1
|
||||
u:add_spell("create_roi")
|
||||
local err = u:add_spell("create_roi")
|
||||
assert_equal(0, err)
|
||||
u:clear_orders()
|
||||
u:add_order("ZAUBERE 'Erschaffe einen Ring der Unsichtbarkeit' ")
|
||||
process_orders()
|
||||
write_reports()
|
||||
assert_equal(1, u:get_item("roi"))
|
||||
assert_equal(2, u:get_item("roi"))
|
||||
end
|
||||
|
||||
function test_blessedharvest_lasts_n_turn()
|
||||
free_game()
|
||||
local r = region.create(0, 0, "plain")
|
||||
local f = faction.create("noreply@eressea.de", "halfling", "de")
|
||||
local u = unit.create(f, r)
|
||||
r:set_resource("peasant", 100)
|
||||
r:set_resource("money", 0)
|
||||
u:add_item("money", 1000)
|
||||
u.magic = "gwyrrd"
|
||||
u.race = "dwarf"
|
||||
u:set_skill("magic", 20)
|
||||
u.aura = 200
|
||||
u:add_spell("raindance")
|
||||
u:add_spell("blessedharvest")
|
||||
u:clear_orders()
|
||||
local level = 5
|
||||
u:add_order("ZAUBERE STUFE " .. level .. " Regentanz")
|
||||
assert_equal(0, r:get_resource("money"), 0)
|
||||
|
||||
local m = 0
|
||||
local p = 100
|
||||
for i=1,level+2 do
|
||||
process_orders()
|
||||
local income = p * 12
|
||||
p = r:get_resource("peasant")
|
||||
income = income - p * 10
|
||||
m = m + income
|
||||
-- print(i, m, p, r:get_resource("money"))
|
||||
if (i>level+1) then
|
||||
assert_not_equal(m, r:get_resource("money"))
|
||||
else
|
||||
assert_equal(m, r:get_resource("money"))
|
||||
end
|
||||
free_game()
|
||||
local r = region.create(0, 0, "plain")
|
||||
local f = faction.create("noreply@eressea.de", "halfling", "de")
|
||||
local u = unit.create(f, r)
|
||||
local err = 0
|
||||
r:set_resource("peasant", 100)
|
||||
r:set_resource("money", 0)
|
||||
u:add_item("money", 1000)
|
||||
u.magic = "gwyrrd"
|
||||
u.race = "dwarf"
|
||||
u:set_skill("magic", 20)
|
||||
u.aura = 200
|
||||
err = err + u:add_spell("raindance")
|
||||
err = err + u:add_spell("blessedharvest")
|
||||
assert_equal(0, err)
|
||||
|
||||
u:clear_orders()
|
||||
u:add_order("ARBEITEN")
|
||||
-- u:add_spell("raindance")
|
||||
end
|
||||
local level = 5
|
||||
u:add_order("ZAUBERE STUFE " .. level .. " Regentanz")
|
||||
assert_equal(0, r:get_resource("money"), 0)
|
||||
|
||||
local m = 0
|
||||
local p = 100
|
||||
for i=1,level+2 do
|
||||
process_orders()
|
||||
local income = p * 12
|
||||
p = r:get_resource("peasant")
|
||||
income = income - p * 10
|
||||
m = m + income
|
||||
-- print(i, m, p, r:get_resource("money"))
|
||||
if (i>level+1) then
|
||||
assert_not_equal(m, r:get_resource("money"))
|
||||
else
|
||||
assert_equal(m, r:get_resource("money"))
|
||||
end
|
||||
u:clear_orders()
|
||||
u:add_order("ARBEITEN")
|
||||
end
|
||||
end
|
||||
|
|
|
@ -48,8 +48,9 @@ without prior permission by the authors of Eressea.
|
|||
#include <lua.h>
|
||||
#include <tolua.h>
|
||||
|
||||
#include <limits.h>
|
||||
#include <assert.h>
|
||||
#include <errno.h>
|
||||
#include <limits.h>
|
||||
|
||||
static int
|
||||
tolua_unit_get_objects(lua_State* L)
|
||||
|
@ -168,7 +169,7 @@ static int tolua_unit_set_info(lua_State* L)
|
|||
static int tolua_unit_get_id(lua_State* L)
|
||||
{
|
||||
unit* self = (unit*) tolua_tousertype(L, 1, 0);
|
||||
tolua_pushnumber(L, (lua_Number)unit_getid(self));
|
||||
lua_pushinteger(L, unit_getid(self));
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -182,14 +183,14 @@ static int tolua_unit_set_id(lua_State* L)
|
|||
static int tolua_unit_get_hpmax(lua_State* L)
|
||||
{
|
||||
unit* self = (unit*) tolua_tousertype(L, 1, 0);
|
||||
tolua_pushnumber(L, (lua_Number)unit_max_hp(self));
|
||||
lua_pushinteger(L, unit_max_hp(self));
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int tolua_unit_get_hp(lua_State* L)
|
||||
{
|
||||
unit* self = (unit*) tolua_tousertype(L, 1, 0);
|
||||
tolua_pushnumber(L, (lua_Number)unit_gethp(self));
|
||||
lua_pushinteger(L, unit_gethp(self));
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -203,7 +204,7 @@ static int tolua_unit_set_hp(lua_State* L)
|
|||
static int tolua_unit_get_number(lua_State* L)
|
||||
{
|
||||
unit* self = (unit*) tolua_tousertype(L, 1, 0);
|
||||
tolua_pushnumber(L, (lua_Number)self->number);
|
||||
lua_pushinteger(L, self->number);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -223,7 +224,7 @@ static int tolua_unit_set_number(lua_State* L)
|
|||
static int tolua_unit_get_flags(lua_State* L)
|
||||
{
|
||||
unit* self = (unit*) tolua_tousertype(L, 1, 0);
|
||||
tolua_pushnumber(L, (lua_Number)self->flags);
|
||||
lua_pushinteger(L, self->flags);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -273,7 +274,7 @@ static int tolua_unit_set_magic(lua_State* L)
|
|||
static int tolua_unit_get_aura(lua_State* L)
|
||||
{
|
||||
unit* self = (unit*) tolua_tousertype(L, 1, 0);
|
||||
tolua_pushnumber(L, (lua_Number)get_spellpoints(self));
|
||||
lua_pushinteger(L, get_spellpoints(self));
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -287,7 +288,7 @@ static int tolua_unit_set_aura(lua_State* L)
|
|||
static int tolua_unit_get_age(lua_State* L)
|
||||
{
|
||||
unit* self = (unit*) tolua_tousertype(L, 1, 0);
|
||||
tolua_pushnumber(L, (lua_Number)self->age);
|
||||
lua_pushinteger(L, self->age);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -301,7 +302,7 @@ static int tolua_unit_set_age(lua_State* L)
|
|||
static int tolua_unit_get_status(lua_State* L)
|
||||
{
|
||||
unit* self = (unit*) tolua_tousertype(L, 1, 0);
|
||||
tolua_pushnumber(L, (lua_Number)unit_getstatus(self));
|
||||
lua_pushinteger(L, unit_getstatus(self));
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -325,7 +326,7 @@ tolua_unit_get_item(lua_State* L)
|
|||
result = i_get(self->items, itype);
|
||||
}
|
||||
}
|
||||
tolua_pushnumber(L, (lua_Number)result);
|
||||
lua_pushinteger(L, result);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -344,7 +345,7 @@ tolua_unit_add_item(lua_State* L)
|
|||
result = i?i->number:0;
|
||||
}
|
||||
}
|
||||
lua_pushnumber(L, (lua_Number)result);
|
||||
lua_pushinteger(L, result);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -362,7 +363,7 @@ tolua_unit_getskill(lua_State* L)
|
|||
}
|
||||
else value = 0;
|
||||
}
|
||||
lua_pushnumber(L, (lua_Number)value);
|
||||
lua_pushinteger(L, value);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -373,7 +374,7 @@ tolua_unit_effskill(lua_State* L)
|
|||
const char * skname = tolua_tostring(L, 2, 0);
|
||||
skill_t sk = sk_find(skname);
|
||||
int value = (sk==NOSKILL)?-1:eff_skill(self, sk, self->region);
|
||||
lua_pushnumber(L, (lua_Number)value);
|
||||
lua_pushinteger(L, value);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -505,17 +506,20 @@ tolua_unit_castspell(lua_State* L)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static void
|
||||
static int
|
||||
unit_addspell(unit * u, const char * name)
|
||||
{
|
||||
sc_mage * m = get_mage(u);
|
||||
spell * spadd = find_spell(m->magietyp, name);
|
||||
|
||||
if (!spadd) log_error(("spell %s could not be found\n", name));
|
||||
else {
|
||||
if (!spadd) {
|
||||
log_error(("spell %s could not be found\n", name));
|
||||
return EINVAL;
|
||||
} else {
|
||||
quicklist ** starget = get_spelllist(m, u->faction);
|
||||
add_spell(starget, spadd);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int
|
||||
|
@ -523,8 +527,9 @@ tolua_unit_addspell(lua_State* L)
|
|||
{
|
||||
unit* self = (unit*)tolua_tousertype(L, 1, 0);
|
||||
const char * str = tolua_tostring(L, 2, 0);
|
||||
unit_addspell(self, str);
|
||||
return 0;
|
||||
int err = unit_addspell(self, str);
|
||||
lua_pushinteger(L, err);
|
||||
return 1;
|
||||
}
|
||||
|
||||
static void
|
||||
|
@ -579,7 +584,7 @@ tolua_unit_setskill(lua_State* L)
|
|||
} else {
|
||||
level = -1;
|
||||
}
|
||||
lua_pushnumber(L, (lua_Number)level);
|
||||
lua_pushinteger(L, level);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -594,7 +599,7 @@ tolua_unit_use_pooled(lua_State* L)
|
|||
if (rtype!=NULL) {
|
||||
result = use_pooled(self, rtype, GET_DEFAULT, number);
|
||||
}
|
||||
lua_pushnumber(L, (lua_Number)result);
|
||||
lua_pushinteger(L, result);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -608,7 +613,7 @@ tolua_unit_get_pooled(lua_State* L)
|
|||
if (rtype!=NULL) {
|
||||
result = get_pooled(self, rtype, GET_DEFAULT, INT_MAX);
|
||||
}
|
||||
lua_pushnumber(L, (lua_Number)result);
|
||||
lua_pushinteger(L, result);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -800,14 +805,14 @@ static int tolua_unit_set_flag(lua_State* L)
|
|||
static int tolua_unit_get_weight(lua_State* L)
|
||||
{
|
||||
unit* self = (unit*) tolua_tousertype(L, 1, 0);
|
||||
tolua_pushnumber(L, (lua_Number)unit_getweight(self));
|
||||
lua_pushinteger(L, unit_getweight(self));
|
||||
return 1;
|
||||
}
|
||||
|
||||
static int tolua_unit_get_capacity(lua_State* L)
|
||||
{
|
||||
unit* self = (unit*) tolua_tousertype(L, 1, 0);
|
||||
tolua_pushnumber(L, (lua_Number)unit_getcapacity(self));
|
||||
lua_pushinteger(L, unit_getcapacity(self));
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -905,9 +910,9 @@ tolua_event_get(lua_State *L)
|
|||
if (strcmp(arg->type, "string")==0) {
|
||||
tolua_pushstring(L, (const char *)arg->data.v);
|
||||
} else if (strcmp(arg->type, "int")==0) {
|
||||
tolua_pushnumber(L, (lua_Number)arg->data.i);
|
||||
lua_pushinteger(L, arg->data.i);
|
||||
} else if (strcmp(arg->type, "float")==0) {
|
||||
tolua_pushnumber(L, (lua_Number)arg->data.f);
|
||||
lua_pushnumber(L, (lua_Number)arg->data.f);
|
||||
} else {
|
||||
/* this is pretty lazy */
|
||||
tolua_pushusertype(L, (void*)arg->data.v, TOLUA_CAST arg->type);
|
||||
|
|
Loading…
Reference in a new issue