more functions for bind_region

This commit is contained in:
Enno Rehling 2008-12-20 19:18:45 +00:00
parent 1cab3ce7f1
commit b981e0e26e
14 changed files with 200 additions and 46 deletions

View file

@ -623,3 +623,26 @@ building_addaction(building * b, const char * fname, const char * param)
}
}
region *
building_getregion(const building * b)
{
return b->region;
}
void
building_setregion(building * b, region * r)
{
building ** blist = &b->region->buildings;
while (*blist && *blist!=b) {
blist = &(*blist)->next;
}
*blist = b->next;
b->next = NULL;
blist = &r->buildings;
while (*blist && *blist!=b) blist = &(*blist)->next;
*blist = b;
b->region = r;
}

View file

@ -160,6 +160,9 @@ extern const char * buildingname(const struct building * b);
extern const char * building_getname(const struct building * b);
extern void building_setname(struct building * self, const char * name);
struct region * building_getregion(const struct building * b);
void building_setregion(struct building * bld, struct region * r);
#ifdef __cplusplus
}
#endif

View file

@ -1101,8 +1101,7 @@ terraform_region(region * r, const terrain_type * terrain)
terraform_resources(r);
if (!fval(terrain, LAND_REGION)) {
free(r->display);
r->display = NULL;
region_setinfo(r, NULL);
if (r->land!=NULL) {
i_freeall(&r->land->items);
freeland(r->land);
@ -1345,6 +1344,18 @@ region_setowner(struct region * r, struct faction * owner)
#endif
}
void
region_setinfo(struct region * r, const char * info)
{
free(r->display);
r->display = strdup(info);
}
const char *
region_getinfo(const region * r) {
return (const char *)r->display;
}
void
region_setname(struct region * r, const char * name)
{

View file

@ -248,6 +248,8 @@ const char * regionname(const struct region * r, const struct faction * f);
const char * region_getname(const struct region * self);
void region_setname(struct region * self, const char * name);
const char * region_getinfo(const struct region * self);
void region_setinfo(struct region * self, const char * name);
int region_getresource(const struct region * r, const struct resource_type * rtype);
void region_setresource(struct region * r, const struct resource_type * rtype, int value);

View file

@ -879,7 +879,9 @@ readregion(struct storage * store, short x, short y)
if (lomem) {
store->r_str_buf(store, NULL, 0);
} else {
r->display = store->r_str(store);
char info[DISPLAYSIZE];
store->r_str_buf(store, info, sizeof(info));
region_setinfo(r, info);
}
if (store->version < TERRAIN_VERSION) {
@ -998,7 +1000,7 @@ void
writeregion(struct storage * store, const region * r)
{
store->w_int(store, r->uid);
store->w_str(store, r->display?(const char *)r->display:"");
store->w_str(store, region_getinfo(r));
store->w_tok(store, r->terrain->_name);
store->w_int(store, r->flags & RF_SAVEMASK);
store->w_int(store, r->age);

View file

@ -85,30 +85,6 @@ building_setinfo(building * b, const char * info)
b->display = strdup(info);
}
static region *
building_getregion(const building * b)
{
return b->region;
}
static void
building_setregion(building * bld, region * r)
{
building * b = bld;
building ** blist = &b->region->buildings;
while (*blist && *blist!=b) {
blist = &(*blist)->next;
}
*blist = b->next;
b->next = NULL;
blist = &r->buildings;
while (*blist && *blist!=b) blist = &(*blist)->next;
*blist = b;
b->region = r;
}
static std::ostream&
operator<<(std::ostream& stream, const building& b)
{

View file

@ -86,18 +86,6 @@ region_getherbtype(const region * r) {
return itype->rtype->_name[0];
}
static void
region_setinfo(region * r, const char * info)
{
free(r->display);
r->display = strdup(info);
}
static const char *
region_getinfo(const region * r) {
return (const char *)r->display;
}
static int
region_plane(const region * r)
{

View file

@ -21,6 +21,19 @@ without prior permission by the authors of Eressea.
#include <lua.h>
#include <tolua.h>
int tolua_buildinglist_next(lua_State *tolua_S)
{
building** building_ptr = (building **)lua_touserdata(tolua_S, lua_upvalueindex(1));
building * u = *building_ptr;
if (u != NULL) {
tolua_pushusertype(tolua_S, (void*)u, "building");
*building_ptr = u->next;
return 1;
}
else return 0; /* no more values to return */
}
static int
tolua_building_addaction(lua_State* tolua_S)
{
@ -41,6 +54,21 @@ tolua_building_get_objects(lua_State* tolua_S)
return 1;
}
static int tolua_building_get_region(lua_State* tolua_S)
{
building* self = (building*) tolua_tousertype(tolua_S, 1, 0);
tolua_pushusertype(tolua_S, building_getregion(self), "region");
return 1;
}
static int tolua_building_set_region(lua_State* tolua_S)
{
building* self = (building*)tolua_tousertype(tolua_S, 1, 0);
building_setregion(self, (region*)tolua_tousertype(tolua_S, 2, 0));
return 0;
}
static int tolua_building_get_name(lua_State* tolua_S)
{
building* self = (building*) tolua_tousertype(tolua_S, 1, 0);
@ -108,6 +136,7 @@ tolua_building_open(lua_State* tolua_S)
tolua_variable(tolua_S, "id", tolua_building_get_id, NULL);
tolua_variable(tolua_S, "name", tolua_building_get_name, tolua_building_set_name);
tolua_variable(tolua_S, "units", tolua_building_get_units, NULL);
tolua_variable(tolua_S, "region", tolua_building_get_region, tolua_building_set_region);
tolua_function(tolua_S, "add_action", tolua_building_addaction);
tolua_variable(tolua_S, "objects", tolua_building_get_objects, 0);

View file

@ -15,6 +15,7 @@ extern "C" {
#endif
struct lua_State;
int tolua_buildinglist_next(struct lua_State *tolua_S);
void tolua_building_open(struct lua_State *tolua_S);
#ifdef __cplusplus

View file

@ -13,12 +13,16 @@ without prior permission by the authors of Eressea.
#include <config.h>
#include "bind_region.h"
#include "bind_unit.h"
#include "bind_ship.h"
#include "bind_building.h"
#include <kernel/region.h>
#include <kernel/unit.h>
#include <kernel/region.h>
#include <kernel/item.h>
#include <kernel/build.h>
#include <kernel/building.h>
#include <kernel/ship.h>
#include <kernel/terrain.h>
#include <attributes/key.h>
@ -50,6 +54,22 @@ tolua_region_get_id(lua_State* tolua_S)
return 1;
}
static int
tolua_region_get_x(lua_State* tolua_S)
{
region * self = (region *)tolua_tousertype(tolua_S, 1, 0);
tolua_pushnumber(tolua_S, (lua_Number)self->x);
return 1;
}
static int
tolua_region_get_y(lua_State* tolua_S)
{
region * self = (region *)tolua_tousertype(tolua_S, 1, 0);
tolua_pushnumber(tolua_S, (lua_Number)self->y);
return 1;
}
static int
tolua_region_get_terrain(lua_State* tolua_S)
{
@ -58,6 +78,21 @@ tolua_region_get_terrain(lua_State* tolua_S)
return 1;
}
static int tolua_region_get_info(lua_State* tolua_S)
{
region* self = (region*) tolua_tousertype(tolua_S, 1, 0);
tolua_pushstring(tolua_S, region_getinfo(self));
return 1;
}
static int tolua_region_set_info(lua_State* tolua_S)
{
region* self = (region*)tolua_tousertype(tolua_S, 1, 0);
region_setinfo(self, tolua_tostring(tolua_S, 2, 0));
return 0;
}
static int tolua_region_get_name(lua_State* tolua_S)
{
region* self = (region*) tolua_tousertype(tolua_S, 1, 0);
@ -65,7 +100,7 @@ static int tolua_region_get_name(lua_State* tolua_S)
return 1;
}
static int tolua_region_set_units(lua_State* tolua_S)
static int tolua_region_set_name(lua_State* tolua_S)
{
region* self = (region*)tolua_tousertype(tolua_S, 1, 0);
region_setname(self, tolua_tostring(tolua_S, 2, 0));
@ -195,6 +230,34 @@ static int tolua_region_get_units(lua_State* tolua_S)
return 1;
}
static int tolua_region_get_buildings(lua_State* tolua_S)
{
region * self = (region *)tolua_tousertype(tolua_S, 1, 0);
building ** building_ptr = (building**)lua_newuserdata(tolua_S, sizeof(building *));
luaL_getmetatable(tolua_S, "building");
lua_setmetatable(tolua_S, -2);
*building_ptr = self->buildings;
lua_pushcclosure(tolua_S, tolua_buildinglist_next, 1);
return 1;
}
static int tolua_region_get_ships(lua_State* tolua_S)
{
region * self = (region *)tolua_tousertype(tolua_S, 1, 0);
ship ** ship_ptr = (ship**)lua_newuserdata(tolua_S, sizeof(ship *));
luaL_getmetatable(tolua_S, "ship");
lua_setmetatable(tolua_S, -2);
*ship_ptr = self->ships;
lua_pushcclosure(tolua_S, tolua_shiplist_next, 1);
return 1;
}
static int
tolua_region_getkey(lua_State* tolua_S)
{
@ -237,19 +300,38 @@ tolua_region_open(lua_State* tolua_S)
tolua_cclass(tolua_S, "region", "region", "", NULL);
tolua_beginmodule(tolua_S, "region");
{
tolua_function(tolua_S, "create", tolua_region_create);
tolua_variable(tolua_S, "id", tolua_region_get_id, NULL);
tolua_variable(tolua_S, "name", tolua_region_get_name, tolua_region_set_units);
tolua_variable(tolua_S, "x", tolua_region_get_x, NULL);
tolua_variable(tolua_S, "y", tolua_region_get_y, NULL);
tolua_variable(tolua_S, "name", tolua_region_get_name, tolua_region_set_name);
tolua_variable(tolua_S, "info", tolua_region_get_info, tolua_region_set_info);
tolua_variable(tolua_S, "units", tolua_region_get_units, NULL);
tolua_variable(tolua_S, "ships", tolua_region_get_ships, NULL);
tolua_variable(tolua_S, "buildings", tolua_region_get_buildings, NULL);
tolua_variable(tolua_S, "terrain", tolua_region_get_terrain, NULL);
tolua_function(tolua_S, "get_resource", tolua_region_get_resource);
tolua_function(tolua_S, "set_resource", tolua_region_set_resource);
tolua_function(tolua_S, "get_flag", tolua_region_get_flag);
tolua_function(tolua_S, "set_flag", tolua_region_set_flag);
tolua_function(tolua_S, "create", tolua_region_create);
tolua_function(tolua_S, "get_key", tolua_region_getkey);
tolua_function(tolua_S, "set_key", tolua_region_setkey);
#if 0
.property("owner", &lua_region_getowner, &lua_region_setowner)
.property("herbtype", &region_getherbtype, &region_setherbtype)
.def("add_notice", &region_addnotice)
.def("add_direction", &region_adddirection)
.def("move", &region_move)
.def("get_road", &region_getroad)
.def("set_road", &region_setroad)
.def("next", &region_next)
.def_readwrite("age", &region::age)
.def("add_item", &region_additem)
.property("items", &region_items, return_stl_iterator)
.property("plane_id", &region_plane)
#endif
tolua_variable(tolua_S, "objects", tolua_region_get_objects, 0);
}
tolua_endmodule(tolua_S);

View file

@ -24,6 +24,18 @@ without prior permission by the authors of Eressea.
#include <lua.h>
#include <tolua.h>
int tolua_shiplist_next(lua_State *tolua_S)
{
ship** ship_ptr = (ship **)lua_touserdata(tolua_S, lua_upvalueindex(1));
ship * u = *ship_ptr;
if (u != NULL) {
tolua_pushusertype(tolua_S, (void*)u, "ship");
*ship_ptr = u->next;
return 1;
}
else return 0; /* no more values to return */
}
static int
tolua_ship_get_id(lua_State* tolua_S)
{

View file

@ -15,6 +15,7 @@ extern "C" {
#endif
struct lua_State;
int tolua_shiplist_next(struct lua_State *tolua_S);
void tolua_ship_open(struct lua_State *tolua_S);
#ifdef __cplusplus

View file

@ -584,6 +584,16 @@ tolua_get_region(lua_State* tolua_S)
return 1;
}
static int
tolua_get_region_byid(lua_State* tolua_S)
{
int uid = (int)tolua_tonumber(tolua_S, 1, 0);
region * r = findregionbyid(uid);
tolua_pushusertype(tolua_S, r, "region");
return 1;
}
static int
tolua_get_building(lua_State* tolua_S)
{
@ -726,6 +736,8 @@ tolua_eressea_open(lua_State* tolua_S)
}
tolua_endmodule(tolua_S);
tolua_function(tolua_S, "get_region_by_id", tolua_get_region_byid);
tolua_function(tolua_S, "get_faction", tolua_get_faction);
tolua_function(tolua_S, "get_unit", tolua_get_unit);
tolua_function(tolua_S, "get_alliance", tolua_get_alliance);

View file

@ -130,6 +130,11 @@ local function test_building()
units = units + 1
end
assert(units==2)
local r2 = region.create(0, 1, "plain")
assert(b.region==r)
b.region = r2
assert(b.region==r2)
assert(r2.buildings()==b)
end
local function loadscript(name)
@ -180,11 +185,18 @@ tests = {
["test_gmtool"] = test_gmtool
}
fail = 0
for k, v in pairs(tests) do
local status, err = pcall(v)
if not status then
fail = fail + 1
print("[FAIL] " .. k .. ": " .. err)
else
print("[OK] " .. k)
end
end
if fail > 0 then
print(fail .. " tests failed.")
io.stdin:read()
end