forked from github/server
replace resource_type::_name array with a single string.
This commit is contained in:
parent
4c00777553
commit
920902f8eb
10 changed files with 86 additions and 50 deletions
|
@ -228,7 +228,7 @@ static int tolua_region_get_luxury(lua_State * L)
|
||||||
if (r->land) {
|
if (r->land) {
|
||||||
const item_type *lux = r_luxury(r);
|
const item_type *lux = r_luxury(r);
|
||||||
if (lux) {
|
if (lux) {
|
||||||
const char *name = lux->rtype->_name[0];
|
const char *name = lux->rtype->_name;
|
||||||
tolua_pushstring(L, name);
|
tolua_pushstring(L, name);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -268,7 +268,7 @@ static int tolua_region_get_herb(lua_State * L)
|
||||||
{
|
{
|
||||||
region *r = (region *) tolua_tousertype(L, 1, 0);
|
region *r = (region *) tolua_tousertype(L, 1, 0);
|
||||||
if (r->land && r->land->herbtype) {
|
if (r->land && r->land->herbtype) {
|
||||||
const char *name = r->land->herbtype->rtype->_name[0];
|
const char *name = r->land->herbtype->rtype->_name;
|
||||||
tolua_pushstring(L, name);
|
tolua_pushstring(L, name);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -151,7 +151,7 @@ int tolua_itemlist_next(lua_State * L)
|
||||||
item **item_ptr = (item **) lua_touserdata(L, lua_upvalueindex(1));
|
item **item_ptr = (item **) lua_touserdata(L, lua_upvalueindex(1));
|
||||||
item *itm = *item_ptr;
|
item *itm = *item_ptr;
|
||||||
if (itm != NULL) {
|
if (itm != NULL) {
|
||||||
tolua_pushstring(L, itm->type->rtype->_name[0]);
|
tolua_pushstring(L, itm->type->rtype->_name);
|
||||||
*item_ptr = itm->next;
|
*item_ptr = itm->next;
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -820,7 +820,7 @@ static int config_get_resource(lua_State * L)
|
||||||
lua_newtable(L);
|
lua_newtable(L);
|
||||||
for (i = 0; itype->construction->materials[i].number; ++i) {
|
for (i = 0; itype->construction->materials[i].number; ++i) {
|
||||||
lua_pushstring(L,
|
lua_pushstring(L,
|
||||||
itype->construction->materials[i].rtype->_name[0]);
|
itype->construction->materials[i].rtype->_name);
|
||||||
lua_pushinteger(L, itype->construction->materials[i].number);
|
lua_pushinteger(L, itype->construction->materials[i].number);
|
||||||
lua_settable(L, -3);
|
lua_settable(L, -3);
|
||||||
}
|
}
|
||||||
|
@ -865,7 +865,7 @@ static int config_get_btype(lua_State * L)
|
||||||
lua_newtable(L);
|
lua_newtable(L);
|
||||||
for (i = 0; btype->maintenance[i].number; ++i) {
|
for (i = 0; btype->maintenance[i].number; ++i) {
|
||||||
lua_pushstring(L,
|
lua_pushstring(L,
|
||||||
btype->maintenance[i].rtype->_name[0]);
|
btype->maintenance[i].rtype->_name);
|
||||||
lua_pushinteger(L, btype->maintenance[i].number);
|
lua_pushinteger(L, btype->maintenance[i].number);
|
||||||
lua_settable(L, -3);
|
lua_settable(L, -3);
|
||||||
}
|
}
|
||||||
|
@ -884,7 +884,7 @@ static int config_get_btype(lua_State * L)
|
||||||
lua_newtable(L);
|
lua_newtable(L);
|
||||||
for (i = 0; btype->construction->materials[i].number; ++i) {
|
for (i = 0; btype->construction->materials[i].number; ++i) {
|
||||||
lua_pushstring(L,
|
lua_pushstring(L,
|
||||||
btype->construction->materials[i].rtype->_name[0]);
|
btype->construction->materials[i].rtype->_name);
|
||||||
lua_pushinteger(L, btype->construction->materials[i].number);
|
lua_pushinteger(L, btype->construction->materials[i].number);
|
||||||
lua_settable(L, -3);
|
lua_settable(L, -3);
|
||||||
}
|
}
|
||||||
|
@ -950,7 +950,7 @@ static int config_get_stype(lua_State * L)
|
||||||
lua_newtable(L);
|
lua_newtable(L);
|
||||||
for (i = 0; stype->construction->materials[i].number; ++i) {
|
for (i = 0; stype->construction->materials[i].number; ++i) {
|
||||||
lua_pushstring(L,
|
lua_pushstring(L,
|
||||||
stype->construction->materials[i].rtype->_name[0]);
|
stype->construction->materials[i].rtype->_name);
|
||||||
lua_pushinteger(L, stype->construction->materials[i].number);
|
lua_pushinteger(L, stype->construction->materials[i].number);
|
||||||
lua_settable(L, -3);
|
lua_settable(L, -3);
|
||||||
}
|
}
|
||||||
|
|
|
@ -46,7 +46,7 @@ lua_giveitem(unit * s, unit * d, const item_type * itype, int n, struct order *o
|
||||||
lua_State *L = (lua_State *) global.vm_state;
|
lua_State *L = (lua_State *) global.vm_state;
|
||||||
char fname[64];
|
char fname[64];
|
||||||
int result = -1;
|
int result = -1;
|
||||||
const char *iname = itype->rtype->_name[0];
|
const char *iname = itype->rtype->_name;
|
||||||
|
|
||||||
assert(s != NULL);
|
assert(s != NULL);
|
||||||
strlcpy(fname, iname, sizeof(fname));
|
strlcpy(fname, iname, sizeof(fname));
|
||||||
|
@ -81,7 +81,7 @@ static int limit_resource(const region * r, const resource_type * rtype)
|
||||||
int result = -1;
|
int result = -1;
|
||||||
lua_State *L = (lua_State *) global.vm_state;
|
lua_State *L = (lua_State *) global.vm_state;
|
||||||
|
|
||||||
strlcpy(fname, rtype->_name[0], sizeof(fname));
|
strlcpy(fname, rtype->_name, sizeof(fname));
|
||||||
strlcat(fname, "_limit", sizeof(fname));
|
strlcat(fname, "_limit", sizeof(fname));
|
||||||
|
|
||||||
lua_getglobal(L, fname);
|
lua_getglobal(L, fname);
|
||||||
|
@ -110,7 +110,7 @@ produce_resource(region * r, const resource_type * rtype, int norders)
|
||||||
lua_State *L = (lua_State *) global.vm_state;
|
lua_State *L = (lua_State *) global.vm_state;
|
||||||
char fname[64];
|
char fname[64];
|
||||||
|
|
||||||
strlcpy(fname, rtype->_name[0], sizeof(fname));
|
strlcpy(fname, rtype->_name, sizeof(fname));
|
||||||
strlcat(fname, "_produce", sizeof(fname));
|
strlcat(fname, "_produce", sizeof(fname));
|
||||||
|
|
||||||
lua_getglobal(L, fname);
|
lua_getglobal(L, fname);
|
||||||
|
@ -250,7 +250,7 @@ lua_changeresource(unit * u, const struct resource_type *rtype, int delta)
|
||||||
int result = -1;
|
int result = -1;
|
||||||
char fname[64];
|
char fname[64];
|
||||||
|
|
||||||
strlcpy(fname, rtype->_name[0], sizeof(fname));
|
strlcpy(fname, rtype->_name, sizeof(fname));
|
||||||
strlcat(fname, "_changeresource", sizeof(fname));
|
strlcat(fname, "_changeresource", sizeof(fname));
|
||||||
|
|
||||||
lua_getglobal(L, fname);
|
lua_getglobal(L, fname);
|
||||||
|
@ -280,7 +280,7 @@ static int lua_getresource(unit * u, const struct resource_type *rtype)
|
||||||
int result = -1;
|
int result = -1;
|
||||||
char fname[64];
|
char fname[64];
|
||||||
|
|
||||||
strlcpy(fname, rtype->_name[0], sizeof(fname));
|
strlcpy(fname, rtype->_name, sizeof(fname));
|
||||||
strlcat(fname, "_getresource", sizeof(fname));
|
strlcat(fname, "_getresource", sizeof(fname));
|
||||||
|
|
||||||
lua_getglobal(L, fname);
|
lua_getglobal(L, fname);
|
||||||
|
@ -315,7 +315,7 @@ static bool lua_canuse_item(const unit * u, const struct item_type *itype)
|
||||||
lua_getglobal(L, fname);
|
lua_getglobal(L, fname);
|
||||||
if (lua_isfunction(L, -1)) {
|
if (lua_isfunction(L, -1)) {
|
||||||
tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit");
|
tolua_pushusertype(L, (void *)u, TOLUA_CAST "unit");
|
||||||
tolua_pushstring(L, itype->rtype->_name[0]);
|
tolua_pushstring(L, itype->rtype->_name);
|
||||||
|
|
||||||
if (lua_pcall(L, 2, 1, 0) != 0) {
|
if (lua_pcall(L, 2, 1, 0) != 0) {
|
||||||
const char *error = lua_tostring(L, -1);
|
const char *error = lua_tostring(L, -1);
|
||||||
|
@ -503,7 +503,7 @@ lua_useitem(struct unit *u, const struct item_type *itype, int amount,
|
||||||
char fname[64];
|
char fname[64];
|
||||||
|
|
||||||
strlcpy(fname, "use_", sizeof(fname));
|
strlcpy(fname, "use_", sizeof(fname));
|
||||||
strlcat(fname, itype->rtype->_name[0], sizeof(fname));
|
strlcat(fname, itype->rtype->_name, sizeof(fname));
|
||||||
|
|
||||||
lua_getglobal(L, fname);
|
lua_getglobal(L, fname);
|
||||||
if (lua_isfunction(L, -1)) {
|
if (lua_isfunction(L, -1)) {
|
||||||
|
|
|
@ -139,18 +139,25 @@ static int res_changeitem(unit * u, const resource_type * rtype, int delta)
|
||||||
|
|
||||||
const char *resourcename(const resource_type * rtype, int flags)
|
const char *resourcename(const resource_type * rtype, int flags)
|
||||||
{
|
{
|
||||||
int i = 0;
|
if (!rtype)
|
||||||
|
assert(rtype);
|
||||||
if (rtype) {
|
if (rtype) {
|
||||||
if (rtype->name)
|
if (rtype->name)
|
||||||
return rtype->name(rtype, flags);
|
return rtype->name(rtype, flags);
|
||||||
|
|
||||||
if (flags & NMF_PLURAL)
|
if (flags & NMF_APPEARANCE && rtype->itype) {
|
||||||
i = 1;
|
int i = (flags & NMF_PLURAL) ? 1 : 0;
|
||||||
if (flags & NMF_APPEARANCE && rtype->itype && rtype->itype->_appearance[i]) {
|
const char * result = rtype->itype->_appearance[i];
|
||||||
return rtype->itype->_appearance[i];
|
if (result) {
|
||||||
|
return result;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return rtype->_name[i];
|
if (flags & NMF_PLURAL) {
|
||||||
|
static char name[64]; // FIXME: static return value
|
||||||
|
_snprintf(name, sizeof(name), "%s_p", rtype->_name);
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
return rtype->_name;
|
||||||
}
|
}
|
||||||
return "none";
|
return "none";
|
||||||
}
|
}
|
||||||
|
@ -160,7 +167,7 @@ static int num_resources;
|
||||||
static void rt_register(resource_type * rtype)
|
static void rt_register(resource_type * rtype)
|
||||||
{
|
{
|
||||||
char buffer[64];
|
char buffer[64];
|
||||||
const char * name = rtype->_name[0];
|
const char * name = rtype->_name;
|
||||||
size_t len = strlen(name);
|
size_t len = strlen(name);
|
||||||
|
|
||||||
assert(len < sizeof(buffer) - sizeof(rtype));
|
assert(len < sizeof(buffer) - sizeof(rtype));
|
||||||
|
@ -173,9 +180,7 @@ resource_type *rt_get_or_create(const char *name) {
|
||||||
resource_type *rtype = rt_find(name);
|
resource_type *rtype = rt_find(name);
|
||||||
if (!rtype) {
|
if (!rtype) {
|
||||||
rtype = (resource_type *)calloc(sizeof(resource_type), 1);
|
rtype = (resource_type *)calloc(sizeof(resource_type), 1);
|
||||||
rtype->_name[0] = _strdup(name);
|
rtype->_name = _strdup(name);
|
||||||
rtype->_name[1] = (char *)malloc(strlen(name) + 3);
|
|
||||||
sprintf(rtype->_name[1], "%s_p", name);
|
|
||||||
rt_register(rtype);
|
rt_register(rtype);
|
||||||
}
|
}
|
||||||
return rtype;
|
return rtype;
|
||||||
|
@ -184,7 +189,7 @@ resource_type *rt_get_or_create(const char *name) {
|
||||||
void it_register(item_type * itype)
|
void it_register(item_type * itype)
|
||||||
{
|
{
|
||||||
char buffer[64];
|
char buffer[64];
|
||||||
const char * name = itype->rtype->_name[0];
|
const char * name = itype->rtype->_name;
|
||||||
size_t len = strlen(name);
|
size_t len = strlen(name);
|
||||||
|
|
||||||
assert(len < sizeof(buffer) - sizeof(itype));
|
assert(len < sizeof(buffer) - sizeof(itype));
|
||||||
|
@ -225,7 +230,7 @@ item_type *it_find(const char *zname)
|
||||||
item_type *it_get_or_create(resource_type *rtype) {
|
item_type *it_get_or_create(resource_type *rtype) {
|
||||||
item_type * itype;
|
item_type * itype;
|
||||||
assert(rtype);
|
assert(rtype);
|
||||||
itype = it_find(rtype->_name[0]);
|
itype = it_find(rtype->_name);
|
||||||
assert(!itype || !itype->rtype || itype->rtype == rtype);
|
assert(!itype || !itype->rtype || itype->rtype == rtype);
|
||||||
if (!itype) {
|
if (!itype) {
|
||||||
itype = (item_type *)calloc(sizeof(item_type), 1);
|
itype = (item_type *)calloc(sizeof(item_type), 1);
|
||||||
|
@ -409,7 +414,7 @@ item *i_add(item ** pi, item * i)
|
||||||
{
|
{
|
||||||
assert(i && i->type && !i->next);
|
assert(i && i->type && !i->next);
|
||||||
while (*pi) {
|
while (*pi) {
|
||||||
int d = strcmp((*pi)->type->rtype->_name[0], i->type->rtype->_name[0]);
|
int d = strcmp((*pi)->type->rtype->_name, i->type->rtype->_name);
|
||||||
if (d >= 0)
|
if (d >= 0)
|
||||||
break;
|
break;
|
||||||
pi = &(*pi)->next;
|
pi = &(*pi)->next;
|
||||||
|
@ -432,7 +437,7 @@ void i_merge(item ** pi, item ** si)
|
||||||
while (i) {
|
while (i) {
|
||||||
item *itmp;
|
item *itmp;
|
||||||
while (*pi) {
|
while (*pi) {
|
||||||
int d = strcmp((*pi)->type->rtype->_name[0], i->type->rtype->_name[0]);
|
int d = strcmp((*pi)->type->rtype->_name, i->type->rtype->_name);
|
||||||
if (d >= 0)
|
if (d >= 0)
|
||||||
break;
|
break;
|
||||||
pi = &(*pi)->next;
|
pi = &(*pi)->next;
|
||||||
|
@ -456,7 +461,7 @@ item *i_change(item ** pi, const item_type * itype, int delta)
|
||||||
{
|
{
|
||||||
assert(itype);
|
assert(itype);
|
||||||
while (*pi) {
|
while (*pi) {
|
||||||
int d = strcmp((*pi)->type->rtype->_name[0], itype->rtype->_name[0]);
|
int d = strcmp((*pi)->type->rtype->_name, itype->rtype->_name);
|
||||||
if (d >= 0)
|
if (d >= 0)
|
||||||
break;
|
break;
|
||||||
pi = &(*pi)->next;
|
pi = &(*pi)->next;
|
||||||
|
@ -1044,7 +1049,7 @@ static int add_resourcename_cb(const void * match, const void * key, size_t keyl
|
||||||
cb_get_kv(match, &rtype, sizeof(rtype));
|
cb_get_kv(match, &rtype, sizeof(rtype));
|
||||||
for (i = 0; i != 2; ++i) {
|
for (i = 0; i != 2; ++i) {
|
||||||
char buffer[128];
|
char buffer[128];
|
||||||
const char * name = locale_string(lang, rtype->_name[i]);
|
const char * name = locale_string(lang, resourcename(rtype, (i==0) ? 0 : NMF_PLURAL));
|
||||||
|
|
||||||
if (name && transliterate(buffer, sizeof(buffer), name)) {
|
if (name && transliterate(buffer, sizeof(buffer), name)) {
|
||||||
size_t len = strlen(buffer);
|
size_t len = strlen(buffer);
|
||||||
|
@ -1095,7 +1100,7 @@ static int add_itemname_cb(const void * match, const void * key, size_t keylen,
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i != 2; ++i) {
|
for (i = 0; i != 2; ++i) {
|
||||||
char buffer[128];
|
char buffer[128];
|
||||||
const char * name = locale_string(lang, rtype->_name[i]);
|
const char * name = locale_string(lang, resourcename(rtype, (i == 0) ? 0 : NMF_PLURAL));
|
||||||
|
|
||||||
if (name && transliterate(buffer, sizeof(buffer), name)) {
|
if (name && transliterate(buffer, sizeof(buffer), name)) {
|
||||||
size_t len = strlen(buffer);
|
size_t len = strlen(buffer);
|
||||||
|
@ -1180,8 +1185,7 @@ int free_itype_cb(const void * match, const void * key, size_t keylen, void *cbd
|
||||||
int free_rtype_cb(const void * match, const void * key, size_t keylen, void *cbdata) {
|
int free_rtype_cb(const void * match, const void * key, size_t keylen, void *cbdata) {
|
||||||
resource_type *rtype;
|
resource_type *rtype;
|
||||||
cb_get_kv(match, &rtype, sizeof(rtype));
|
cb_get_kv(match, &rtype, sizeof(rtype));
|
||||||
free(rtype->_name[0]);
|
free(rtype->_name);
|
||||||
free(rtype->_name[1]);
|
|
||||||
free(rtype);
|
free(rtype);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,7 +64,7 @@ extern "C" {
|
||||||
typedef char *(*rtype_name) (const struct resource_type * rtype, int flags);
|
typedef char *(*rtype_name) (const struct resource_type * rtype, int flags);
|
||||||
typedef struct resource_type {
|
typedef struct resource_type {
|
||||||
/* --- constants --- */
|
/* --- constants --- */
|
||||||
char *_name[2]; /* wie es heißt */
|
char *_name; /* wie es heißt */
|
||||||
unsigned int flags;
|
unsigned int flags;
|
||||||
/* --- functions --- */
|
/* --- functions --- */
|
||||||
rtype_uchange uchange;
|
rtype_uchange uchange;
|
||||||
|
@ -254,7 +254,6 @@ extern "C" {
|
||||||
|
|
||||||
/* creation */
|
/* creation */
|
||||||
resource_type *rt_get_or_create(const char *name);
|
resource_type *rt_get_or_create(const char *name);
|
||||||
// resource_type *new_resourcetype(const char **names, const char **appearances, int flags);
|
|
||||||
item_type *it_get_or_create(resource_type *rtype);
|
item_type *it_get_or_create(resource_type *rtype);
|
||||||
extern item_type *new_itemtype(resource_type * rtype, int iflags, int weight,
|
extern item_type *new_itemtype(resource_type * rtype, int iflags, int weight,
|
||||||
int capacity);
|
int capacity);
|
||||||
|
|
|
@ -10,6 +10,38 @@
|
||||||
#include <CuTest.h>
|
#include <CuTest.h>
|
||||||
#include <tests.h>
|
#include <tests.h>
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
|
static void test_resourcename_no_appearance(CuTest *tc) {
|
||||||
|
const resource_type *rtype;
|
||||||
|
|
||||||
|
test_cleanup();
|
||||||
|
init_resources(); // creates R_SILVER
|
||||||
|
rtype = get_resourcetype(R_SILVER);
|
||||||
|
assert(rtype && rtype->itype);
|
||||||
|
assert(rtype->itype->_appearance[0] == 0);
|
||||||
|
assert(rtype->itype->_appearance[1] == 0);
|
||||||
|
CuAssertStrEquals(tc, "money", resourcename(rtype, 0));
|
||||||
|
CuAssertStrEquals(tc, "money_p", resourcename(rtype, NMF_PLURAL));
|
||||||
|
CuAssertStrEquals(tc, "money", resourcename(rtype, NMF_APPEARANCE));
|
||||||
|
CuAssertStrEquals(tc, "money_p", resourcename(rtype, NMF_APPEARANCE|NMF_PLURAL));
|
||||||
|
test_cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_resourcename_with_appearance(CuTest *tc) {
|
||||||
|
item_type *itype;
|
||||||
|
|
||||||
|
test_cleanup();
|
||||||
|
itype = it_get_or_create(rt_get_or_create("foo"));
|
||||||
|
assert(itype && itype->rtype);
|
||||||
|
it_set_appearance(itype, "bar");
|
||||||
|
CuAssertStrEquals(tc, "foo", resourcename(itype->rtype, 0));
|
||||||
|
CuAssertStrEquals(tc, "foo_p", resourcename(itype->rtype, NMF_PLURAL));
|
||||||
|
CuAssertStrEquals(tc, "bar", resourcename(itype->rtype, NMF_APPEARANCE));
|
||||||
|
CuAssertStrEquals(tc, "bar_p", resourcename(itype->rtype, NMF_APPEARANCE | NMF_PLURAL));
|
||||||
|
test_cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
static void test_uchange(CuTest * tc, unit * u, const resource_type * rtype) {
|
static void test_uchange(CuTest * tc, unit * u, const resource_type * rtype) {
|
||||||
int n;
|
int n;
|
||||||
change_resource(u, rtype, 4);
|
change_resource(u, rtype, 4);
|
||||||
|
@ -26,7 +58,6 @@ void test_change_item(CuTest * tc)
|
||||||
unit * u;
|
unit * u;
|
||||||
|
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
register_resources();
|
|
||||||
init_resources();
|
init_resources();
|
||||||
test_create_world();
|
test_create_world();
|
||||||
|
|
||||||
|
@ -103,6 +134,8 @@ void test_findresourcetype(CuTest * tc)
|
||||||
CuSuite *get_item_suite(void)
|
CuSuite *get_item_suite(void)
|
||||||
{
|
{
|
||||||
CuSuite *suite = CuSuiteNew();
|
CuSuite *suite = CuSuiteNew();
|
||||||
|
SUITE_ADD_TEST(suite, test_resourcename_no_appearance);
|
||||||
|
SUITE_ADD_TEST(suite, test_resourcename_with_appearance);
|
||||||
SUITE_ADD_TEST(suite, test_change_item);
|
SUITE_ADD_TEST(suite, test_change_item);
|
||||||
SUITE_ADD_TEST(suite, test_change_person);
|
SUITE_ADD_TEST(suite, test_change_person);
|
||||||
SUITE_ADD_TEST(suite, test_resource_type);
|
SUITE_ADD_TEST(suite, test_resource_type);
|
||||||
|
|
|
@ -61,7 +61,7 @@ int get_resource(const unit * u, const resource_type * rtype)
|
||||||
if (rtype == get_resourcetype(R_PERMAURA)) {
|
if (rtype == get_resourcetype(R_PERMAURA)) {
|
||||||
return max_spellpoints(u->region, u);
|
return max_spellpoints(u->region, u);
|
||||||
}
|
}
|
||||||
log_error("trying to get unknown resource '%s'.\n", rtype->_name[0]);
|
log_error("trying to get unknown resource '%s'.\n", rtype->_name);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -80,7 +80,7 @@ int change_resource(unit * u, const resource_type * rtype, int change)
|
||||||
assert(i == get_resource(u, rtype));
|
assert(i == get_resource(u, rtype));
|
||||||
assert(i >= 0);
|
assert(i >= 0);
|
||||||
if (i >= 100000000) {
|
if (i >= 100000000) {
|
||||||
log_warning("%s has %d %s\n", unitname(u), i, rtype->_name[0]);
|
log_warning("%s has %d %s\n", unitname(u), i, rtype->_name);
|
||||||
}
|
}
|
||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
|
@ -411,7 +411,7 @@ void read_items(struct storage *store, item ** ilist)
|
||||||
rtype = rt_find(ibuf);
|
rtype = rt_find(ibuf);
|
||||||
READ_INT(store, &i);
|
READ_INT(store, &i);
|
||||||
if (i <= 0) {
|
if (i <= 0) {
|
||||||
log_error("data contains an entry with %d %s\n", i, rtype->_name[1]);
|
log_error("data contains an entry with %d %s\n", i, resourcename(rtype, NMF_PLURAL));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (rtype && rtype->itype) {
|
if (rtype && rtype->itype) {
|
||||||
|
|
|
@ -776,7 +776,7 @@ static weapon_type *xml_readweapon(xmlXPathContextPtr xpath, item_type * itype)
|
||||||
|
|
||||||
parse_function(node, &fun, &propValue);
|
parse_function(node, &fun, &propValue);
|
||||||
if (fun == NULL) {
|
if (fun == NULL) {
|
||||||
log_error("unknown function name '%s' for item '%s'\n", (const char *)propValue, itype->rtype->_name[0]);
|
log_error("unknown function name '%s' for item '%s'\n", (const char *)propValue, itype->rtype->_name);
|
||||||
xmlFree(propValue);
|
xmlFree(propValue);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -786,7 +786,7 @@ static weapon_type *xml_readweapon(xmlXPathContextPtr xpath, item_type * itype)
|
||||||
(bool(*)(const struct troop *, const struct weapon_type *,
|
(bool(*)(const struct troop *, const struct weapon_type *,
|
||||||
int *))fun;
|
int *))fun;
|
||||||
} else {
|
} else {
|
||||||
log_error("unknown function type '%s' for item '%s'\n", (const char *)propValue, itype->rtype->_name[0]);
|
log_error("unknown function type '%s' for item '%s'\n", (const char *)propValue, itype->rtype->_name);
|
||||||
}
|
}
|
||||||
xmlFree(propValue);
|
xmlFree(propValue);
|
||||||
}
|
}
|
||||||
|
@ -880,7 +880,7 @@ static item_type *xml_readitem(xmlXPathContextPtr xpath, resource_type * rtype)
|
||||||
|
|
||||||
parse_function(node, &fun, &propValue);
|
parse_function(node, &fun, &propValue);
|
||||||
if (fun == NULL) {
|
if (fun == NULL) {
|
||||||
log_error("unknown function name '%s' for item '%s'\n", (const char *)propValue, rtype->_name[0]);
|
log_error("unknown function name '%s' for item '%s'\n", (const char *)propValue, rtype->_name);
|
||||||
xmlFree(propValue);
|
xmlFree(propValue);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -901,7 +901,7 @@ static item_type *xml_readitem(xmlXPathContextPtr xpath, resource_type * rtype)
|
||||||
(int (*)(struct unit *, int, const struct item_type *, int,
|
(int (*)(struct unit *, int, const struct item_type *, int,
|
||||||
struct order *))fun;
|
struct order *))fun;
|
||||||
} else {
|
} else {
|
||||||
log_error("unknown function type '%s' for item '%s'\n", (const char *)propValue, rtype->_name[0]);
|
log_error("unknown function type '%s' for item '%s'\n", (const char *)propValue, rtype->_name);
|
||||||
}
|
}
|
||||||
xmlFree(propValue);
|
xmlFree(propValue);
|
||||||
}
|
}
|
||||||
|
@ -997,7 +997,7 @@ static int parse_resources(xmlDocPtr doc)
|
||||||
|
|
||||||
parse_function(node, &fun, &propValue);
|
parse_function(node, &fun, &propValue);
|
||||||
if (fun == NULL) {
|
if (fun == NULL) {
|
||||||
log_error("unknown function name '%s' for resource %s\n", (const char *)propValue, rtype->_name[0]);
|
log_error("unknown function name '%s' for resource %s\n", (const char *)propValue, rtype->_name);
|
||||||
xmlFree(propValue);
|
xmlFree(propValue);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -1010,7 +1010,7 @@ static int parse_resources(xmlDocPtr doc)
|
||||||
} else if (strcmp((const char *)propValue, "name") == 0) {
|
} else if (strcmp((const char *)propValue, "name") == 0) {
|
||||||
rtype->name = (rtype_name) fun;
|
rtype->name = (rtype_name) fun;
|
||||||
} else {
|
} else {
|
||||||
log_error("unknown function type '%s' for resource %s\n", (const char *)propValue, rtype->_name[0]);
|
log_error("unknown function type '%s' for resource %s\n", (const char *)propValue, rtype->_name);
|
||||||
}
|
}
|
||||||
xmlFree(propValue);
|
xmlFree(propValue);
|
||||||
}
|
}
|
||||||
|
@ -1077,7 +1077,7 @@ static int parse_resources(xmlDocPtr doc)
|
||||||
xmlFree(propBldg);
|
xmlFree(propBldg);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
log_error("unknown type '%s' for resourcelimit-modifier '%s'\n", (const char *)propValue, rtype->_name[0]);
|
log_error("unknown type '%s' for resourcelimit-modifier '%s'\n", (const char *)propValue, rtype->_name);
|
||||||
}
|
}
|
||||||
xmlFree(propValue);
|
xmlFree(propValue);
|
||||||
}
|
}
|
||||||
|
@ -1112,7 +1112,7 @@ static int parse_resources(xmlDocPtr doc)
|
||||||
assert(propValue != NULL);
|
assert(propValue != NULL);
|
||||||
fun = get_function((const char *)propValue);
|
fun = get_function((const char *)propValue);
|
||||||
if (fun == NULL) {
|
if (fun == NULL) {
|
||||||
log_error("unknown limit '%s' for resource %s\n", (const char *)propValue, rtype->_name[0]);
|
log_error("unknown limit '%s' for resource %s\n", (const char *)propValue, rtype->_name);
|
||||||
xmlFree(propValue);
|
xmlFree(propValue);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -1125,7 +1125,7 @@ static int parse_resources(xmlDocPtr doc)
|
||||||
} else if (strcmp((const char *)propValue, "limit") == 0) {
|
} else if (strcmp((const char *)propValue, "limit") == 0) {
|
||||||
rdata->limit = (rlimit_limit) fun;
|
rdata->limit = (rlimit_limit) fun;
|
||||||
} else {
|
} else {
|
||||||
log_error("unknown limit '%s' for resource %s\n", (const char *)propValue, rtype->_name[0]);
|
log_error("unknown limit '%s' for resource %s\n", (const char *)propValue, rtype->_name);
|
||||||
}
|
}
|
||||||
xmlFree(propValue);
|
xmlFree(propValue);
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,7 +78,7 @@ static void giveitem_write(const trigger * t, struct storage *store)
|
||||||
giveitem_data *td = (giveitem_data *) t->data.v;
|
giveitem_data *td = (giveitem_data *) t->data.v;
|
||||||
write_unit_reference(td->u, store);
|
write_unit_reference(td->u, store);
|
||||||
WRITE_INT(store, td->number);
|
WRITE_INT(store, td->number);
|
||||||
WRITE_TOK(store, td->itype->rtype->_name[0]);
|
WRITE_TOK(store, td->itype->rtype->_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int giveitem_read(trigger * t, struct storage *store)
|
static int giveitem_read(trigger * t, struct storage *store)
|
||||||
|
|
Loading…
Reference in a new issue